
Product
Introducing Rust Support in Socket
Socket now supports Rust and Cargo, offering package search for all users and experimental SBOM generation for enterprise projects.
gridappsd-2030-5-client
Advanced tools
A Python client library for IEEE 2030.5 (Smart Energy Profile 2.0) servers with persistent connections and extensible event handling.
# Install from PyPI
pip install gridappsd-2030-5-client
# Or with Poetry
poetry add gridappsd-2030-5-client
import logging
from gridappsd_2030_5_client import IEEE2030Client, IEEE2030EventHandler
# Configure logging
logging.basicConfig(level=logging.INFO)
# Create a custom event handler
class MyEventHandler(IEEE2030EventHandler):
def on_connect(self, client):
print("Connected to IEEE 2030.5 server!")
def on_subscription_update(self, client, resource, data):
print(f"Received update for {resource}: {data}")
# Create and use the client
client = IEEE2030Client(
base_url="https://ieee2030server.example.com/api",
event_handler=MyEventHandler(),
cert_path="client_cert.pem",
key_path="client_key.pem",
ca_cert_path="ca_cert.pem"
)
try:
# Connect to the server
if client.connect():
# Get device capability
capability = client.get_device_capability()
print(f"Device capability: {capability}")
# Subscribe to resources
client.create_subscription("drp/1/dre") # Demand response events
# Start polling for updates
client.start_polling()
# Wait for events
input("Press Enter to stop...")
finally:
# Disconnect and clean up
client.disconnect()
import asyncio
from gridappsd_2030_5_client import IEEE2030Client, IEEE2030EventHandler
# Create a custom event handler
class MyEventHandler(IEEE2030EventHandler):
def on_connect(self, client):
print("Connected to IEEE 2030.5 server!")
async def main():
# Create client
client = IEEE2030Client(
base_url="https://ieee2030server.example.com/api",
event_handler=MyEventHandler(),
cert_path="client_cert.pem",
key_path="client_key.pem",
ca_cert_path="ca_cert.pem"
)
try:
# Connect to the server asynchronously
if await client.async_connect():
# Start polling for updates
client.start_polling()
# Wait for some time
await asyncio.sleep(300) # Run for 5 minutes
finally:
# Disconnect and clean up
client.disconnect()
# Run the async program
asyncio.run(main())
# Clone the repository
git clone https://github.com/GRIDAPPSD/gridappsd-2030-5-client.git
cd gridappsd-2030-5-client
# Install dependencies with Poetry
poetry install
# Run tests
poetry run pytest
# Run tests with coverage
poetry run pytest --cov=gridappsd_2030_5_client
# Format code
poetry run black gridappsd_2030_5_client
BSD 3-Clause License
Copyright (c) 2023, GridAPPSD Contributors All rights reserved.
FAQs
IEEE 2030.5 client for GridAppSD
We found that gridappsd-2030-5-client demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Product
Socket now supports Rust and Cargo, offering package search for all users and experimental SBOM generation for enterprise projects.
Product
Socket’s precomputed reachability slashes false positives by flagging up to 80% of vulnerabilities as irrelevant, with no setup and instant results.
Product
Socket is launching experimental protection for Chrome extensions, scanning for malware and risky permissions to prevent silent supply chain attacks.