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
es1445
Thu, 2018/07/19 - 21:00
Permalink
Very nice app but I am missing the sleep tracking funktion. Can you add this feature? This would be very nice.
piggz
Thu, 2018/07/19 - 22:15
Permalink
Yes, its a feature id like to add.....however, you could also work it out for yourself. As you may or may not know, I store all the data in a .kexi database. If you copy the database off the computer, and load it up in Kexi on a desktop machine, you may be able to work out how the sleep data is stored. I basically store all the activity events off the watch, so working out sleep patterns is just a case of querying the correct data.
jojonintendo
Thu, 2018/07/19 - 20:23
Permalink
Can't get to install it on my Xperia X with latest 2.2.0 Sailfish X. Also, can we expect support for Amazfit equator someday? The hardware seems to be the same as Mi Band, functionality wise it is just like first Mi Band but with even less features (no LED).
piggz
Thu, 2018/07/19 - 22:18
Permalink
any errors? what happens if you try and install from the command line? My understanding is that is _does_ work on the X. I think the app mostly supports the MiBand 2, but never had anyone test the original MiBand. Without a device its hard to add support, but I will accept PRs for new devices on github, or device donations :)
jojonintendo
Fri, 2018/07/20 - 00:55
Permalink
Installing from command line I get approx this (translated): fatal error, nothing provides libKDb3.so.4. Thank you very much for your hard work and for answering this fast!
piggz
Fri, 2018/07/20 - 09:34
Permalink
how are you installing? if using storeman, this should be resolved automatically. the only way i can see this failing is if you just downloaded the rpm. look at my other packages and install all the kde ones if you are insatalling outside of a package manager.,
jojonintendo
Fri, 2018/07/20 - 13:05
Permalink
Silly me, I was just installing the rpm. Now the app works as it should. It seems to try to pair to the equator, but can't really achieve it. If I pair the device from the phone first, then it appears as connected in Amazfish but can't get any data. I could try to provide you with some logs if it could help development. The debug info of Amazfish doesn't really work with equator though.
Again, thank you for your time!
ar560
Mon, 2018/07/23 - 20:38
Permalink
Hi. Do you activated MiBand in MiFit app? I couldn't connect Amazfit to fresh buyed Band 2. After registration I could connect to Miband.
My setup: Intex Aqua Fish 2.2.0.29 MiBand 2 HW:V0.1.3.3 SW:V1.0.1.81
Now my problem. No steps count on main page and no heartrate on analysis page. Also alarms seems to not be working.
ar560
Mon, 2018/07/23 - 21:50
Permalink
Just found function "Lift wrist to view info" doesn't work with Amazfish. Previously I switch on this function in MiFit. And now it doesn't work :(
Where "Refresh button" go? :)
https://i.imgur.com/3CA3iBd.png
piggz
Mon, 2018/07/23 - 21:56
Permalink
refresh is now a pulley menu on the stats page
piggz
Mon, 2018/07/23 - 20:57
Permalink
If you run harbour-amazfish from the command line, it will generate a ton of output which would be useful to debugging the MiBand2. Have you set a profile on on it? Settings > profile > save, see if that helps.
ar560
Mon, 2018/07/23 - 22:49
Permalink
looks like 12/24h setting inversed for band2. When I select 12h, clock show 0-24 range. 24h selected -> 0-12h range.
ar560
Mon, 2018/07/23 - 22:07
Permalink
Send links to logs in privat message.
> Settings > profile > save
Where? In Mifit no such buttons. amazfish too
piggz
Mon, 2018/07/23 - 23:21
Permalink
I just uploaded a fixed version, opening the user profile page was broken.
Try opening the user profile page, and sending the profile to the band to see if that helps get data back. If not, send me logs again.
ar560
Mon, 2018/07/23 - 23:46
Permalink
Yep, settings are saved now. Only steps count on main page absent.
mr_Upolo
Tue, 2018/07/17 - 15:37
Permalink
Does it work with mi Band 1s? Or it will not connects?
piggz
Thu, 2018/07/19 - 22:19
Permalink
No, I think at best it works with the MiBand2, Cor, and of course Bip, which is the only officially supported device.
TybaldRabe
Tue, 2018/07/17 - 11:40
Permalink
Hi, your app is great, but latest version had issues w my MiBand2. Heath rate and steps not displayed on graphs. Ver 0.6.8-1 work better. How can i help? Maybe translation to Czech??
piggz
Tue, 2018/07/17 - 18:31
Permalink
odd, there shouldnt have been any changes in that regard. can you get logs after trying to retrieve data and post to github?
mr_Upolo
Tue, 2018/07/17 - 09:29
Permalink
Is there a thing to unpair the device? I want to connect another device but the app only find old mi Band 2...
piggz
Tue, 2018/07/17 - 09:37
Permalink
delete the old device from system bluetooth settings, and make sure it is out of range when pairing the new one.
explit
Fri, 2018/07/06 - 01:49
Permalink
It brings cyrillic (RU) support. (For me very important)
piggz
Fri, 2018/07/06 - 09:17
Permalink
in that case id better add support for setting that lang in the app!
explit
Thu, 2018/07/05 - 16:00
Permalink
Thanks piggz! Cool App. Working with the new FW 1.0.1.00 too
piggz
Thu, 2018/07/05 - 17:06
Permalink
cool, im not on that yet ... does it bring anything noticable? theyre terrible for changelogs!
TybaldRabe
Fri, 2018/06/29 - 13:36
Permalink
Hi, maybe developer "mat90c@gmail.com" can help with code for MiBands. He build app for android. I can help with Czech language.
Caluna
Thu, 2018/06/28 - 15:51
Permalink
How to upload a watchface file? At least bin files from amazfitwatchfaces do not work. When I choose a downloaded bin file at "Download File" it says: "No file selected".
piggz
Thu, 2018/06/28 - 16:24
Permalink
works here, but maybe i have a newer dev build . apologies, ill re-upload later, i remember fixing that as one of the last problems, and could have got the release wrong.
Caluna
Fri, 2018/06/29 - 09:29
Permalink
Great, now it works: thank you!!
cvp
Sat, 2018/06/23 - 14:05
Permalink
Thanks for the update. Watchface upload works fine! I get the message that the app responding, just keep waiting. Donation is out :)
German translation for 0.6.5 is ready, pullrequest is started.
Pages