Skip to main content

A library for controlling Navien NWP500 Water Heaters via NaviLink

Project description

Python library for Navien NWP500 Heat Pump Water Heater

A Python library for monitoring and controlling the Navien NWP500 Heat Pump Water Heater through the Navilink cloud service. This library provides comprehensive access to device status, temperature control, operation mode management, and real-time monitoring capabilities.

Documentation: https://nwp500-python.readthedocs.io/

Source Code: https://github.com/eman/nwp500-python

Features

  • Monitor status (temperature, power, charge %)

  • Set target water temperature

  • Change operation mode

  • Optional scheduling (reservations)

  • Optional time-of-use settings

  • Periodic high-temp cycle info

  • Access detailed status fields

  • Async friendly

Quick Start

Installation

pip install nwp500-python

Basic Usage

from nwp500 import NavienAuthClient, NavienAPIClient

# Authentication happens automatically when entering the context
async with NavienAuthClient("your_email@example.com", "your_password") as auth_client:
    # Create API client
    api_client = NavienAPIClient(auth_client=auth_client)

    # Get device data
    devices = await api_client.list_devices()
    device = devices[0] if devices else None

    if device:
        # Access status information
        status = device.status
        print(f"Water Temperature: {status.dhwTemperature}°F")
        print(f"Tank Charge: {status.dhwChargePer}%")
        print(f"Power Consumption: {status.currentInstPower}W")

        # Set temperature
        await api_client.set_device_temperature(device, 130)

        # Change operation mode
        await api_client.set_device_mode(device, "heat_pump")

Command Line Interface

The library includes a command line interface for quick monitoring and device information retrieval:

# Set credentials via environment variables
export NAVIEN_EMAIL="your_email@example.com"
export NAVIEN_PASSWORD="your_password"

# Get current device status (one-time)
python -m nwp500.cli --status

# Get device information
python -m nwp500.cli --device-info

# Get device feature/capability information
python -m nwp500.cli --device-feature

# Turn device on
python -m nwp500.cli --power-on

# Turn device off
python -m nwp500.cli --power-off

# Turn device on and see updated status
python -m nwp500.cli --power-on --status

# Set operation mode and see response
python -m nwp500.cli --set-mode energy-saver

# Set DHW target temperature and see response
python -m nwp500.cli --set-dhw-temp 140

# Set temperature and then get updated status
python -m nwp500.cli --set-dhw-temp 140 --status

# Set mode and then get updated status
python -m nwp500.cli --set-mode energy-saver --status

# Just get current status (one-time)
python -m nwp500.cli --status

# Monitor continuously (default - writes to CSV)
python -m nwp500.cli --monitor

# Monitor with custom output file
python -m nwp500.cli --monitor --output my_data.csv

Available CLI Options:

  • --status: Print current device status as JSON. Can be combined with control commands to see updated status.

  • --device-info: Print comprehensive device information (firmware, model, capabilities) as JSON and exit

  • --device-feature: Print device capabilities and feature settings as JSON and exit

  • --power-on: Turn the device on and display response

  • --power-off: Turn the device off and display response

  • --set-mode MODE: Set operation mode and display response. Valid modes: heat-pump, energy-saver, high-demand, electric, vacation, standby

  • --set-dhw-temp TEMP: Set DHW (Domestic Hot Water) target temperature in Fahrenheit (115-150°F) and display response

  • --monitor: Continuously monitor status every 30 seconds and log to CSV (default)

  • -o, --output: Specify CSV output filename for monitoring mode

  • --email: Override email (alternative to environment variable)

  • --password: Override password (alternative to environment variable)

Device Status Fields

The library provides access to comprehensive device status information:

Temperature Sensors
  • Water temperature (current and target)

  • Tank upper/lower temperatures

  • Ambient temperature

  • Discharge, suction, and evaporator temperatures

  • Inlet temperature

System Status
  • Operation mode (Heat Pump, Energy Saver, High Demand, Electric, Vacation)

  • Compressor status

  • Heat pump and electric heater status

  • Evaporator fan status

  • Tank charge percentage

Power & Energy
  • Current power consumption (Watts)

  • Total energy capacity (Wh)

  • Available energy capacity (Wh)

Diagnostics
  • WiFi signal strength

  • Error codes

  • Fault status

  • Cumulative operation time

  • Flow rates

Documentation

Full docs: https://nwp500-python.readthedocs.io/

Data Models

The library includes type-safe data models with automatic unit conversions:

  • DeviceStatus: Complete device status with 70+ fields

  • DeviceFeature: Device capabilities, firmware versions, and configuration limits

  • OperationMode: Enumeration of available operation modes

  • TemperatureUnit: Celsius/Fahrenheit handling

Requirements

  • Python 3.9+

  • aiohttp >= 3.8.0

  • websockets >= 10.0

  • cryptography >= 3.4.0

  • pydantic >= 2.0.0

  • awsiotsdk >= 1.21.0

License

This project is licensed under the MIT License.

Author

Emmanuel Levijarvi <emansl@gmail.com>

Acknowledgments

This project has been set up using PyScaffold 4.6. For details and usage information on PyScaffold see https://pyscaffold.org/.

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

nwp500_python-6.0.4.tar.gz (269.4 kB view details)

Uploaded Source

Built Distribution

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

nwp500_python-6.0.4-py3-none-any.whl (81.0 kB view details)

Uploaded Python 3

File details

Details for the file nwp500_python-6.0.4.tar.gz.

File metadata

  • Download URL: nwp500_python-6.0.4.tar.gz
  • Upload date:
  • Size: 269.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for nwp500_python-6.0.4.tar.gz
Algorithm Hash digest
SHA256 cb90a2f3cd1c8fcc1907e47a782cd8e4b5e3cd06fe92a8af3f189a9ccbd3f7af
MD5 741a3f4563037bca33d7b8a8dcb1b298
BLAKE2b-256 9aa1cc75e2e3715a3995b2b457312df2f15a4f0287672ce1a10d4b08f6925406

See more details on using hashes here.

Provenance

The following attestation bundles were made for nwp500_python-6.0.4.tar.gz:

Publisher: release.yml on eman/nwp500-python

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

File details

Details for the file nwp500_python-6.0.4-py3-none-any.whl.

File metadata

  • Download URL: nwp500_python-6.0.4-py3-none-any.whl
  • Upload date:
  • Size: 81.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for nwp500_python-6.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 d88e7ab601af0d614bf14970175a65118e0e168321769295341d5d0baf51c6f1
MD5 952108790a9b50b1f48ea154e49d0c91
BLAKE2b-256 6620a172d30729a1764c8841ffca793f16f7516ec61eece01b8a8ed6f8766c11

See more details on using hashes here.

Provenance

The following attestation bundles were made for nwp500_python-6.0.4-py3-none-any.whl:

Publisher: release.yml on eman/nwp500-python

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