Skip to content

A 2FA app for Zepp OS powered smart watch

License

MIT, MIT licenses found

Licenses found

MIT
LICENSE_ZoLArk173
MIT
LICENSE_manujedi
Notifications You must be signed in to change notification settings

manujedi/Authenticator

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

73 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Fork of ZoLArk173 Authenticator Zepp OS app

Big thanks to ZoLArk173 and Alpaca131 for the idea and original code. The application is now available in the Zepp Store

Note to anyone wants to use it with gadgetbridge: The gadgetbridge branch contains a version with a hardcoded otp list so you can build it yourself and flash with gadgetbridge

  • added advanced options:
    • otpauth://totp/{ACCOUNT_NAME}?secret={SECRET}&issuer={ISSUER}&algorithm={ALGO}&digits={DIGITS}&period={PERIOD}
      • {ALGO}: SHA1 (default if not specified), SHA256, SHA512
      • {DIGITS}: how many digits the code has (more than 10 are useless as only 31bit are used for the code)
      • {PERIOD}: in seconds, (30 default if not specified)
  • fixed base32 decoder
  • fixed label (https://github.com/google/google-authenticator/wiki/Key-Uri-Format#label)
  • changed to Zepp OS 2
  • auto update expired codes
  • New storage API from 2.0
  • Dead simple UI, works without modifications on GTR4 and GTS4 (and looks good on my opinion)
    • should work on GTR3, GTR3-Pro, GTS3 if they ever get the Zepp OS 2 update

Screenshots

App settings

App Settings

Watch App on GTR4

WatchApp WatchApp WatchApp WatchApp

Watch App on GTS4

WatchApp WatchApp WatchApp WatchApp

Old Readme

Authenticator

An 2FA app for Zepp OS

Features

  • Display 2FA codes on the Zepp OS enabled watches.
  • Manage 2FA codes inside Zepp app settings page.

Usage

After install the app, go to Authenticator setting under "More Settings" on Zepp app. You can add 2FA URI to the list by tapping the blue button. Now, the URI must be formatted as following:

otpauth://totp/{ACCOUNT_NAME}?secret={SECRET}&issuer={ISSUER}
  • {ACCOUNT_NAME}: The account name, e.g. alice@gmail.com
    • Notice that some character like : or @ will be converted to other code when you copy. You can edit it if it doesn't display properly.
  • {SECRET}: The secret key
  • {ISSUER}: The issuer of the code, which will be display as the title. e.g. Google

After adding URI, you can open the Authenticator app on the watch. The watch will sync the data from the phone every time it launched. You may see the 2FA 6-digit code on the screen!

Future Improvements

This app is a prototype. There are a lot of things can be improved.

  • Cannot rearrange 2FA codes.
  • Cannot import URI without manual edit.
  • Won't auto update every 30 secs.
  • The UI of the settings page is less than desired.
  • The UI on the GTS 3 is less than desired.

Notes

Some part of code is come from demos of Zepp OS developer documentation.

2FA code calculation part is come from iamyuthan/2FA-Solver.

Special thanks to them!

Random

There are only several apps that available to Zepp OS enabled watches. And some of them are kind of useless or games. It is kind of disappointing that Zepp OS is capable of running third-party apps while maintaining the excellent battery life, while there are only a few useful apps in the App Store. Then a 2FA app comes to mind, a useful application that can show 6-digit code handy when you login. It is also my first time developing with JavaScript, which you can tell from by terrible coding style in this project.

About

A 2FA app for Zepp OS powered smart watch

Topics

Resources

License

MIT, MIT licenses found

Licenses found

MIT
LICENSE_ZoLArk173
MIT
LICENSE_manujedi

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 100.0%