Security of the TOTP hardware token secret keys (seeds)

We have been getting questions about the security surrounding the shared secret key hashes (seeds) of our hardware tokens. On this page, we describe how this data is secured, operated, stored and destroyed.

The seeds are randomly generated and sent to the factory in a secure manner (we use GPG encryption).  

We store them on our servers for a limited period of time and then delete after seeds were transferred to end users. The servers we are using to temporarily store the secret seeds can only be accessed from our office network and the access is protected with two-factor authentication. 

Permanent storage of seeds is done at UBS Safe, which is basically our e-banking account attached storage and has the highest level of security (MFA protected, PCI-DSS compliant etc.)

When it comes to transferring the keys to end users, we strongly recommend using PGP or GPG encryption to transfer secret keys for all types of tokens. PGP and GPG are popular solutions for encrypting, decrypting, signing, and verifying messages and files, often found in email communications and package repository identity verification. If you are new to PGP we recommend having a look at the PGPTool

   If requested by customers, we can send the seeds by email assuming the tokens are not to be used in production, however, this is not recommended as transferring secret keys in plain text format by email may lead to a compromise of your token seeds which could potentially result in MFA bypass.


Furthermore, in this context, worth mentioning the following:

- All our employees use multi-factor authentication wherever possible - in addition to corporate email accounts, personal email and social network accounts are also protected with 2FA.

- TOKEN2 has started as a research project with the University of Geneva- the core operations team members hold M.Sc./Ph.D. degrees in Information Security.

If you are still concerned, there is an option of setting the seeds yourself, so you have full control and no one else touches your seeds. This option is only available with our programmable tokens. The procedures are explained below.


Hardware token provisioning with the full control of the seeds

The guide below is using Azure MFA as an example. The same provisioning flow can be used with other systems as well.

TOKEN2 has developed a simple HTML5 application ("Token2 TOTP Toolset") which can be run locally without accessing any libraries/resources on the Internet (including the QR image generation). This application is designed to generate random seeds and produce CSV file ready to be imported to Azure MFA. The source code if the application is available on GitHub.


The provisioning will be done in the following way:

  1. Download and launch Token2 TOTP Toolset - local. You may want to run this app on a computer that is fully offline (or firewalled) to be sure no information is being transferred to third parties
  2. Install Token2 Burner App on an Android device with NFC. After the app has been installed, you can set the device to flight mode with Bluetooth, Wifi and Cellular data off to ensure no data will be transferred outside
  3. Generate a random seed using Token2 TOTP Toolset. 
  4. After the seed is generated, burn the seed using the Burner App
  5. Verify the OTP shown on the device with the OTP value shown on the  TOTP Toolset
  6. Enter the serial number of your token and the username in UPN format to the relevant fields on the TOTP Toolset and click on " ⇲ append to CSV" button
  7. Repeat steps 3 to 6 for every token you are provisioning
  8. Click on "save as file" button and save your MFA CSV file
  9. Import the CSV to Azure MFA 
  10. Your tokens are ready to be activated for users 




Payment methods

   PayPal Logo
Large Volume Orders
For large orders, Token2 offers volume discounts.If you are interested in larger volume orders, please contact us and we will get back with a quote immediately


x
This website is using cookies. By using this website you agree with our ToS That's Fine