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
dalas_revo
Tue, 2019/01/22 - 22:52
Permalink
The same hills true for the intensity graph, it also shows today's intensity for yesterday and tomorrow
dalas_revo
Tue, 2019/01/22 - 22:47
Permalink
Thank you for the update!
I found that for me the steps all are the same as for the day being in the detailed view. I mean that if i walked 5000 steps today, the page with the graphs for yesterday and for tomorrow also show these 5000 steps, at least as number.
One question: whenever i go to the page with the data graphs I always have to touch the single graphs to show anything or to update. Could it be automated that whenever I enter this page that all graphs are updated?
jpn9s
Sat, 2019/01/19 - 09:20
Permalink
Amazfish app looks excellent for a smartwatch support. Could it be possible to adjust it working with Samsung Galaxy watch (Tizen)? I am very disappointed that Xperia X do not support it due to too low Android support 4.4.4. Also I do not have any high expectations whether Galaxy Wearables app should work with Android support for 5 or 8.1. Thank you for information. Good luck.
Historyscholar
Fri, 2019/01/11 - 07:17
Permalink
Good ,but I just have Ticwatch S.
mvdm
Wed, 2018/12/12 - 17:47
Permalink
Just installed it on sony xperia X 3.0.0.8 and paired it with mi band2
working : date and time
heart rate and battery
not the steps and the alarm so far ...
test of call ok , thanks a lot for the great work ;-)
mvdm
Mon, 2019/01/14 - 12:38
Permalink
works great with xperia x and mi band 2 only missing step counter not displaying on the main page but ok in the data statistics.
great work,
phone call also ok
not ok notification, email and popup
time format 24 hr not ok ..
hardware v0.1.3.2 soft v1.0.1.39 ...
mvdm
Mon, 2019/01/14 - 12:44
Permalink
if you need help for french or dutch translation just ask ;-)
cvp
Sat, 2018/12/01 - 00:42
Permalink
Did someone test it with the Stratos 2 or Pace Watch? :)
dalas_revo
Fri, 2018/11/30 - 18:46
Permalink
In SFOS's BT setting, sorry
dalas_revo
Fri, 2018/11/30 - 18:46
Permalink
I recovered by deleting the watch in SFOS's, re-pairing it, sending resources, fw and finally the font
marxistavegana
Fri, 2018/11/30 - 14:05
Permalink
0.8.1 works with COR and does not crash
dalas_revo
Thu, 2018/11/29 - 10:38
Permalink
No, I think your instruction is clear enough, people just have to follow it ;)
Maybe you could add a hint not to mix Latin and non-latin files, but in general I think it should be clear...
Reflashing did only work after deleting the watch in the BT section of SFOS settings, but finally flashing non-Latin font did the trick! Thank you very much!
dalas_revo
Thu, 2018/11/29 - 09:38
Permalink
Very nice app! Thank you!
Finally a usable smartwatch on sailfish :) Unfortunately I managed to bring my device into a more or less unusable state ( not bricked). First I flashed latest fw ( doesn't recognize the one with ending "latin" as fw) and res (latin), which worked very well. Afterwards I flashed latin fonts. Now the Bip always displays "Connect APP to update" and I can't get it out of this state. Reflashing firmware and ressources doesn't help.
I's there anything I can do to get it working again?
I am using it on an XA2, amazfish 0.8.1, as 0.8 always crashed at startup
piggz
Thu, 2018/11/29 - 10:11
Permalink
This page better describes the process
https://github.com/Freeyourgadget/Gadgetbridge/wiki/Amazfit-Bip-Firmware...
piggz
Thu, 2018/11/29 - 10:07
Permalink
Oh, sorry you got in such a state. Could you try flashing the 3 non latin files, firmware, Res and font.
Failing that, can you use an android device to use mifit to do the flash? I probably need better instructions on what to flash and which order!
Caluna
Fri, 2018/11/30 - 10:59
Permalink
Hi piggz,
I am also trapped in the "Connect to update" loop. Tried tore-flash different firmwares (from 0.1 to 1.1.5) without much success. Additionally, Mi-Fit app on Android does not help as pairing fails. Do you have any other ideas?
Best
C.
piggz
Fri, 2018/11/30 - 11:46
Permalink
you need to srnd thr matching firmware and res, and.possibly font file. hopefully amazfish can still connect and send the files? all i can suggest is what is in the gadget bridge wiki, good luck
Caluna
Fri, 2018/11/30 - 15:13
Permalink
Hi Piggz,
I think, the device is bricke and stuck in a state that cannot be recovered: The files are sent in the correct order (as suggested in the wiki), but at the end of the transfer of the respective files I always end up with the message "connect to app to update" and connection to the phone is lost. I have to re-pair using Amazfish and can connect again. The connection request on the device pops up and I can agree and connection can be established. But still: the device does not "boot".
Mi Fit on Android sends connection request, but when I agree, it says that the connection request cannot be sent.
piggz
Fri, 2018/11/30 - 15:30
Permalink
doesnt sound dire if you can still connect and send files. persist, try older, or try gadgetbridge
Caluna
Fri, 2018/11/30 - 16:50
Permalink
Tried a lot without any success: Gadgetbridge says, that there is a problem with transfer of metadata. "Google" provides not a real answer to this...
piggz
Fri, 2018/11/30 - 17:29
Permalink
you are trying all the non latin files,.3 of?
Caluna
Fri, 2018/11/30 - 17:43
Permalink
Yes: tried just the non-latin files, also in different order (fw first, res first gps first). FW Versions: 1.1.5.02, 1.1.5.04, 1.0.1.00, 0.0.9.40
All ends up with the same result
Caluna
Wed, 2019/01/23 - 14:07
Permalink
Finally, the problem has been solved "automatically": Somehow the firmware got stuck (I think). I had to wait till the device shut off due to low battery, load it and restart. Afterwards I had to install firmware again using official Mi-fit app on an Android deviced. Now, everything works again like a charm...
cartron
Thu, 2018/11/29 - 01:03
Permalink
One thing i just noticed: alarms are not synchronized to the watch. Actually i have one alarm which got pushed (happening on Mon, Tue, Thu, Fri) but whenever i try to add / enable other alarms, the watch shows me the other alarms as '0:00 tomorrow / disabled'
And modifying the alarm which got pushed does not work either
dalas_revo
Thu, 2018/11/29 - 10:53
Permalink
I cannot push any alarms, too. The output which is relevant here (I guess) is
piggz
Thu, 2018/11/29 - 10:56
Permalink
Ah, great, thanks for the console output, a remainder of the major restructure.
cartron
Sat, 2018/12/01 - 10:28
Permalink
Will you fix it in thr next release? :)
meemorph
Mon, 2018/11/26 - 21:48
Permalink
On startup
harbour-amazfish
[D] unknown:0 - BluezAdapter::BluezAdapter
[D] unknown:0 - Registered notifications listener for device
[D] unknown:0 - BluezAdapter::setAdapterPath: "/org/bluez/hci0"
[D] unknown:0 - DRIVERS: ("org.kde.kdb.sqlite")
[D] unknown:0 - KDbConnection object created.
[D] unknown:0 - KDbConnection::connect() OK.
[D] unknown:0 - ("mi_band_activity", "sports_data")
[D] unknown:0 - VoiceCallsChanged
[D] unknown:0 - ActiveVoiceCallChanged
[D] unknown:0 - BluezAdapter::BluezAdapter
[D] unknown:0 - Using Wayland-EGL
library "libwlparser.so" not found
Segmentation fault (core dumped)
meemorph
Mon, 2018/11/26 - 21:40
Permalink
0.8.0 gives segmentation fault on geminipda with 3.0.0.8. Had to go back to 0.7.5-1.
piggz
Mon, 2018/11/26 - 21:44
Permalink
Are you doing anything specific to cause the crash or does it happen on startup?
Pages