itd is a daemon that uses my infinitime library to interact with the PineTime smartwatch running InfiniTime.
Go to file
Arsen Musayelyan 518fe74e96 Propagate FS errors on read/write and close files when finished writing 2021-12-13 09:58:34 -08:00
api Propagate FS errors on read/write and close files when finished writing 2021-12-13 09:58:34 -08:00
cmd Make paths absolute for firmware upgrades 2021-12-12 17:46:50 -08:00
internal/types Implement file transfer progress 2021-12-12 17:08:48 -08:00
translit Add and fix comments, fix transliteration maps so only first character is capitalized 2021-10-06 13:26:16 -07:00
.gitignore Add GUI frontend 2021-08-25 21:18:24 -07:00
.gitm.toml Add gitm for mirroring 2021-08-21 15:59:19 -07:00
LICENSE Initial Commit 2021-08-21 01:19:49 -07:00
Makefile Add uninstall rule to makefile 2021-08-21 17:17:25 -07:00
README.md Remove playerctl from depencency list 2021-11-24 16:46:57 -08:00
calls.go Allow multiple call notification responses 2021-11-25 12:41:36 -08:00
config.go Update default values to reflect new config fields 2021-11-01 11:28:55 -07:00
dbus.go Switch calls to use dbus library and add helpers for private connections 2021-11-24 11:36:36 -08:00
go.mod Propagate FS errors on read/write and close files when finished writing 2021-12-13 09:58:34 -08:00
go.sum Propagate FS errors on read/write and close files when finished writing 2021-12-13 09:58:34 -08:00
itd.service Initial Commit 2021-08-21 01:19:49 -07:00
itd.toml Remove config version field 2021-10-27 08:34:10 -07:00
main.go Ensure that the FS works after a reconnect 2021-11-25 20:35:03 -08:00
music.go Update music control implementation 2021-11-24 16:44:36 -08:00
notifs.go Use new helper functions 2021-11-24 11:52:52 -08:00
socket.go Propagate FS errors on read/write and close files when finished writing 2021-12-13 09:58:34 -08:00

README.md

ITD

InfiniTime Daemon

itd is a daemon that uses my infinitime library to interact with the PineTime running InfiniTime.

Build status Binary downloads AUR package


Features

  • Notification relay
  • Notification transliteration
  • Call Notifications (ModemManager)
  • Music control
  • Get info from watch (HRM, Battery level, Firmware version, Motion)
  • Set current time
  • Control socket
  • Firmware upgrades

Socket

This daemon creates a UNIX socket at /tmp/itd/socket. It allows you to directly control the daemon and, by extension, the connected watch.

The socket accepts JSON requests. For example, sending a notification looks like this:

{"type": 5, "data": {"title": "title1", "body": "body1"}}

It will return a JSON response. A response can have 3 fields: error, msg, and value. Error is a boolean that signals whether an error was returned. If error is true, the msg field will contain the error. Value can contain any data and depends on what the request was.

The various request types and their data requirements can be seen in internal/types. I can make separate docs for it if I get enough requests.


Transliteration

Since the PineTime does not have enough space to store all unicode glyphs, it only stores the ASCII space and Cyrillic. Therefore, this daemon can transliterate unsupported characters into supported ones. Since some languages have different transliterations, the transliterators to be used must be specified in the config. Here are the available transliterators:

  • eASCII
  • Scandinavian
  • German
  • Hebrew
  • Greek
  • Russian
  • Ukranian
  • Arabic
  • Farsi
  • Polish
  • Lithuanian
  • Estonian
  • Icelandic
  • Czeck
  • French
  • Armenian
  • Korean
  • Chinese
  • Emoji

Place the desired map names in an array as notifs.translit.use. They will be evaluated in order. You can also put custom transliterations in notifs.translit.custom. These take priority over any other maps. The notifs.translit config section should look like this:

[notifs.translit]
    use = ["eASCII", "Russian", "Emoji"]
    custom = [
        "test", "replaced"
    ]

itctl

This daemon comes with a binary called itctl which uses the socket to control the daemon from the command line. As such, it can be scripted using bash.

This is the itctl usage screen:

Control the itd daemon for InfiniTime smartwatches

Usage:
  itctl [flags]
  itctl [command]

Available Commands:
  firmware    Manage InfiniTime firmware
  get         Get information from InfiniTime
  help        Help about any command
  notify      Send notification to InfiniTime
  set         Set information on InfiniTime

Flags:
  -h, --help                 help for itctl
  -s, --socket-path string   Path to itd socket

Use "itctl [command] --help" for more information about a command.

itgui

In cmd/itgui, there is a gui frontend to the socket of itd. It uses the fyne library for Go. It can be compiled by running:

go build ./cmd/itgui

Screenshots

Info tab

Notify tab

Set time tab

Upgrade tab

Upgrade in progress


Interactive mode

Running itctl by itself will open interactive mode. It's essentially a shell where you can enter commands. For example:

$ itctl                        
itctl> fw ver
1.3.0
itctl> get batt
81%
itctl> get heart
92 BPM
itctl> set time 2021-08-22T00:06:18-07:00
itctl> set time now
itctl> exit

Installation

To install, install the go compiler and make. Usually, go is provided by a package either named go or golang, and make is usually provided by make. The go compiler must be version 1.16 or newer for the io/fs module.

To install, run

make && sudo make install

Starting

To start the daemon, run the following without root:

systemctl --user start itd

To autostart on login, run:

systemctl --user enable itd

Cross compiling

To cross compile, simply set the go environment variables. For example, for PinePhone, use:

make GOOS=linux GOARCH=arm64

This will compile itd and itctl for Linux aarch64 which is what runs on the PinePhone. This daemon only runs on Linux due to the library's dependencies (dbus, and bluez specifically).


Configuration

This daemon places a config file at /etc/itd.toml. This is the global config. itd will also look for a config at ~/.config/itd.toml.

Most of the time, the daemon does not need to be restarted for config changes to take effect.