twitter logo linkedin logo facebook logo

FIDO vs M-PIN and the credential database (4 min read)

Dr Michael Scott
MIRACL Trust ID, 2fa, mfa, multi-factor authentication

If passwords are becoming redundant, what’s the solution? FIDO is an alternative approach, but comes with limitations. Using pairing-based cryptography to allow smart flexibility in the ‘secrets’ needed to enable authentication, MIRACL Trust ID takes security one step further.

In the final blog of this three part series, MIRACL’s leading crypto expert, Dr Michael Scott, explains how this MIRACL technology works and why it’s the future.

FIDO is a well-established industry solution to client authentication. It uses the tried and tested 50 year old technology of Public Key Cryptography.

Basically for the client it’s very like the hotel safe solution described in the first part of this three part blog series. A private key is stored inside of a hardware vault, which in turn is protected by a PIN number or a biometric. The associated public key is stored in a credentials database maintained by the server.

Authentication takes place when the server issues a random challenge to the client, who must access their private key to digitally sign the challenge and return it to the server. Finally, the server looks up the client in the credential database, retrieves their public key and uses it to verify the signature. Note that the successful signature requires possession of the private key but reveals nothing about it, so this does constitute a form of Zero-Knowledge proof.

The vault may exist inside of their mobile phone or it may be a physical token (U2F), sent out to the client as part of the enrolment process, which connects via USB to their laptop.

An attacker now has two problems to solve. They need to steal the mobile phone or the token, and they need to figure out the PIN, or provide the biometric.

Provided that you trust the hardware vault in either the mobile phone or the physical token – and we do day-to-day despite frequent accounts of the hardware being compromised - the front door certainly does appear to be protected. But that protection came at a price – secure hardware vaults are expensive and only high-end mobile phones support them. Also we must hope that the hardware manufacturer can be trusted. As you will recall, the hotel owner had immediate access to all of its vaults!

So far, so good. But that’s as far as the FIDO specification takes us – it’s only concerned with the front door. Meanwhile, what about the back door? Consider again the smash-and-grab raid on the server which claims the credentials database. You may be reassured by the fact that “only” public keys are stored there, but that would be a false sense of security. For example, these keys are not protected from a simple substitution attack, where the attacker installs his own public keys enabling him to take control of the system. Worryingly, how or if these keys are protected falls outside of the FIDO specification, although they do offer some advice - See https://fidoalliance.org/white-paper-fido-and-pki-integration-in-the-enterprise/.

MIRACL Trust® works very differently, based as it is on the newer technology of pairing-based cryptography. A major innovation is to separate out the enrolment process from the server function. Another innovation is the flexible form of the secrets which make it easy to divide them into many parts - parts as small as a 4-digit PIN number - and to recombine them.

When enrolling, clients are issued with individualised keys from a Distributed Trust Authority (DTA). Different pieces of the key are issued by each individual TA, and there will be at least two of them. The individual parts are then combined by the client to form their full secret. An attacker who wishes to capture this secret is faced with the problem of intercepting two communications.

Having constructed its full secret, the client then extracts a PIN component from it, creating the two factors needed to authenticate. The part remaining after PIN extraction is called the client token. An attacker would need to know both, as one is useless without the other. The token could be kept in secure storage if such were available, but it is not necessary in order to achieve true two factor authentication.

At the moment of authentication, the two parts are brought together to reconstitute the full secret, and a Zero-Knowledge proof deployed to convince the server of the legitimacy of the client.

On the server side, at the time of server establishment, the DTAs combine to issue the server with a single short verifier (stored in memory), which can be used to verify all of the individual clients. This has an important implication – there is no credential database file! The smash-and-grab attacker cannot succeed as there is nothing there.

The Achilles heel of all of MIRACL’s competitors such as FIDO is the credentials database. This represents a single point of failure which time and time again has proven to be impossible to defend. With M-PIN – as used in MIRACL Trust - we have removed it, and secured all of the doors and windows, not just the obvious front door.

A full white paper on FIDO will be published by Dr Michael Scott later this week and will delve deeper into the topics already discussed in this latest series of blogs. For more information on MIRACL Trust visit MIRACL.


Dr Michael Scott is Chief Crypto Officer at MIRACL, one of the pioneers of Pairing-based Cryptography and the “S” in the widely used BLS and KSS families of elliptic curves. Following a distinguished career of almost 30 years at Dublin City University and an active consultant to both public and private sector, his unmatched depth in knowledge is drawn not only from his academic expertise - he’s published over 100 highly cited papers – but his genuine love of cryptography and the science behind this.

Get the MIRACL memo in your inbox

