Skip to main content

Python API and CLI for controlling Jackery portable power stations

Project description

socketry

CI Coverage Python

Python API and CLI for controlling Jackery portable power stations.

Reverse-engineered from the Jackery Android APK (v1.0.7) and iOS app (v1.2.0). Communicates via Jackery's cloud MQTT broker and HTTP API — no modifications to the device or its firmware.

Quick start

uvx 'socketry[cli]' login --email you@example.com --password 'yourpass'
uvx 'socketry[cli]' get

Or install it once and use socketry directly:

uv tool install 'socketry[cli]'
socketry login --email you@example.com --password 'yourpass'
socketry get

Supported devices

All 10 models in the current Jackery app share the same protocol:

Model Code
Explorer 3000 Pro 1
Explorer 2000 Plus 2
Explorer 300 Plus 4
Explorer 1000 Plus 5
Explorer 700 Plus 6
Explorer 280 Plus 7
Explorer 1000 Pro2 8
Explorer 600 Plus 9
Explorer 240 10
Explorer 2000 12

Properties and MQTT action IDs are exhaustive for this APK version. Unknown properties returned by newer firmware are displayed as raw key/value pairs.

Install

# Install as a CLI tool
uv tool install 'socketry[cli]'

# Or run directly without installing
uvx 'socketry[cli]' --help

# Or install as a library only (no CLI dependencies)
pip install socketry

# Or install with CLI included
pip install 'socketry[cli]'

CLI usage

Login

# Authenticates and discovers all devices (owned + shared with you)
socketry login --email you@example.com --password 'yourpass'

# List devices and select the active one
socketry devices
socketry select 0

Credentials are saved to ~/.config/socketry/credentials.json (mode 0600).

Reading properties (get)

# All properties (colored + grouped on a TTY)
socketry get

# Single property — by CLI name or raw protocol key
socketry get battery          # Battery: 85%
socketry get rb               # Battery: 85% (same thing)
socketry get ac               # AC output: ON

# JSON output (indented on TTY, compact when piped)
socketry get --json
socketry get ac --json        # {"oac": 1}
socketry get --json | jq .rb  # pipe-friendly

Available properties:

Group Names
Battery & Power battery, battery-temp, battery-state, input-power, output-power, input-time, output-time
I/O State ac, dc, usb, car, ac-in, dc-in, light, wireless
Settings charge-speed, auto-shutdown, energy-saving, battery-protection, sfc, ups, screen-timeout
AC / Power Detail ac-input-power, car-input-power, ac-voltage, ac-freq, ac-power, ac-power-2, ac-socket-power
Other / Alarms error-code, temp-alarm, power-alarm, power-mode-battery, total-temp, system-status, power-capacity

Raw protocol keys (rb, oac, bt, ...) are also accepted.

Changing settings (set)

# I/O toggles
socketry set ac on
socketry set dc off
socketry set usb on
socketry set car off

# Light
socketry set light high       # off | low | high | sos

# Device settings
socketry set charge-speed mute      # fast | mute
socketry set battery-protection eco # full | eco
socketry set ups on
socketry set sfc on

# Integer settings
socketry set screen-timeout 30
socketry set auto-shutdown 60
socketry set energy-saving 30

# Wait for device confirmation
socketry set ac on --wait

# Show available settings
socketry set
socketry set light            # "expects a value: off | low | high | sos"

Writable settings:

Setting Values Description
ac on / off AC output
dc on / off DC output
usb on / off USB output
car on / off Car (12V) output
ac-in on / off AC input
dc-in on / off DC input
light off / low / high / sos Light mode
screen-timeout integer Screen timeout
auto-shutdown integer Auto shutdown timer
charge-speed fast / mute Charge speed mode
battery-protection full / eco Battery protection level
energy-saving integer Energy saving timeout
sfc on / off Super fast charge
ups on / off UPS mode

Watching live updates (watch)

# Stream all property changes in real time
socketry watch

# Filter to a single property
socketry watch battery

# Example output:
# [14:32:01] 855124121010657 Output power (output-power): 182W
# [14:32:05] 855124121010657 Battery (battery): 85%
# [14:32:10] Disconnected, reconnecting...
# [14:32:15] 855124121010657 Battery (battery): 84%

Press Ctrl+C to stop. The connection automatically reconnects if the broker disconnects (e.g. when a set command runs from another terminal).

Note: The Jackery broker only allows one MQTT connection per account. Running socketry set while watch is active will briefly disconnect the watcher. It reconnects automatically, but updates during the reconnection window are lost.

Library usage

import asyncio
from socketry import Client

async def main():
    # Authenticate (or load saved credentials)
    client = await Client.login("email@example.com", "password")
    client.save_credentials()

    # Or load previously saved credentials
    client = Client.from_saved()

    # List and select devices
    devices = await client.fetch_devices()
    client.select_device(0)

    # Read properties
    props = await client.get_all_properties()
    setting, value = await client.get_property("battery")
    print(f"{setting.name}: {setting.format_value(value)}")

    # Control
    await client.set_property("ac", "on")
    result = await client.set_property("light", "high", wait=True)

    # Subscribe to real-time updates
    async def on_update(device_sn: str, properties: dict) -> None:
        print(f"{device_sn}: {properties}")

    async def on_disconnect() -> None:
        print("Reconnecting...")

    subscription = await client.subscribe(on_update, on_disconnect=on_disconnect)
    # ... later
    await subscription.stop()

asyncio.run(main())

How it works

socketry ──HTTP──> iot.jackeryapp.com    (login, device list, properties)
socketry ──MQTT──> emqx.jackeryapp.com  (device control via encrypted TLS)

Login uses AES-192/ECB + RSA-1024 encrypted HTTP POST. Device control commands are published over MQTT (TLS 1.2 with a self-signed CA). Status polling uses the HTTP property endpoint. See docs/protocol.md for the full protocol specification.

Roadmap

  • MQTT real-time monitor (socketry watch + client.subscribe())
  • Token auto-refresh (JWT expires ~30 days)

License

MIT

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

socketry-0.2.3.tar.gz (21.3 kB view details)

Uploaded Source

Built Distribution

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

socketry-0.2.3-py3-none-any.whl (23.8 kB view details)

Uploaded Python 3

File details

Details for the file socketry-0.2.3.tar.gz.

File metadata

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

File hashes

Hashes for socketry-0.2.3.tar.gz
Algorithm Hash digest
SHA256 f13c46fe438e1c01f95e36d298bf5e8531c0b3876462b5dbb475490a53c76b1d
MD5 9099eef2ebce11f692fbcf1f218dbfee
BLAKE2b-256 a3772d6e26a4780f25c40c2a1e7b9e93d6c7829a1a0ffb2f5be32591af77f0ff

See more details on using hashes here.

Provenance

The following attestation bundles were made for socketry-0.2.3.tar.gz:

Publisher: release.yml on jlopez/socketry

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

File details

Details for the file socketry-0.2.3-py3-none-any.whl.

File metadata

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

File hashes

Hashes for socketry-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 8bc65328f0523e646766fa1210164fb7589ab530c4b999f828efa5f5e68ff7e2
MD5 c637647f4350c50314afb8a76b9d839f
BLAKE2b-256 be1894d2652cb557d50d9c678cc6e76e32e437030dd476373caa69972a637cd2

See more details on using hashes here.

Provenance

The following attestation bundles were made for socketry-0.2.3-py3-none-any.whl:

Publisher: release.yml on jlopez/socketry

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