Metadata-Version: 2.4
Name: myhisense-tv
Version: 1.6.1
Summary: Control Hisense/Vidaa Smart TVs via MQTT
Home-page: https://github.com/warrenrees/myhisense-tv
Author: Warren Rees
Author-email: 
Project-URL: Bug Tracker, https://github.com/warrenrees/myhisense-tv/issues
Project-URL: Documentation, https://github.com/warrenrees/myhisense-tv#readme
Project-URL: Source Code, https://github.com/warrenrees/myhisense-tv
Project-URL: Changelog, https://github.com/warrenrees/myhisense-tv/blob/main/CHANGELOG.md
Keywords: hisense myhisense vidaa tv mqtt smart-tv home-automation
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: End Users/Desktop
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: Home Automation
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Requires-Python: >=3.8
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: paho-mqtt>=1.6.0
Requires-Dist: pyyaml>=6.0
Dynamic: author
Dynamic: classifier
Dynamic: description
Dynamic: description-content-type
Dynamic: home-page
Dynamic: keywords
Dynamic: license-file
Dynamic: project-url
Dynamic: requires-dist
Dynamic: requires-python
Dynamic: summary

# myhisense-tv

[![Python 3.8+](https://img.shields.io/badge/python-3.8+-blue.svg)](https://www.python.org/downloads/)
[![hacs_badge](https://img.shields.io/badge/HACS-Custom-41BDF5.svg)](https://github.com/hacs/integration)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)

Python library and Home Assistant integration for Hisense/Vidaa Smart TV control. Two integration options available:

1. **Custom Component** (Recommended) - Native Home Assistant integration with SSDP auto-discovery
2. **MQTT Bridge** - Docker-based bridge for MQTT-based home automation setups

## Features

- **Home Assistant Custom Component** with config flow UI
- **SSDP Auto-Discovery** - TVs automatically detected on network
- **PIN Pairing** - Secure authentication via TV screen
- Control Hisense/Vidaa TVs via MQTT (optional bridge mode)
- Power on/off (with Wake-on-LAN support)
- Volume control and mute
- Input source switching
- App launching (Netflix, YouTube, etc.)
- Navigation keys (up, down, left, right, ok, back, home, menu)
- Multi-TV support
- Docker deployment ready (MQTT bridge)

## Quick Start

### 1. Prerequisites

- **Paired UUID**: You must first pair a device with your TV using the official Vidaa app
- **TV IP Address**: Your TV's IP address (static IP recommended)
- **MQTT Broker**: Mosquitto or Home Assistant's built-in broker
- **Docker** (recommended) or Python 3.8+

### 2. Configure

Copy the example config and edit:

```bash
cp config.example.yaml config.yaml
nano config.yaml
```

Minimum required settings:

```yaml
mqtt:
  host: "192.168.1.100"    # Your MQTT broker IP

tv:
  host: "YOUR_TV_IP"       # Your TV's IP address
  uuid: "xx:xx:xx:xx:xx:xx" # UUID from Vidaa app pairing
  mac: "XX:XX:XX:XX:XX:XX"  # TV MAC for Wake-on-LAN
  name: "Living Room TV"
```

### 3. Run with Docker

```bash
docker compose up -d
```

View logs:

```bash
docker compose logs -f
```

### 4. Home Assistant

The TV will automatically appear in Home Assistant via MQTT discovery. You'll get:

- **Media Player** entity with power, volume, source controls
- **Navigation Buttons** for remote control
- **App Launcher** select for streaming apps

## Manual Installation

If not using Docker:

```bash
# Install dependencies
pip install -r requirements.txt

# Run
python -m hisense2mqtt --config config.yaml
```

## Configuration

See [docs/CONFIGURATION.md](docs/CONFIGURATION.md) for full configuration reference.

### Environment Variables

Override config via environment:

| Variable | Description |
|----------|-------------|
| `MQTT_HOST` | MQTT broker hostname |
| `MQTT_PORT` | MQTT broker port |
| `MQTT_USERNAME` | MQTT username |
| `MQTT_PASSWORD` | MQTT password |
| `TV_HOST` | TV IP address |
| `TV_UUID` | Paired UUID |
| `TV_MAC` | TV MAC address |
| `LOG_LEVEL` | Logging level |

## MQTT Topics

### Commands (publish to these)

| Topic | Payload | Description |
|-------|---------|-------------|
| `hisense2mqtt/{id}/set/power` | `ON` / `OFF` | Power control |
| `hisense2mqtt/{id}/set/volume` | `0-100` | Set volume |
| `hisense2mqtt/{id}/set/mute` | `ON` / `OFF` | Toggle mute |
| `hisense2mqtt/{id}/set/source` | `hdmi1`, `hdmi2`, etc. | Change input |
| `hisense2mqtt/{id}/set/key` | `up`, `down`, `ok`, etc. | Send remote key |
| `hisense2mqtt/{id}/set/app` | `netflix`, `youtube`, etc. | Launch app |

### State (subscribe to these)

| Topic | Payload | Description |
|-------|---------|-------------|
| `hisense2mqtt/{id}/state/power` | `ON` / `OFF` | Power state |
| `hisense2mqtt/{id}/state/volume` | `0-100` | Current volume |
| `hisense2mqtt/{id}/state/mute` | `ON` / `OFF` | Mute state |
| `hisense2mqtt/{id}/state/source` | Source name | Current input |
| `hisense2mqtt/{id}/state/available` | `online` / `offline` | Availability |

## Getting the UUID

The UUID is required for authentication. To get it:

1. Install the official **Vidaa** app on your phone
2. Pair the app with your TV (enter the PIN shown on TV)
3. The UUID is your phone's Bluetooth/WiFi MAC address
4. Check your phone's settings or use `adb logcat` to find it

Alternatively, if you have a working UUID from previous pairing, use that.

## Wake-on-LAN

To turn on the TV when it's off:

1. Enable "Wake on LAN" or "Network Standby" in TV settings
2. Set `tv.mac` in config to your TV's MAC address
3. Connect TV via Ethernet (WiFi WoL is unreliable)
4. Set `options.wake_on_lan: true`

## Troubleshooting

See [docs/TROUBLESHOOTING.md](docs/TROUBLESHOOTING.md) for common issues.

### Quick Fixes

**TV not responding:**
- Ensure TV is on the same network
- Check TV IP address is correct
- Verify UUID is from a paired device

**Discovery not appearing in HA:**
- Check MQTT broker connection in HA
- Verify discovery_prefix matches HA config
- Check logs: `docker compose logs hisense2mqtt`

**Wake-on-LAN not working:**
- TV must be connected via Ethernet
- Enable WoL in TV settings
- Verify MAC address is correct

## Library Usage

Install the library:

```bash
pip install myhisense-tv
```

Basic usage:

```python
from hisense_tv import HisenseTV, discover_all

# Discover TVs on network
devices = discover_all(timeout=5.0)
for ip, device in devices.items():
    print(f"Found: {ip} - {device.name}")

# Connect to TV
tv = HisenseTV(
    host="YOUR_TV_IP",
    mac_address="XX:XX:XX:XX:XX:XX",
    use_dynamic_auth=True,
)

if tv.connect():
    # Control TV
    tv.power_on()
    tv.volume_up()
    tv.launch_app("netflix")

    tv.disconnect()
```

See [docs/API.md](docs/API.md) for full API reference.

## Documentation

- [API Reference](docs/API.md)
- [Configuration Reference](docs/CONFIGURATION.md)
- [Home Assistant Integration](docs/HOME_ASSISTANT.md)
- [MQTT Topics](docs/MQTT_TOPICS.md)
- [Troubleshooting](docs/TROUBLESHOOTING.md)
- [Protocol Analysis](VIDAA_PROTOCOL_ANALYSIS.md)

## Contributing

Contributions are welcome! See [CONTRIBUTING.md](CONTRIBUTING.md) for guidelines.

## License

This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.

## Credits

Protocol reverse-engineered from the Vidaa Android app.
