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
nitrotnt
Sat, 2024/12/14 - 13:25
Permalink
Hi from what I read bangle.js2 is not supported, would it be possible, with donations, to develop support?
Firefox84
Sat, 2023/12/23 - 20:34
Permalink
Hey Piggz,
a great work this app! :) Do you think it would be possible to add support for the Amazfit Balance? As i tried to connect it with Amazfish, but couldn't establish a connectio . Thanks really much for your effort! :) Greetings
piggz
Sat, 2023/12/23 - 21:49
Permalink
Hi
The balance uses ZeppOS3 which isnt supported by Amazfish unfortunately. Support could likely be added as a refernece implementation exists in Gadgetbridge, but it would have to wait for me to get such a device, or for someone with such a adevice to add support. Id be more than happy for the community to band together and send me a balance, looks like a nice watch! :)
Firefox84
Tue, 2023/12/26 - 23:59
Permalink
Hey Piggz,
thanks for your quick reply. Merry christmas! :)
If there would be an iniative to buy a second hand device, i would be in to participate with 5-10 €
I just tried to install Gadgetbridge, but due to the Bluetooth problem in Android it doesn't work for SFOS users :(.
Thanks for the great effort you are doing for the SFOS community!
Greetings
zipotron
Thu, 2022/09/08 - 11:24
Permalink
Hello, I have the PineTime and Xperia 10 II, until two or three months ago the app was working good, but from last system update (or whatever else, I am not sure completelly) I am not able to pair the devices, I tried many times, many ways, like using pinetime profile, and infinitime profile... no way. I hope the issue is easy to fix and will be solve because I really like this app. Thanks
MihailSafonov
Wed, 2022/08/24 - 14:01
Permalink
Как подключить Mi Band 4?
itsNotMe
Tue, 2022/06/14 - 12:12
Permalink
When supporting Bangle.js.. this means Bangle.js 2, too? For me connection to Bangle.js 2 works. But I don't see anything else... No Heart Rate etc. Is there any Wiki for further documentation? Has anyone experiences with Bangle.js 2 + Amazfish?
Cheers!
EPaiN
Mon, 2024/04/22 - 16:22
Permalink
I have the same issues on my Bangle.js 2, did you figure out anything else?
ahalasz
Sat, 2022/05/28 - 15:42
Permalink
Hi Piggz,
For running workout I have to download the agps files to the watch. I've followed your instructions and could download the zip files from the huami server with the script and I tried to download the cep_pak.bin and the gps_alm.bin to the watch. I got error messages. In case of cep_pak.bin the Amazfish says File not supported on this device. And in case of gps_alm.bin it says: Update opertaion failed, filetype not supported.
Could you help me please what's wrong?
I used the script with these options: ./huami_token.py -m amazfit -e myemail -p mypw -g
b100dian
Fri, 2022/07/22 - 17:59
Permalink
I also get this on the GTR1..
ahalasz
Wed, 2022/05/25 - 15:51
Permalink
Hi Piggz,
I'm new with Amazfish, bought an Amazfit GTS installed Sailfish 4.4.0.64 on a Xperia 10 III. After pairing Amazfish and the watch working well together. Only one question: After the pairing I realized lots of menus disappeared from the watch: If I scroll up there is no any menu showing only a black screen only time in the upper right corner with small font. Scroll down I can see battery, brightness and so on as earlier with Zepp on Android. Is it normal or should I upload the latest firmware again to the watch to get back the factory menus?
Kind regards
Arpad
piggz
Wed, 2022/05/25 - 16:21
Permalink
Try
Settings > Device > Huami Display Items
And make sure all items are enabled, int he order you like them, then click Save Settings
ahalasz
Wed, 2022/05/25 - 17:18
Permalink
Very nice. Thank you very much. For PAI it says I would have to set on mobile app 1 minute Automatic Heart Rate detection. Is there any trick on Amazfish to set this and get the PAI on the watch?
piggz
Wed, 2022/05/25 - 19:57
Permalink
Yes, that should work ..
Settings > User, set the all-day HRM rate to 1 ... the slider is a little fiddly but it will work
ahalasz
Thu, 2022/05/26 - 07:57
Permalink
Super! It's working. Thank you for this app.
Caluna
Fri, 2022/05/20 - 13:49
Permalink
On my GTR, Settings and Messages are missing in the menu. I am sure, that these have been there in an older version - but I might be wrong. Additionally, download of the data seems not to work any more, so that the graphs are not displayed. This also worked in older versions. I am currently using latest version from chum on Xperia 10 II with 4.4.0.64 (was the same in 4.4.0.58).
Vargotoros
Mon, 2022/05/16 - 08:48
Permalink
For Mi Band 4 show only steps. Heartrate or Sleep data don't show((
chris_bavaria
Wed, 2022/05/11 - 02:24
Permalink
Hello, how I can purge all settings from amazfish?
After removing app and delete ~/.locale/harbour-amazfish folder there appear my settings and private profile after new reinstall.
chris7chris
Sat, 2022/04/23 - 21:37
Permalink
Hello Piggz, sorry but I can't find harbour-amzfish in chum. (Sony 10 II, 4.4.0.58) Chum is installed correctly (hopefully).
I also can't find it here: http://repo.merproject.org/obs/sailfishos:/chum/4.4.0.58_aarch64/aarch64/
Installed this app from storeman, but it worked only partially like fingus described before.
What else can I do?
...Meanwhile I helped myself. I noticed that there is an option to enter another SFOS version in Chum. After entering a previous version amazfish appeared... After installing this everything worked as it should. Thanks for everything.
calinutzzz
Tue, 2022/03/22 - 09:38
Permalink
Unfortunately, not working anymore with SFOS 4.4.0.58 Any suggestions how to fix it? Thank you!
Blumenkraft
Wed, 2022/04/20 - 20:24
Permalink
I can also confirm, not working with 4.4.0.58. Any advice is appreciated, thank you.
piggz
Wed, 2022/04/20 - 21:07
Permalink
You need to install the updates from Chum
Blumenkraft
Sat, 2022/04/23 - 21:53
Permalink
What updates are we talking about? Chum GUI says "No updates available".
piggz
Sat, 2022/04/23 - 23:06
Permalink
Uninstall any existing version, 2.0.8 is in chum, but pkcin wont change vendor, so wont show an update if the installed version isnt from chum.
Blumenkraft
Sun, 2022/04/24 - 10:58
Permalink
I see. It seems to work again. Thank you.
fingus
Mon, 2022/04/04 - 16:56
Permalink
Installation on SailfishOS 4.4 with Amazfish 2.0.3 works for the second time but the pairing with my Amazfit GTS doesn´t work anymore. The watch is found and i can enter the Pairing-Key but after that nothing happens.
fingus
Fri, 2022/02/04 - 12:17
Permalink
Please add Notification to Watch if Smartphone Battery is fully loaded.
Second suggestion:
Selectable Calendar Entries for the Reminder
apozaf
Tue, 2022/01/25 - 09:09
Permalink
Either download Termux, give it root rights with "su", or use adb, then go to /data/data/... and write the sqlite3 command. If it's not working look at the name of the origindb file and use that instead of origindb[yourdevicename].
gembiak
Fri, 2022/01/07 - 23:08
Permalink
Hello
I have a problem with the pairing key. I did manage to get the CHUM repository and Amazfit app installed, but the instructions for getting the pairing key are too complicated. The link takes you to the next link, and this one to the next. There are requests to install applications such as Buildozer and Kivy, but it is not given how to do it.
Can I have simple but detailed step-by-step instructions on what to do to obtain the pairing key? Please explain how to use any scripts or other commands such as (found at https://github.com/argrento/huami-token):
"3. Clone this repo: git clone https://github.com/argrento/huami-token.git"
"4. Install requirements: pip3 install -r requirements.txt"
The phone on which I want to install the Amazfish application is Sony Xperia XA2 Plus, of course, with Sailfish 4.3.0.12. I also have an unreported Sony Xperia 10 Plus phone with Android 10 on which the ZEPP application is installed and an established connection with the Amazfit GTR 2 watch.
Thank you so much for your help and sorry for my language as I use an online translator.
apozaf
Tue, 2021/12/28 - 15:29
Permalink
Same as ABreen. Amazfit GTS.
I cannot even connect with Gadgetbridge anymore. Resetted, grabbed new key... No luck
Pages