Skip to main content

Interactive wizard for Tuya Library

Project description

Tuya Wizard

tuyawizard is a powerful and interactive CLI tool and Python library designed to help you discover and manage devices registered on the Tuya Cloud. It simplifies the authentication process using QR code login via the Smart Life or Tuya Smart app.


Features

  • Easy Authentication: Support for QR code login using the Smart Life or Tuya Smart mobile apps.
  • Automatic Token Management: Automatically handles and refreshes cloud tokens.
  • Device Discovery: Fetches a comprehensive list of all registered devices and their details.
  • Flexible Usage: Use it as a standalone CLI tool or integrate it into your own Python projects.
  • Refactored & Typed: Modern Python implementation with type hints and improved error handling.

Installation

Install the package via pip:

pip install tuyawizard

To enable the local network scan feature, install the optional dependency:

pip install rustuya

When tuyawizard was installed with pipx, inject it into the same venv instead:

pipx inject tuyawizard rustuya

cryptography (upstream missing dependency)

tuyawizard itself does not depend on cryptography, but the underlying tuya-device-sharing-sdk imports it without declaring it in its own requirements. If ModuleNotFoundError: No module named 'cryptography' appears at runtime, install it manually:

pip install cryptography

When tuyawizard was installed with pipx, inject it into the same venv instead:

pipx inject tuyawizard cryptography

(The bundled Windows .exe already includes it, so this only affects pip/pipx-installed setups.)

Windows Executable

A pre-built single-file tuyawizard.exe is available on the Releases page. Download tuyawizard-windows.zip, extract it, and run tuyawizard.exe. No Python install required; the scan feature is bundled.

The executable is not code-signed, so Windows SmartScreen or antivirus software may warn on first run. Click More info → Run anyway to proceed.


Quick Start (CLI)

You can run the wizard directly from your terminal:

python -m tuyawizard

Command-line Options

Option Default Description
-device-file FILE tuyadevices.json Path to save the discovered devices list (JSON).
-credentials-file FILE tuyacreds.json Path to load/save cloud authentication credentials (JSON).
--postprocess false Run postprocess after fetching devices.
--postprocess-only false Run postprocess only (skip wizard login/fetch).
--postprocess-mode all Select postprocess mode: parent, scan, all.

Post process

  • parent: In the post‑process stage, the output JSON is adjusted so that each subdevice is properly linked to its parent device.
  • scan: The output JSON is enriched with IP and version details obtained through the realtime scanner (requires rustuya).

Postprocess Examples

Run wizard and then postprocess:

python -m tuyawizard --postprocess

Run postprocess only:

python -m tuyawizard --postprocess-only

Run parent-only postprocess:

python -m tuyawizard --postprocess-only --postprocess-mode parent

Run scan-only postprocess:

python -m tuyawizard --postprocess-only --postprocess-mode scan

Using as a Python Module

tuyawizard can also be imported and used as a module inside your own Python project — fetch the device list from the Tuya cloud and, optionally, enrich it with LAN scan data.

With rustuya installed

If rustuya is installed, just call postprocess_devices after fetching — it runs the LAN scan and merges the results in one step:

from tuyawizard import TuyaWizard, postprocess_devices

tuya = TuyaWizard()
tuya.login_auto(user_code="YOUR_USER_CODE")
devices = tuya.fetch_devices()

postprocess_devices(devices, mode="scan")  # scans via rustuya and merges

Without rustuya (inject your own scan data)

If rustuya is not available but you already have id/ip(/version) data collected from elsewhere (for example via rustuya-bridge), inject those results directly. version is optional per item:

from tuyawizard import TuyaWizard, apply_scan_results

tuya = TuyaWizard()
tuya.login_auto(user_code="YOUR_USER_CODE")
devices = tuya.fetch_devices()

scan_results = [
    {"id": "bf...01", "ip": "192.168.1.10"},
    {"id": "bf...02", "ip": "192.168.1.11", "version": "3.4"},
]
apply_scan_results(devices, scan_results)

