Skip to main content

Python library used by Home Assistant to interact with the WeatherFlow REST API

Project description

WeatherFlow4Py

A Python library for interacting with the WeatherFlow REST API and WebSocket services. This library provides both synchronous and asynchronous interfaces to access weather data from WeatherFlow weather stations.

PyPI Test PyPI

Features

  • REST API Client: Access station data, forecasts, and observations
  • WebSocket Client: Real-time weather data updates
  • Type Annotations: Full type support for better development experience
  • Asynchronous Support: Built with asyncio for efficient I/O operations
  • Pydantic Models: Strongly-typed data models for all API responses

Installation

pip install weatherflow4py

Or with uv:

uv pip install weatherflow4py

Prerequisites

Quick Start

REST API Example

import asyncio
from weatherflow4py.api import WeatherFlowRestAPI

async def main():
    # Initialize the API with your token
    async with WeatherFlowRestAPI("YOUR_API_TOKEN") as api:
        # Get all available stations
        stations = await api.async_get_stations()
        
        for station in stations.stations:
            print(f"Station: {station.name}")
            print(f"Location: {station.latitude}, {station.longitude}")
            
            # Get current observations
            obs = await api.async_get_observation(station.station_id)
            print(f"Current temperature: {obs.obs[0].air_temperature}°C")
            
            # Get forecast
            forecast = await api.async_get_forecast(station.station_id)
            print(f"Forecast high: {forecast.forecast.daily[0].air_temp_high}°C")

if __name__ == "__main__":
    asyncio.run(main())

WebSocket Example

import asyncio
import logging
from weatherflow4py.ws import WeatherFlowWebsocketAPI

# Set up logging
logging.basicConfig(level=logging.INFO)
logger = logging.getLogger(__name__)

async def main():
    # Initialize the WebSocket client
    ws = WeatherFlowWebsocketAPI("YOUR_API_TOKEN")
    
    # Define callback functions for different message types
    def handle_observation(data):
        print(f"Observation received - Temp: {data.air_temperature}°C")
    
    def handle_rapid_wind(data):
        print(f"Wind speed: {data.wind_speed} m/s at {data.wind_direction}°")
    
    # Register callbacks
    ws.register_callback("obs_st", handle_observation)
    ws.register_callback("rapid_wind", handle_rapid_wind)
    
    try:
        # Start listening for messages
        await ws.connect()
        
        # Start listening to all available devices
        await ws.start_listening()
        
        # Keep the connection alive
        while True:
            await asyncio.sleep(1)
            
    except KeyboardInterrupt:
        print("Disconnecting...")
    finally:
        await ws.disconnect()

if __name__ == "__main__":
    asyncio.run(main())

API Documentation

REST API

The WeatherFlowRestAPI class provides the following methods:

  • async_get_stations(): Get all stations associated with the account
  • async_get_observation(station_id): Get current observations for a station
  • async_get_forecast(station_id): Get forecast data for a station
  • async_get_device_observations(device_id): Get observations from a specific device
  • get_all_data(): Get all available data for all stations

WebSocket API

The WeatherFlowWebsocketAPI class provides real-time updates:

  • connect(): Establish WebSocket connection
  • disconnect(): Close the connection
  • start_listening(device_ids=None): Start listening for updates
  • stop_listening(device_ids=None): Stop listening for updates
  • register_callback(message_type, callback): Register a callback for specific message types

Error Handling

The library raises specific exceptions for different error conditions:

  • TokenError: When no API token is provided
  • APIError: For general API errors
  • WebSocketError: For WebSocket connection issues

Rate Limiting

  • REST API: Limited to 100 requests per minute
  • WebSocket: Follows WeatherFlow's rate limiting policies

Resources

Development

This project uses uv for dependency management and virtual environment creation.

Setup with Nix

If you have Nix installed with flakes enabled:

# Enter the development environment
nix develop

# This will automatically:
# 1. Create a virtual environment with uv
# 2. Install dependencies from requirements.txt and requirements-dev.txt
# 3. Install the project in development mode

Manual Setup with uv

# Create a virtual environment
uv venv

# Activate the virtual environment
source .venv/bin/activate

# Install dependencies
uv pip install -r requirements.txt
uv pip install -r requirements-dev.txt

# Install the project in development mode
uv pip install -e .

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgments

  • WeatherFlow for their excellent weather station hardware and API
  • All contributors who have helped improve this library

Support

For support, please open an issue on the GitHub repository.

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

weatherflow4py-1.5.4.tar.gz (141.2 kB view details)

Uploaded Source

Built Distribution

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

weatherflow4py-1.5.4-py3-none-any.whl (23.4 kB view details)

Uploaded Python 3

File details

Details for the file weatherflow4py-1.5.4.tar.gz.

File metadata

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

File hashes

Hashes for weatherflow4py-1.5.4.tar.gz
Algorithm Hash digest
SHA256 cee8e840a2fdc986f279ba2e19ce79788b68c02d3dfd592c064ee2f91e4d188f
MD5 f5ef10b09ec45e5a39f4fecf213b5ac8
BLAKE2b-256 2876e9b102756b69b6dadb889c115c6d5ee2067d8a3b48e9525fa2d55224abb9

See more details on using hashes here.

Provenance

The following attestation bundles were made for weatherflow4py-1.5.4.tar.gz:

Publisher: release.yml on jeeftor/weatherflow4py

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

File details

Details for the file weatherflow4py-1.5.4-py3-none-any.whl.

File metadata

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

File hashes

Hashes for weatherflow4py-1.5.4-py3-none-any.whl
Algorithm Hash digest
SHA256 94a1ce0d86bb0acf1b9f7bcd754ba90f637141022b3e55779b1390d28d79fc73
MD5 598b9a866de0ebae15db3d1d3dbf41e8
BLAKE2b-256 0a17802b19537c0fccaad1a09f960d7e3e38042c8cac828b180eba11dec01b7d

See more details on using hashes here.

Provenance

The following attestation bundles were made for weatherflow4py-1.5.4-py3-none-any.whl:

Publisher: release.yml on jeeftor/weatherflow4py

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