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.dhw_temperature}°F")
        print(f"Tank Charge: {status.dhw_charge_per}%")
        print(f"Power Consumption: {status.current_inst_power}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 monitoring and controlling your Navien water heater:

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

# Get current device status
python3 -m nwp500.cli status

# Get device information and firmware
python3 -m nwp500.cli info

# Get controller serial number
python3 -m nwp500.cli serial

# Turn device on/off
python3 -m nwp500.cli power on
python3 -m nwp500.cli power off

# Set operation mode
python3 -m nwp500.cli mode heat-pump
python3 -m nwp500.cli mode energy-saver
python3 -m nwp500.cli mode high-demand
python3 -m nwp500.cli mode electric
python3 -m nwp500.cli mode vacation
python3 -m nwp500.cli mode standby

# Set target temperature
python3 -m nwp500.cli temp 140

# Set vacation days
python3 -m nwp500.cli vacation 7

# Trigger instant hot water
python3 -m nwp500.cli hot-button

# Set recirculation pump mode (1-4)
python3 -m nwp500.cli recirc 2

# Reset air filter timer
python3 -m nwp500.cli reset-filter

# Enable water program mode
python3 -m nwp500.cli water-program

# View and update schedules
python3 -m nwp500.cli reservations get
python3 -m nwp500.cli reservations set '[{"hour": 6, "min": 0, ...}]'

# Time-of-use settings
python3 -m nwp500.cli tou get
python3 -m nwp500.cli tou set on

# Energy usage data
python3 -m nwp500.cli energy --year 2024 --months 10,11,12

# Demand response
python3 -m nwp500.cli dr enable
python3 -m nwp500.cli dr disable

# Real-time monitoring (logs to CSV)
python3 -m nwp500.cli monitor
python3 -m nwp500.cli monitor -o my_data.csv

Global Options:

  • --email EMAIL: Navien account email (or use NAVIEN_EMAIL env var)

  • --password PASSWORD: Navien account password (or use NAVIEN_PASSWORD env var)

  • -v, --verbose: Enable debug logging

  • --version: Show version and exit

Available Commands:

  • status: Show current device status (temperature, mode, power)

  • info: Show device information (firmware, capabilities)

  • serial: Get controller serial number

  • power on|off: Turn device on or off

  • mode MODE: Set operation mode (heat-pump, electric, energy-saver, high-demand, vacation, standby)

  • temp TEMPERATURE: Set target water temperature in °F

  • vacation DAYS: Enable vacation mode for N days

  • recirc MODE: Set recirculation pump (1=always, 2=button, 3=schedule, 4=temperature)

  • hot-button: Trigger instant hot water

  • reset-filter: Reset air filter maintenance timer

  • water-program: Enable water program reservation mode

  • reservations get|set: View or update schedule

  • tou get|set STATE: View or configure time-of-use settings

  • energy: Query historical energy usage (requires --year and --months)

  • dr enable|disable: Enable or disable demand response

  • monitor: Monitor device status in real-time (logs to CSV with -o option)

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.13+

  • aiohttp >= 3.8.0

  • pydantic >= 2.0.0

  • awsiotsdk >= 1.27.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-7.1.0.tar.gz (333.6 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-7.1.0-py3-none-any.whl (102.2 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for nwp500_python-7.1.0.tar.gz
Algorithm Hash digest
SHA256 a6d3f03643475a97669e2f81d3d26cc9452468e33d1b4afea141db60783ace84
MD5 57590f22a56d19df96377401a865a80d
BLAKE2b-256 4691ec349f6a24d6621a20d839331cef1643a9dcf22a82491431c555672c10bc

See more details on using hashes here.

Provenance

The following attestation bundles were made for nwp500_python-7.1.0.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-7.1.0-py3-none-any.whl.

File metadata

  • Download URL: nwp500_python-7.1.0-py3-none-any.whl
  • Upload date:
  • Size: 102.2 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-7.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f93b9624a9262311e1e216a5192f84c5cfaa87f4d5b4802c6ed2ff70f56f2384
MD5 3e90f6d547f0cc000fa56ea263b4a86d
BLAKE2b-256 e1d407e16cbea4a4a9672a8674d7b6684e0004d6c64d44d7b7c5c6d32f074c70

See more details on using hashes here.

Provenance

The following attestation bundles were made for nwp500_python-7.1.0-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