Lifecycle and cleanup (close() / context manager, v0.1.9+)

The underlying tuya_sharing SDK does not fully tear down on Manager.unload() — its requests.Session connection pool is left open, and the optional SharingMQ background thread (if started) is not stopped. Long-running consumers that build a fresh TuyaWizard per operation will accumulate state (rustuya-manager observed ~750-950 KB RSS per cycle, never reclaimed).

Use the context-manager form to make teardown deterministic:

from tuyawizard import TuyaWizard

with TuyaWizard() as tuya:
    tuya.login_auto(user_code="YOUR_USER_CODE")
    devices = tuya.fetch_devices()
# close() is called on exit — sessions closed, MQ thread joined.
# Saved tokens stay valid so the next run can skip the QR scan.

Or call close() explicitly from a finally block. It is idempotent and safe before login_auto() (partial-construction tolerant).

revoke_terminal (default False): by default close() only releases local resources. The cloud-side access/refresh tokens stored in info_file remain valid so the next TuyaWizard invocation can skip the QR scan. Only pass close(revoke_terminal=True) on an explicit logout where the saved credentials should be invalidated — this triggers Manager.unload() which POSTs to Tuya's /v1.0/m/token/terminal/expire endpoint and kills the tokens server-side. Long-running services that reuse the credentials file across runs must leave the default; otherwise every subsequent run will hit the QR fallback.


How to get User Code

  1. Open the Smart Life or Tuya Smart app.
  2. Go to Me (Profile) tab.
  3. Tap on the Settings icon in the top right corner.
  4. Go to Account and Security.
  5. You will find your User Code (or Account ID) there.

Output Files

  • tuyacreds.json: Contains sensitive authentication tokens and endpoint information. Keep this file secure.
  • tuyadevices.json: A structured JSON list of all your Tuya devices and their properties.

Notes

  • Client Credentials: This tool currently uses temporary Home Assistant client credentials. These are intended to be replaced when official 3rd-party developer credentials become more widely available.
  • Python Version: Requires Python 3.8 or higher.

License

This project is licensed under the MIT License.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tuyawizard-0.1.9.tar.gz (15.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tuyawizard-0.1.9-py3-none-any.whl (11.6 kB view details)

Uploaded Python 3

File details

Details for the file tuyawizard-0.1.9.tar.gz.

File metadata

  • Download URL: tuyawizard-0.1.9.tar.gz
  • Upload date:
  • Size: 15.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tuyawizard-0.1.9.tar.gz
Algorithm Hash digest
SHA256 180d8690a5be83684d9f19878ae862842bdb9228b0c020c1f587a3c3595bdc19
MD5 4bc977173cc4af3d2a1204b1d8c59b3b
BLAKE2b-256 b7a21964e2a55872300b886c7ad2a7d30ce244ae17078758b652e5bcfa5802d7

See more details on using hashes here.

Provenance

The following attestation bundles were made for tuyawizard-0.1.9.tar.gz:

Publisher: release.yml on 3735943886/tuyawizard

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file tuyawizard-0.1.9-py3-none-any.whl.

File metadata

  • Download URL: tuyawizard-0.1.9-py3-none-any.whl
  • Upload date:
  • Size: 11.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tuyawizard-0.1.9-py3-none-any.whl
Algorithm Hash digest
SHA256 ccab709fad3e116af0e5a5a58419933862e4866ed48b808211e9f42995e4d49e
MD5 f6ae573ef7a6446deb3fa5f79bb3df30
BLAKE2b-256 4a77e1abbf2abdab556dabf5261a059681f0d2aa1d9df69d9ff3388f4df33b13

See more details on using hashes here.

Provenance

The following attestation bundles were made for tuyawizard-0.1.9-py3-none-any.whl:

Publisher: release.yml on 3735943886/tuyawizard

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page