DuOTP is a small GPL3+ Android app that allows you to log in to Duo*-protected services with a standard OTP app, such as Google Authenticator.
DuOTP has no visible interface or app drawer icon. An OTP-capable app must also be installed (Google Authenticator or similar.) See below for usage instructions.
(Disclaimer: I don't know how much of this could vary between sites, so I can only describe how the one I tested with works.)
- Get your Android device with DuOTP installed and enter incognito mode. (Incognito so that any previous login sessions are ignored.) Begin logging into the protected service on your Android device.
- When you get to the Duo login screen, choose Add a new deviceand authenticate if needed.
- Choose to activate a Tablet, then chooseAndroid.
- Click I have Duo Mobile installed, thenTake me to Duo Mobile.
- Your OTP app should then open, asking to confirm importing the secret token. If an error occurs, DuOTP will pop up an error message. If nothing happens, then DuOTP is not installed correctly, or your browser is not activating it.
- After you have saved the account in your OTP app, return to the browser. Tap ContinueandContinue to Login. Now and any future time you are prompted by the Duo login screen, chooseEnter a Passcodeand copy the numeric code from your OTP app.
After this, you don't need to use DuOTP again, and may remove it from your device if you'd like. (It's small though, so it might be worth keeping around in case Duo expires the secret token.)
- Google Authenticator for Android v5.00, GitHub release APK
- de.kuix.android.apps.authenticator2version 1.0
- andOTP version 0.7.1.1
- Firefox for Android 68.3.0 (for browsing through the import process)
This app is activated by tapping a link with sceheme duo:// from a Duo-enabled web page. DuOTP then loads the HOTP token from a Duo URL and passes it to your OTP app (any app supporting the otpauth:// scheme.) Most of this logic is in the ActivationStringImporter class.
- Does the token expire after some time? (Mine's still working after 8 months.) The JSON response from the service does include a reactivation_tokenfield that DuOTP currently ignores.- If it does expire on you, you can re-do the import process and I imagine you'll get a new secret and be fine until another expiration.
 
- QR code enrollment: if you begin logging in on a PC, you have the option to enroll via Duo Mobile with a QR code displayed on the PC.
- I believe the code contains the same data as the duo://link you are tapping in my usage instructions above, but without a URI scheme prefix. If you would like to use the QR code and can DIY a bit, you should be able to decode the QR code into text, addduo://on the beginning, generate a new QR code from that result, and scan that in your phone's browser, and it will be imported by DuOTP and your OTP app.
 
- I believe the code contains the same data as the 
- Supporting push notifications: I guess this app's target audience won't like the non-libre dependencies that probably come with that.
Copyright 2019 Joey Hewitt <[email protected]>
DuOTP is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
DuOTP is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.
The full GPLv3 license text is included in the file COPYING.
A file under Apache License Version 2.0 is included in app/src/main/java/com/google/android/apps/authenticator/util/Base32String.java.
* Note: this app is not associated with or endorsed by Duo Security, Inc. or Cisco Systems, Inc.
Thanks to https://github.com/simonseo/nyuad-spammer/blob/master/spammer/duo/duo.py for giving some hints about the enrollment process.