Get in touch to learn more

  • United Kingdom +44
  • Afghanistan +93
  • Aland Islands +358
  • Albania +355
  • Algeria +213
  • American Samoa +1
  • Andorra +376
  • Angola +244
  • Anguilla +1
  • Antigua and Barbuda +1
  • Argentina +54
  • Armenia +374
  • Aruba +297
  • Ascension Island +247
  • Australia +61
  • Austria +43
  • Azerbaijan +994
  • Bahamas +1
  • Bahrain +973
  • Bangladesh +880
  • Barbados +1
  • Belarus +375
  • Belgium +32
  • Belize +501
  • Benin +229
  • Bermuda +1
  • Bhutan +975
  • Bolivia +591
  • Bosnia and Herzegovina +387
  • Botswana +267
  • Brazil +55
  • British Indian Ocean Territory +246
  • Brunei Darussalam +673
  • Bulgaria +359
  • Burkina Faso +226
  • Burundi +257
  • Cambodia +855
  • Cameroon +237
  • Canada +1
  • Cape Verde +238
  • Caribbean Netherlands +599
  • Cayman Islands +1
  • Central African Republic +236
  • Chad +235
  • Chile +56
  • China +86
  • Christmas Island +61
  • Cocos (Keeling) Islands +61
  • Colombia +57
  • Comoros +269
  • Congo (DRC) +243
  • Congo (Republic) +242
  • Cook Islands +682
  • Costa Rica +506
  • Côte d'Ivoire +225
  • Croatia +385
  • Cuba +53
  • Curaçao +599
  • Cyprus +357
  • Czech Republic +420
  • Denmark +45
  • Djibouti +253
  • Dominica +1
  • Dominican Republic +1
  • Ecuador +593
  • Egypt +20
  • El Salvador +503
  • Equatorial Guinea +240
  • Eritrea +291
  • Estonia +372
  • Ethiopia +251
  • Falkland Islands (Islas Malvinas) +500
  • Faroe Islands +298
  • Fiji +679
  • Finland +358
  • France +33
  • French Guiana +594
  • French Polynesia +689
  • Gabon +241
  • Gambia +220
  • Georgia +995
  • Germany +49
  • Ghana +233
  • Gibraltar +350
  • Greece +30
  • Greenland +299
  • Grenada +1
  • Guadeloupe +590
  • Saint Pierre and Miquelon +508
  • Saint Helena, Ascension and Tristan Da Cunha +290
  • Guam +1
  • Guatemala +502
  • Guernsey +44
  • Guinea +224
  • Guinea-Bissau +245
  • Guyana +592
  • Haiti +509
  • Honduras +504
  • Hong Kong +852
  • Hungary +36
  • Iceland +354
  • India +91
  • Indonesia +62
  • Iran +98
  • Iraq +964
  • Ireland +353
  • Isle of Man +44
  • Israel +972
  • Italy +39
  • Jamaica +1
  • Japan +81
  • Jersey +44
  • Jordan +962
  • Kazakhstan +7
  • Kenya +254
  • Kiribati +686
  • Kuwait +965
  • Kyrgyzstan +996
  • Laos +856
  • Latvia +371
  • Lebanon +961
  • Lesotho +266
  • Liberia +231
  • Libya +218
  • Liechtenstein +423
  • Lithuania +370
  • Luxembourg +352
  • Macao +853
  • Macedonia +389
  • Madagascar +261
  • Malawi +265
  • Malaysia +60
  • Maldives +960
  • Mali +223
  • Malta +356
  • Marshall Islands +692
  • Martinique +596
  • Mauritania +222
  • Mauritius +230
  • Mayotte +262
  • Mexico +52
  • Micronesia +691
  • Moldova +373
  • Monaco +377
  • Mongolia +976
  • Montenegro +382
  • Montserrat +1
  • Morocco +212
  • Mozambique +258
  • Myanmar (Burma) +95
  • Namibia +264
  • Nauru +674
  • Nepal +977
  • Netherlands +31
  • New Caledonia +687
  • New Zealand +64
  • Nicaragua +505
  • Niger +227
  • Nigeria +234
  • Niue +683
  • Norfolk Island +672
  • North Korea +850
  • Norway +47
  • Oman +968
  • Pakistan +92
  • Palau +680
  • Palestinian Territory +970
  • Panama +507
  • Papua New Guinea +675
  • Paraguay +595
  • Peru +51
  • Philippines +63
  • Poland +48
  • Portugal +351
  • Puerto Rico +1
  • Qatar +974
  • Réunion +262
  • Saint Barthelemy +590
  • Romania +40
  • Russian Federation +7
  • Rwanda +250
  • Saint Kitts and Nevis +1
  • Saint Lucia +1
  • Saint Martin (Saint-Martin +590
  • Saint Vincent and the Grenadines +1
  • Samoa +685
  • San Marino +378
  • São Tomé and Príncipe +239
  • Saudi Arabia +966
  • Senegal +221
  • Serbia +381
  • Seychelles +248
  • Sierra Leone +232
  • Singapore +65
  • Slovakia +421
  • Slovenia +386
  • Solomon Islands +677
  • Somalia +252
  • South Africa +27
  • South Korea +82
  • South Sudan +211
  • Spain +34
  • Sri Lanka +94
  • Sudan +249
  • Suriname +597
  • Swaziland +268
  • Sweden +46
  • Switzerland +41
  • Syrian Arab Republic +963
  • Taiwan, Province of China +886
  • Tajikistan +992
  • Tanzania +255
  • Thailand +66
  • Timor-Leste +670
  • Togo +228
  • Tokelau +690
  • Tonga +676
  • Trinidad and Tobago +1
  • Tristan da Cunha +290
  • Tunisia +216
  • Turkey +90
  • Turkmenistan +993
  • Turks and Caicos Islands +1
  • Tuvalu +688
  • Uganda +256
  • Ukraine +380
  • United Arab Emirates +971
  • United Kingdom +44
  • United States +1
  • Uruguay +598
  • Uzbekistan +998
  • Vanuatu +678
  • Vatican City +379
  • Venezuela +58
  • Viet Nam +84
  • Virgin Islands (British) +1
  • Virgin Islands (U.S.) +1
  • Wallis and Futuna +681
  • Western Sahara +212
  • Yemen +967
  • Zambia +260
  • Zimbabwe +263
You can opt out at any time. See our privacy policy here.