rcvd-py

Python 3 port of RCVD project
git clone git://git.luxferre.top/rcvd-py.git
Log | Files | Refs | README

README (4786B)


      1 RCVD.py: sync BLE-enabled Casio watches from Python 3
      2 -----------------------------------------------------
      3 The RCVD project is now fully ported to Python 3. This is an application that
      4 allows you to synchronize time and date on your Bluetooth LE enabled Casio
      5 wristwatches (see supported models in the FAQ section). The original concept
      6 was created for KaiOS 2.5.x and Web Bluetooth API enabled browsers in 2022.
      7 This version is a standalone CLI application but optionally can be used as
      8 a library.
      9 
     10 == Dependencies ==
     11 
     12 RCVD.py has been tested on Python 3.10 and depends on these libraries:
     13 bleak (0.21.1+), asyncio (3.4.3+) and ntplib (0.4.0+). Just install all of
     14 them by running pip install -r requirements.txt from the project directory.
     15 
     16 Of course, you need to run RCVD on a PC with a Bluetooth 4.0+ adapter or on
     17 another Bluetooth-enabled device that supports Bluetooth LE.
     18 
     19 == Usage ==
     20 
     21 RCVD can be run like this:
     22 
     23 python rcvd.py [-h] [-t timeout] [-d delta] [-s ntp_server] [-n ntp_version]
     24 
     25 All parameters are optional here:
     26 
     27 * -h: display help screen
     28 * -t: BLE scanning timeout in seconds (default 4)
     29 * -d: manual delta correction in milliseconds (default 500, see below)
     30 * -s: specify NTP server to fetch time from (if no server is specified, then
     31       local system time is used)
     32 * -n: specify NTP protocol version to use, default is 4, good for most cases
     33 
     34 After running the command, you must press the corresponding time sync button
     35 on your watch (usually the lower right) to put it into the BLE sync mode. If
     36 possible, press this button at the same time as running the command, but a
     37 short delay (within the timeout specified with -t parameter) is allowed. Once
     38 the watch is connected and the handshake is performed, RCVD will fetch the
     39 current time from the specified source (local system time by default, or the
     40 NTP server of your choice) and set it on the watch. Look for the OK indicator
     41 on the watch itself to confirm that the setting process has been successful.
     42 Refer to the manual for your model on how to do that.
     43 
     44 Depending on your specific watch and host Bluetooth hardware, you may need to
     45 set a different delta correction value to account for transmission losses.
     46 You can do this by altering the -d parameter when running the command. This
     47 parameter defines how many milliseconds are added to the time value to be 
     48 immediately set on the watch. It is 500 ms by default, but tends to be more on
     49 the digital Casio models, so you need to find out yourself which delta gives
     50 the most accurate time setting as a result.
     51 
     52 == FAQ ==
     53 
     54 - How is this better than the official (and unofficial) Casio syncing apps?
     55 
     56 As of now, RCVD focuses on doing one thing well and works on any CLI-enabled
     57 platform, as opposed to the official Casio apps only working on mobile OSes.
     58 It doesn't aim to replace them. Just as its JS-based predecessor, RCVD.py is
     59 a lightweight alternative for those who just want to sync time on the watches
     60 and nothing else.
     61 
     62 - Which Casio models are supported as of now?
     63 
     64 The following models were directly tested with both (JS and Python) versions:
     65 GW-B5600, GMW-B5000, OCW-T200, GM-B2100, DW-B5600, GA-B001.
     66 
     67 The following models were directly tested with the Python version:
     68 ABL-100.
     69 
     70 The following models are theoretically supported too but not directly tested:
     71 MRG-B5000, GWR-B1000, GA-B2100, GST-B400, GST-B500, ECB-S100, MSG-B100,
     72 ECB-2000, ECB-2200, G-B001, TRN-50, GD-B500.
     73 
     74 If RCVD works with one of the above models (or with some other ones), please
     75 let me know at https://matrix.to/#/@luxferre:hackliberty.org and I'll mark it
     76 as tested.
     77 
     78 - Will both JS and Python versions be developed in parallel?
     79 
     80 Most likely, no. If there is an issue that really needs to be fixed in the
     81 KaiOS/JS version of RCVD, the fix will be backported there, but all new
     82 feature development will only be focused upon in the Python version, i.e. this
     83 one. This version, by the way, already is ahead of the JS version because it
     84 already integrates NTP support.
     85 
     86 For any new Casio models though, if the basic time sync support is trivial to
     87 add into the Python version, it will most likely be added to the JS version as
     88 well.
     89 
     90 - Are there going to be advanced features for the models supporting them, like
     91   alarm setting, reminders, DST rules, timezone DB, waypoints etc?
     92 
     93 Probably. Not in the short term though. And it will most likely be a separate
     94 script using rcvd.py as a library.
     95 
     96 - Are there going to be any features utilizing "phone finder" and autosync?
     97 
     98 A research is planned in both of these directions, but, again, its results
     99 will be implemented in separate applications, not in this one.
    100 
    101 == Credits ==
    102 
    103 Original research, JS library and KaiOS application by Luxferre, 2022.
    104 Ported to Python in 2024. Released into public domain with no warranties.