Skip to main content

A CLI to fetch the status of charging stations

Project description

Can I charge?

It's a question you might have asked yourself before if you have a BEV/PHEV. This utility allows you to check if your favorite charging stations are available for your car to charge, right from the warmth of your terminal! No need to go outside and physically check if the charging station is available, and possibly return disappointed because it was occupied.

How to install

Using pip

$ pip install can-i-charge

AUR

A PKGBUILD has been created for this package, available on the AUR.

paru -S python-can-i-charge

How to use

CLI

The CLI can be used in the following ways:

# Using arguments
$ can-i-charge --station <SERIAL1> --station <SERIAL2> --station <SERIAL3>
# Using env variables
$ export STATIONS="<SERIAL1> <SERIAL2>"
$ can-i-charge
# The script can also be called using it's abbreviation
$ cic

You can pass as many stations as you want. At least one valid is needed however to actually return some data. The serials for the charging stations can be found on the charging station or on websites like shellrecharge.

Prometheus Exporter

This utility can also be used as a Prometheus exporter:

# Using arguments
$ can-i-charge --station <SERIAL1> --station <SERIAL2> --station <SERIAL3> --exporter --port <default is 9041> --interval <default is 60 seconds>
# Using env variables
$ export STATIONS="<SERIAL1> <SERIAL2>"
$ export EXPORTER=1
# Optionally also overwrite default interval and port
$ export EXPORTER_PORT=9000
$ export EXPORTER_INTERVAL=120
$ can-i-charge

See it in action

GIF of an example session interacting with the cli

Container

Build

$ docker build -t boosterl/can-i-charge:dev .

Run

# Default
$ docker run --rm -e STATIONS='BE-TCB-P104146' boosterl/can-i-charge:dev

# Using exporter
$ docker run --rm -e STATIONS='BE-TCB-P104146' -e EXPORTER='1' -p 9041:9041 boosterl/can-i-charge:dev

# Using docker-compose
$ docker-compose up -d

dgoss

$ dgoss run boosterl/can-i-charge:dev
 INFO: Starting docker container
 INFO: Container ID: 97851a83
 INFO: Sleeping for 0.2
 INFO: Container health
 INFO: Running Tests
 User: can-i-charge: exists: matches expectation: true
 INFO: Deleting container

Acknowledgments

This library uses the excellent python-shellrecharge package.

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

can_i_charge-0.7.4.tar.gz (43.3 kB view details)

Uploaded Source

Built Distribution

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

can_i_charge-0.7.4-py3-none-any.whl (30.8 kB view details)

Uploaded Python 3

File details

Details for the file can_i_charge-0.7.4.tar.gz.

File metadata

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

File hashes

Hashes for can_i_charge-0.7.4.tar.gz
Algorithm Hash digest
SHA256 d8d10d024949c38955ade924e7b1df7d75befa083a4d4a806aa22f3bb5e668ef
MD5 cc9c53c20a1b8fdedf8a9aaab24a2a19
BLAKE2b-256 fb4a8f138c4f2bbf4ba227280836930491a57d8bf52c021f1d08fc9a9967ca0d

See more details on using hashes here.

Provenance

The following attestation bundles were made for can_i_charge-0.7.4.tar.gz:

Publisher: python-publish.yml on boosterl/can-i-charge

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

File details

Details for the file can_i_charge-0.7.4-py3-none-any.whl.

File metadata

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

File hashes

Hashes for can_i_charge-0.7.4-py3-none-any.whl
Algorithm Hash digest
SHA256 21ede5357f918bd26949ceec4e105ca61eec16a88e7a2c9328e046a334bc3bfb
MD5 a1c862d928dd96646aa3dd2e1cc6a3c6
BLAKE2b-256 3f4f48336a124bf64ff21ed29ea9d899bbcbebeab754636425670074cf778116

See more details on using hashes here.

Provenance

The following attestation bundles were made for can_i_charge-0.7.4-py3-none-any.whl:

Publisher: python-publish.yml on boosterl/can-i-charge

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