Donations: https://paypal.me/piggz
Companion application for Huami Devices (such as Amazfit Bip, Cor, MiBand2/3 and GTS and GTS), Pinetime Infinitime and Bangle.js.
This application requires several supporting packages. Until Aug 2021, these were available on openrepos for the latest SailfishOS release. Updating these libs is a big pain, so they have now moved to SailfishOS::Chum. If you dont know what that is, read this https://build.merproject.org/project/show/sailfishos:chum:testing
To install Amazfish, first install the "chum" repository from the link above and "pkcon refresh" then install Amazfish.
I apologise about thie extra step, but it makes updates much easier. Pacakges in chum are automatically built for each SailfishOS release and instantly available. In the future, Amazfish may also be distributed this way, but for now, it can still be installed from here, for the current SailfishOS release.
If you already have Amazfish installed, and need to update, you will also need chum, but you may have to drop to a command line and "zypper dup" and accept and changes to the package vendor.
There are 3 tiers of supported devices:
These are devices I have, have tested and will try not to break any functioanlity for an include:
* Amazfit Bip
* Amazfit GTS
* Pinetime Infinitme
* Bangle.js
These are devices which are properly implemented in the application, but I do not have and are tested by the commuity, and include:
* Amazfit BipS
* Amazfit Bip Lite
I do not promise not to break funcaionality in these, but will fix where I can
These are devices which use a protocol that is close to another suppored device, and so is treated like that device. Your mileage may vary with these devices.
* MiBand 2/3/4
* AMzfit Cor
* Amazfit GTR
Amazfish needs to be built on OBS against a defined set of libraries. Becuase there is a delay between a Sailfish release and that release being available on OBS, there will be a delay to supporting the latest versions.
For releases of the current version built against other Sailfish releases, use the repositories at :
https://build.merproject.org/project/show/home:piggz:harbour-amazfish and
https://build.merproject.org/project/show/home:piggz:kf5
The new sport display feature requires the MapBox component. The easiest way to get this is by installing PureMaps from rinigus repository.
Powered by KEXI
As of version 0.5.1, actiivity data is retrieved into an sqlite database. Becuase I think it is important to allow individuals to be in control of their own data, and that they should have the ability to analyse it themsleves, I have chosen to store data in a KEXI compatible database. This will allow you to copy the database from the phone, and open it up inside KEXI on Linux/Windows/Mac and perform queries and reports on it. This added ability means i link to a couple of KDE libraries, which should be installed automatically.
Firmware Download - READ FIRST - I am not liable if you brick your watch ;)
Read this for info about which files to flash https://github.com/Freeyourgadget/Gadgetbridge/wiki/Amazfit-Bip-Firmware...
App has been tested using an amazfit bip and GTS, downloading the latest (0.1.1.45) official firmware.
The firmware is split into multiple files on these devices. With the official MiFit app, all are downloaded at once, and everything works fine. With this app, you have to send each file individually. The firmwares are available by extracting the MiFit apk, and looking in the assets/ folder for files named Mili_chaohu.*. When you select a file, its type and version will be determined, and you will be prevented from sending invalid files.
The firmware (.fw) requires a matching fotn (.ft) and resource (.res). Send the firmware first, the app will send a reboot command at the end of the transfer, and the watch will boot up into a mode where it needs the matching font and resource sent. Just wait for the app to connect again, then send the font and resource.
The following types of file exist:
firmware, resource, a-gps data, fonts
So, to re-iterate, the firmware flashing order is:
The newer devices (GTS, BipS etc) requires a server-side pairing key which requires inital pairing with an android device. To get the key, follow the instructions here and enter into Amzafish when prompted, WITHOUT 0x at the beginning.
See https://codeberg.org/Freeyourgadget/Gadgetbridge/wiki/Amazfit-GTS
AGPS Download/Transfer
The official amazfit app can download and transfer the AGPS files to the watch automatically. The amazfit web site limits download of the files to those with accounts. A python script has been developped that can download the AGPS files, these can then be transferred to your phone, and downloaded to the watch using the normal "Download File" option.
Pairing Issues
Pairing works for myself, sometimes I have to try twice. If pairing doesnt work at all, then try:
Check if after all this, pairing works from the sailfish BT settings page. It should pair and connect just fine from there. f that doesnt work, my app wont either.
Not all features currently implemented
***May not work on all devices***
Uses Bluetooth Low Energy to communicate with the watch, this is known to be problematic on some devices. it is known to work on the Xiaomi Mido. Probably also works on the FP2. Official devices unknown.
Implemented
Todo
Tip:
On your device, create a symlink in /home/nemo to /home/nemo/.local/share/harbour-amazfish
This way, you can easilty copy the database off the phone using MTP.
Bip and GTS notify when the watch button is pressed. This is captured by amazfish which allows running actions on theses presses. An action can be ran on 2,3 or 4 presses. To confiure the actions, goto Settings > Application > Button Actions.
A custom script can be used, the script must be called harbour-amazfish-script.sh and be in the home folder. Example which sends a OTP code to the watch as a message:
#!/bin/sh if [ "$1" == "4" ]; then CODE=`python3 -c 'import pyotp;totp = pyotp.TOTP("XXXX Authenticator code here XXXX");print(totp.now())'` dbus-send --session --print-reply --dest=uk.co.piggz.amazfish /application uk.co.piggz.amazfish.sendAlert string:'' string:'Google OTP' string:$CODE boolean:true fi;
Source: https://github.com/piggz/harbour-amazfish
Credits to:
2.0.3
2.0.2 - Now for 4.1
2.0.0 (incl unreleased 1.9.9)
1.9.8
1.9.7
1.9.6
1.9.5 (includes unreleased changes for otehr distros)
1.9.0
1.8.7
1.8.6 (not release for sailfish)
1.8.5
1.8.2
1.8.1 - Includes 1.8.0 which was skipped
1.7.1
1.7.0
1.6.8
1.6.7
1.6.6.
1.6.5
1.6.1
1.6.0
1.5.6
1.5.5
1.5.1
1.5.0
1.4.5
1.4.0
1.3.1
1.3.0
1.2.0
1.1.3
1.1.2
1.1.1
1.1.0
1.0.0
0.9.2
Stop notification when call answered
Fix sending weather on interval
Add more languages for watch (only works if supported by FW)
0.9.1
Fixed crash for new users
Weather UI fixes
Whitelisted some more firmware
Translation updates
Bugfixes for daemon/ui split
0.9.0
***ONLY FOR SAILFISHOS >= 3.0.3***
Daemon/UI split
Reworked some pages to streamline them
0.8.9
Add buffer for 10 notifications when watch disconnected
0.8.8
Added deep sleep value to page
Save GPX files in data location not cache location
May install on SFOS 3.0.3 when available
0.8.7
New UI layout
Sleep statistics
0.8.5
Added step summary chart showing steps over previous 20 days from the selected day
Added auto-sync of activity data which occurs each hour
0.8.2
Fixed applying settings from the UI
0.8.1
Hopefully fixed crash introduced in 0.8.0
0.8.0
Major code restructure to better allow support for other devices (devs needed!)
Whitelist new Bip frmwares
Hopefully fixed GPS issue with new firmwares
0.7.5
Implemented sending weather
Fixed app displaying correct status when watch disconnects
Use correct icon for depecher
Fix layout of HR button
0.7.3
Updated translations
Fixed user profile settings page not opening
Comments
nerd7473
Fri, 2020/03/06 - 23:38
Permalink
Thanks ✌
AlphaX2
Fri, 2020/03/06 - 23:17
Permalink
Should work as described here: https://github.com/Freeyourgadget/Gadgetbridge/wiki/Huami-Server-Pairing
nerd7473
Fri, 2020/03/06 - 00:07
Permalink
How do I get the pairing key for Amazfit Bip Lite?
jpn9s
Thu, 2020/03/05 - 14:42
Permalink
Great also with Cor. Outlook is fine.Thank you Piggz. Any plans to target Amazfish to e.g. Galaxy Watch? Amazfisfh is excellent watch app platform!
rdomschk
Wed, 2020/03/04 - 22:43
Permalink
Thank you for your time - now it works perfect for me and my Amazfit GTS with Sony Xperia 10 Dual Sim. Great work! By me helps a complete restart of the phone to solve all problems. Also the calendar works now. Thanks a lot. I am happy!
melvin
Wed, 2020/03/04 - 22:36
Permalink
I am using the Mi Band 3 and notifications and step count work quite well but I wonder why I can't set my alarms (the menu is missing) and why the step count of the current day defaults to exactly 2555965 steps (seems like a kind of an int overflow or sth) - anyway, I'd love to help!
piggz
Wed, 2020/03/04 - 22:47
Permalink
reboot or restart the service
melvin
Thu, 2020/03/05 - 11:04
Permalink
Awesome, this fixed it! Thanks :)
chris_bavaria
Wed, 2020/03/04 - 17:33
Permalink
I use "Amazfit Cor" and watchface-upload worked in the last versions.
"These devices are untested and use the Bip backend. Should be safe to try and FW download should not be allowed."Now I try to upload a watchface.bin I get a error: "File not supported on this device".
In description I can read for Amazfit/Cor:
Can you allow *.bin files to upload for watchfaces?
Thanks
trial
Sat, 2020/03/07 - 18:53
Permalink
Can someone confirm the pairing success with Mi band 3?
I know Mi band 4 is confirmed not working.
edit: I've just paired Mi band 3 successfully. Thanks!
alex000090
Mon, 2020/03/02 - 09:32
Permalink
Dear piggz, is there weather settings in newest version of program? I don't see it in Settings menu as in previous version.
piggz
Mon, 2020/03/02 - 23:24
Permalink
There is new code which hides some settings if theyre not applicable to a particular device. However, all devices have weater enabled at the moment, and GTS and Bip users have confirmed the option is there. If the device isnt paired/set up then it may not show.
alex000090
Tue, 2020/03/03 - 08:52
Permalink
OK. Thank you!
All have worked after rebooting the phone.
AlphaX2
Mon, 2020/03/02 - 23:15
Permalink
What device you are using?
ninepine
Sun, 2020/03/01 - 18:11
Permalink
Fantastic! 1.2.0 fixes the calendar data on GTS for me thanks.
cartron
Tue, 2020/03/03 - 07:13
Permalink
yep, works great on my GTS :)
rdomschk
Sun, 2020/03/01 - 16:39
Permalink
Thanks for your updates and using your freetime :) I have a GTS and I tested the new calendar datas with a choose a watchface with a text face for reminders. But I cant see any entrys. It is the right way?
A secound problem since the update 1.1.3 is by me, that the step count and the sleeptime for comming days are not 0. It shows for every future day the actuell day counts. I have a Sony xperia 10. Maybe it the reason.
cartron
Tue, 2020/03/03 - 07:15
Permalink
re "A secound problem since the update 1.1.3 is by me, that the step count and the sleeptime for comming days are not 0. It shows for every future day the actuell day counts. I have a Sony xperia 10. Maybe it the reason. ", I always had this behaviour, so not sure this was introduced in 1.1.3.
AlphaX2
Sun, 2020/03/01 - 17:59
Permalink
Version 1.2.0-1 should fix calandar data, so it did for me.
AlphaX2
Sun, 2020/03/01 - 14:25
Permalink
Hi piggz, great news, the latest 1.2.0 update fixes calander bug. It's sending calandar data to watch now and thats really cool. I'm working on some GUI beautifying, hope you're interested. :-)
AlphaX2
Sat, 2020/02/29 - 19:52
Permalink
Hi, thank you for the great update with all the these small detail fixes. I'm very sorry, but the new feature of sending calander data, is not working on my GTS. The logs (journal) shows no errors. Any idea, what to try? Thank you very much.
piggz
Sat, 2020/02/29 - 19:58
Permalink
Please supply the logs from journalctl | grep amazfish.... Calendar looks 2 weeks ahead and sends the first 10 events it finds. You will have to reboot for it to work becuase of the permission system.
AlphaX2
Sat, 2020/02/29 - 21:03
Permalink
There are the logs, forced update with Button from debug settings page. https://pastebin.com/wQ8AJxN1
piggz
Sat, 2020/02/29 - 21:05
Permalink
Thats not a full log, get the logs from this boot with journalctl -b | grep amazfish
AlphaX2
Sat, 2020/02/29 - 21:52
Permalink
Ups, sorry.
https://pastebin.com/knyz9bvf
And there is an error, while creating the database.
Thank you.
piggz
Sun, 2020/03/01 - 13:41
Permalink
Can you show the content of /usr/lib/systemd/user/harbour-amazfish.service
Have you rebooted?
piggz
Sun, 2020/03/01 - 13:42
Permalink
Oh, i know the issue...
piggz
Sun, 2020/03/01 - 14:05
Permalink
Please try 1.2.0. Service will need restarted/or a reboot.
Stezkoy
Sat, 2020/02/29 - 15:14
Permalink
Hi, this application supports clock GTR?
piggz
Sat, 2020/02/29 - 15:27
Permalink
not yet, can you gie the exact name of the GTS from the bluetooth settings page?
Pages