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
kkoenders
Fri, 2020/12/18 - 17:48
Permalink
I have installed v1.8.1 of the application (no version info in the app itself?) on Sailfish 3.4 on a Sony XA2, linked to an Amazfit BIP (FW v1.1.16.34). Time and weather is synced and I get steps and heartbeat back. I do not get any notification on the phone though. In the debuginfo Model, Firware Rev and Manufacturer are empty. A-date = 2020-10-25 (I had amazfit installed on v3.3?) and S-date=1970-01-01. Is this because of the firmware of the watch?
rdomschk
Fri, 2020/12/18 - 00:56
Permalink
How can I chang the date for the data? After the update I have A: 01.01.1970 and S:01.01.1970 and I cannot change this to 2020. Thanks in advance
piggz
Fri, 2020/12/18 - 01:06
Permalink
hmmm,not sure how that could happen ... but..
dconf write /uk/co/piggz/amazfish/device/lastactivitysyncmillis 'int64 1608242662000'
dconf write /uk/co/piggz/amazfish/device/lastsportsyncmillis 'int64 1608242662000'
where the number is the number of seconds since 1-1-1970 * 1000, use eg https://www.epochconverter.com/
vsimonkay
Thu, 2020/12/17 - 15:47
Permalink
Do you plan to support AmazfitX?
eanderalx
Thu, 2020/12/17 - 15:36
Permalink
Cant pair with mi band 2. The log say initial auth success and bipinterface auth false. Reset watch and restart phone/Bluetooth dont help
harbour-amazfishd[3696]: [D] unknown:0 - Received initial auth success, requesting random auth number
harbour-amazfishd[3696]: [D] unknown:0 - Writing to "00000009-0000-3512-2118-0009af100700" : "020802"
harbour-amazfishd[3696]: [D] unknown:0 - Mi2Band Changed: "00000009-0000-3512-2118-0009af100700" "\x10\x02\x04"
harbour-amazfishd[3696]: [D] unknown:0 - Unexpected data
harbour-amazfishd[3696]: [D] unknown:0 - BipInterface::authenticated: false
harbour-amazfishd[3696]: [D] unknown:0 - DeviceInterface::onConnectionStateChanged "authfailed"
mklick
Thu, 2020/12/17 - 13:59
Permalink
Thanks for progress but I have still some issues with GTS. Pairing works now with 1.8.1 (thanks), the actual data are present. But download of data starts but does not work. Thus, there are no history data, the diagrams are emty. No journal files found, no other error message. Restart phone and stop/start if service and similar measures does not work, any idea?
chris7chris
Fri, 2020/12/18 - 19:36
Permalink
Thats almost the same that happens to my phone (XA2) and watch (GTS). Only the steps are syncing.
With my BIP everything seems to work (but I didn't check everything - it only looks like that). When I switched back to GTS again, the synched walking distance remained. It can be cheched although the BIP is not connected.
But thanks for all your effort, piggz! I am looking forward to your next updates.
piggz
Thu, 2020/12/17 - 14:11
Permalink
Can you post logs
ronny_b
Fri, 2020/12/18 - 18:13
Permalink
Do you perhaps have the problem since the time change on October 25, 2020?
Ronny
elkiaer
Thu, 2020/12/17 - 13:03
Permalink
Hi agian
The app is now installed, the Mi Smart Band 4 is Paired and the service started.
I can see the Mi Smart Band 4 on the Main screen (first screen), but the icon for the BlueTooth and Watch only apiers for a short time, about 3 secound once a while, this means no connection.
When "clicking" on the start button the Enable button is stil on the front screen.
Any idea to solve this issue?
elkiaer
Thu, 2020/12/17 - 13:20
Permalink
I can see there are some connection, the steps is updated on the phone.
The Download Data is not active.
piggz
Thu, 2020/12/17 - 13:09
Permalink
give phone a reboot, and if still issues send logs from journal. journalctl | grep amaz
elkiaer
Thu, 2020/12/17 - 16:03
Permalink
Did you revive my logs?
I'm sure that I post it but cannot see it anylonger, maybe you have removed it after copying?
piggz
Thu, 2020/12/17 - 16:19
Permalink
Yes, looked like it removed my reply too. You are getting authfailed error ... did it used to work? are you using the correct auth code from android mifit app? Note miband4 is an untested device, i will have to review code to make it likely to work, but cant be sure.
elkiaer
Thu, 2020/12/17 - 17:15
Permalink
Hi
I’m connected now :-)
I did again connect the Mi Band 4 to Mi Fit mod apk (android) and got a new Auth key. Used that and now it works.
elkiaer
Thu, 2020/12/17 - 11:31
Permalink
Nice but -
I can still not install the app, gets the following error:
Nothing provides libicui18.so.63 needed by libKDb3.3.3.0-1.6.1.jolla.armv7hl
I have also downladed the version 1.8.1 and installede it from the phone but gets an error here too.
What can bee the issue. I will mention for a little while ago I did reset the phone and installed the new flash file from Jolla.
elkiaer
Thu, 2020/12/17 - 11:37
Permalink
I have now done a:
devel-su
pkcon refresh
and installed the app again from openrepos and .... succed :-)
stevexley
Thu, 2020/12/17 - 09:10
Permalink
Hi, When trying to update to 1.8 I get an error that nothing provides kdb-sqlite3-driver >= 3.1.0. I've tried pkcon refresh and tried installing sqlite but I still get that error. Which package contains kdb-sqlite3-driver?
piggz
Thu, 2020/12/17 - 11:30
Permalink
refresh and try again, i missed a few packages
kraemera
Thu, 2020/12/17 - 09:02
Permalink
I just tried to install amazfish on 3.4 and got an error message that nothing provides kcoreaddons >= 5.31.0.
piggz
Thu, 2020/12/17 - 11:30
Permalink
refresh and try again, i missed a few packages
kraemera
Thu, 2020/12/17 - 13:46
Permalink
Thx, it works now.
ninepine
Mon, 2020/12/14 - 00:01
Permalink
Any news on a version for 3.4 please?
piggz
Mon, 2020/12/14 - 01:09
Permalink
There is a build of 1.7 here https://build.merproject.org/project/show/home:piggz:harbour-amazfish for 3.3 and 3.4 .. im hoping to get 1.8 ready soon-ish!
ronny_b
Sat, 2020/12/05 - 21:27
Permalink
Since the change to wintertime (from GMT+2 to GMT+1) on 2020/10/25 I have again a problem with the database . The time repeats the same hour from "2020-10-25T02:00:00" to "2020-10-25T02:59:00" again and again.
You already solved this problem a long time ago.
Ronny
ronny_b
Fri, 2020/12/18 - 18:09
Permalink
Unfortunately, the problem is still present in the current version 1.8.1. My database "amazfish.kexi" starts with 2018-10-29 and the data is present until the record 2020-10-25T02:59:00. After that an endless loop starts, again and again from 2020-10-25T02:00:00 to 2020-10-25T02:59:00.
Therefore, no history data is displayed. Maybe this could also be the problem of mklick?
Can you please have a look at it?
Thanks, Ronny
piggz
Fri, 2020/12/18 - 18:14
Permalink
Go into the debug menu and click the+ button next to the activity sync time to add a few hours, and try again
ronny_b
Fri, 2020/12/18 - 21:05
Permalink
Ok, I set by + a few hours further to 2020-10-26. now it seems to work again, thanks! :-)
What still irritates me: Also for me it says "S:1970-01-01T00:00:00.000Z" when debugging SportsData.
Ronny
elkiaer
Mon, 2020/11/16 - 10:36
Permalink
I have updated my xa2 with the latest flash file from Jolla.
I am not able to install amafish because of the ...so.63.
I can install version 0.4.7 but thats do not help me.
As you write, I must wait.
elkiaer
Sat, 2020/11/14 - 11:05
Permalink
Does the following means the amazfish app has been stopped for future development? Then I have a miband for sail.
https://forum.sailfishos.org/t/obs-shut-down-and-next-steps/1814
Pages