Skip to main content

Pythgon API for GShock Watches using BLE

Project description

gshock_api

Announcement

The library now supports sending application-level notifications to watches that support it, namely:

  • DW-H5600

  • GBD-H2000

  • GBD-200

  • GBD-100

  • GBD-800

  • GBD-100BAR

  • GBX-100

The new API is send_app_notification function. See the examples/api_test.py file for usage examples.

Only the DW-H5600 watch has been tested. If you have any of the watches supporting notifications, please let me know your findings.

Overview

This is a Python API library for G-Shock watches that support Bluetooth Low Energy (BLE) communication.

G(M)W-5600, G(M)W-5000, GA-B2100, GA-B001-1AER, GST-B500, GST-B200, MSG-B100, G-B001, GBD-H1000 (Partial support), MRG-B5000, GCW-B5000, GG-B100, ABL-100WE, Edifice ECB-30, ECB-10, ECB-20, most Edifice watches, most Protrek models.

It can perform the following tasks:

  • Set watch’s time

  • Set Home Time (Home City)

  • Set Alarms

  • Set Reminders

  • Set watch’s settings.

  • Get watch’s name

  • Get watch’s battery level

  • Get Watch’s temperature

  • Get/Set watch’s Timer

  • Send notifications to watch (supported models)

Dependencies

This project requires the following Python packages: .. code-block:: sh

pytz bleak

So you can install them using the following command: .. code-block:: sh

pip3 install -r requirements.txt

To understand how to use the library, please refer to the `src/examples` folder.

Virtual Environment Setup

It is recommended that you create a virtual environment to run the tests:

  1. Create a virtual environment:

    # Create a virtual environment
    python3 -m venv venv
    
    # Activate it (Mac/Linux)
    source venv/bin/activate
    
    # Install dependencies
    pip3 install -e .
  2. Run the tests:

    python3 src/examples/api_tests.py [--multi-watch]

The optional `–multi-watch` parameter forces the library to scan for watches every time it tries to connect to a watch. If not provided, the library will try to connect to the last connected watch only. If you have multiple watches, you should use this parameter.

The optional `–multi-watch` parameter forces the library to scan for watches every time it tries to connect to a watch. If not provided, the library will try to connect to the last connected watch only. If you have multiple watches, you should use this parameter.

Installing the library for your project:

pip3 install gshock-api

See this project using this library to run a time server for G-Shock watches.

See also this blog for using the library in the SXMO mobile environment.

Troubleshooting:

If your watch cannot connect, and the `–multi-watch` parameter is not used, remove the `config.ini` file and try again.

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

gshock_api-2.0.7.tar.gz (27.2 kB view details)

Uploaded Source

Built Distribution

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

gshock_api-2.0.7-py3-none-any.whl (35.1 kB view details)

Uploaded Python 3

File details

Details for the file gshock_api-2.0.7.tar.gz.

File metadata

  • Download URL: gshock_api-2.0.7.tar.gz
  • Upload date:
  • Size: 27.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.12

File hashes

Hashes for gshock_api-2.0.7.tar.gz
Algorithm Hash digest
SHA256 704caa35a0fbdaa583c21fbe1bfc7c5ab5bdd6ab65433d5a55d083f0cab40d8d
MD5 e2ef45f583b85e428414a36847714baa
BLAKE2b-256 b7844cfecd1d3b30fbb68e2c10b16f4b62265c100cb17545530024808adc8ee4

See more details on using hashes here.

File details

Details for the file gshock_api-2.0.7-py3-none-any.whl.

File metadata

  • Download URL: gshock_api-2.0.7-py3-none-any.whl
  • Upload date:
  • Size: 35.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.12

File hashes

Hashes for gshock_api-2.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 2344a7d4f28975531ce17175f7a8c8ea0cc73bb07f6dcad6b39aa4a5066a08cc
MD5 add3d99d7e3e13f5da865f97b302a778
BLAKE2b-256 7ecfddfaf37250b24df5b08e2834be1eff4e3976ac69406f12c4444d0e51b517

See more details on using hashes here.

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