passkey
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
passkey [2024.03.10 19:55] – [Using passwords] Steve Isenberg | passkey [2024.03.13 05:47] (current) – Steve Isenberg | ||
---|---|---|---|
Line 1: | Line 1: | ||
~~NOCACHE~~ <fc # | ~~NOCACHE~~ <fc # | ||
visits {{counter|today| time| times}} today, {{counter|yesterday| time| times}} yesterday, and {{counter|total| time total| total times}}]</ | visits {{counter|today| time| times}} today, {{counter|yesterday| time| times}} yesterday, and {{counter|total| time total| total times}}]</ | ||
- | |||
- | Presentation can be include [[https:// | ||
Line 11: | Line 9: | ||
[[https:// | [[https:// | ||
- | ====Using passwords==== | + | The following digested from [[https:// |
- | - Sign up with a website, eg, buystuff.com | + | |
- | - Buystuff accepts | + | ===Passwords - shared secret=== |
- | - You need to remember this password, using a password manager | + | - When you create an account, you choose a password, a '' |
- | - When you log in, you need to send the password to buystuff.com | + | - The website uses a math algorithm to encrypt/ |
- | - Buystuff makes sure you entered | + | - When you login, you send the password |
+ | - The website uses the same math to encrypt/ | ||
+ | - If the two hashes match then you're in | ||
+ | |||
+ | ===Passwords: | ||
+ | * Passwords can be guessed | ||
+ | * Passwords can be seen in transit | ||
+ | * Passwords | ||
+ | * Some websites may save the password and not the hash (and passwords are compromised in a breech) | ||
+ | * Best to use a password manager | ||
+ | |||
+ | ===Passcodes - use public key cryptology=== | ||
+ | * Each passkey is a pair of keys: a public key and a private key | ||
+ | * These are mathematically linked together | ||
+ | * Public key is given to and stored by the website when you sign up with the website(and | ||
+ | | ||
+ | |||
+ | Public info: your public key and the algorithm used (e.g., 3DES, AES, RSA)\\ | ||
+ | f( f(number, public key) , private key) = number\\ | ||
+ | [[https:// | ||
+ | |||
+ | ===Signing in using Passcodes=== | ||
+ | - Your device asks website to log you in | ||
+ | - Website encrypts some arbitrary number (a '' | ||
+ | - Your device uses your private key to decrypt this and sends back the decrypted number | ||
+ | - The website verifies that what you sent in #3 matches | ||
+ | - If there' | ||
- | ====Using passkeys==== | + | ===Passcodes: What does this mean=== |
- | | + | |
- | | + | |
- | - Your password manager creates a public | + | |
- | | + | * You can have many public-private key pairs (I haven' |
- | | + | |
- | | + | (Argument: passkeys can be guessed. Yes, you can guess a 1024-bit or ~300 digit number given enough time and computing resources. |
- | - Only you can decrypt the message as only you have the private key | + | |
- | | + | |
- | - The website goodstuff.com receives | + | |
- | A lot of this happens behind the scenes. | + | |
===1. Passkey Example=== | ===1. Passkey Example=== | ||
- | Let's try a simple public/ | + | Let's try a simple public/ |
- | * Pick a public | + | * Pick a Public |
- | * Remember, everyone can know the public | + | * Remember, everyone can know the Public |
* Suppose message is 246 | * Suppose message is 246 | ||
- | * Add public | + | * Add Public |
* 2+'' | * 2+'' | ||
* 4+'' | * 4+'' | ||
* 6+'' | * 6+'' | ||
* Thus the encrypted message is 595, they send this to you | * Thus the encrypted message is 595, they send this to you | ||
- | * Anyone monitoring the communication only sees 595 and even though they know your public | + | * Anyone monitoring the communication only sees 595 and even though they know your Public |
- | * You receive the message 595 and decrypt it using your private | + | * You receive the message 595 and decrypt it using your Private |
* 5+'' | * 5+'' | ||
* 9+'' | * 9+'' | ||
Line 47: | Line 68: | ||
* and you have decrypted the message and see 246. | * and you have decrypted the message and see 246. | ||
- | Note this is a simple example. In real life a much larger | + | Note this is a simple example. In real life a much larger |
===2. Live Demonstration=== | ===2. Live Demonstration=== | ||
- | ==2a. Using existing passkey== | + | ==2a. Setting up== |
- | On smi's Muscat, log into Shopify.com using BitWarden | + | We'll assume that you have set up your environment, |
+ | - install Bitwarden, | ||
+ | - create Bitwarden account, | ||
+ | - log into Bitwarden, | ||
+ | - install Bitwarden extension to Firefox. | ||
+ | //Note that Bitwarden has OS requirements and that we are using the free version// | ||
+ | |||
+ | ==2b. Login using an existing passkey== | ||
+ | On smi's Muscat | ||
+ | On smi's Muscat using Firefox, log into Nintendo.com using Bitwarden. | ||
+ | |||
+ | //note that I've only added the BitWarden extension to Firefox on Muscat.// | ||
==2b. Creating passkey== | ==2b. Creating passkey== | ||
+ | < | ||
This from video [[https:// | This from video [[https:// | ||
- | - Set up environment once((1: | + | |
- Go to Shopify.com | - Go to Shopify.com | ||
- Create account with password. Save to Bitwarden. | - Create account with password. Save to Bitwarden. | ||
Line 65: | Line 98: | ||
- Log out, log in. Select the icon where userID is entered, select Shopify. | - Log out, log in. Select the icon where userID is entered, select Shopify. | ||
- You're logged in. | - You're logged in. | ||
+ | </ | ||
+ | |||
+ | At Nintendo | ||
+ | - In BitWarden, create login for Nintendo(name, | ||
+ | - Go to nintendo.com (the website) | ||
+ | - Sign-up | ||
+ | - Select the login info f/BitWarden | ||
+ | - Get verification email w/code, enter 4-digit code on Nintendo | ||
+ | - Log out, log in using new acct | ||
+ | - Account settings > Sign-in and security settings | ||
+ | - Scroll to Passkey, Edit | ||
+ | - Register a New Passkey | ||
+ | - Follow verification process: Submit to start it | ||
+ | - Enter 6-digit code | ||
+ | - Register | ||
+ | - BitWarden: select the login you just created to save the passkey | ||
+ | |||
+ | Let's try it | ||
+ | - Sign out | ||
+ | - Sign in '' | ||
+ | - BitWarden: select the login you just created to use its saved passkey | ||
+ | You're in. | ||
- | <hidden initialState=" | + | <hidden initialState=" |
this should be hidden | this should be hidden | ||
<fs large> | <fs large> | ||
Line 90: | Line 145: | ||
Let's say the website encrypts the string " | Let's say the website encrypts the string " | ||
- | | + | The website does: |
+ | | ||
- Using the public key (5, 221), the website computes | - Using the public key (5, 221), the website computes | ||
* H = 8^5 mod 221 = 32768 mod 221 = 119 | * H = 8^5 mod 221 = 32768 mod 221 = 119 | ||
* E = 5^5 mod 221 = 3125 mod 221 = 197 | * E = 5^5 mod 221 = 3125 mod 221 = 197 | ||
+ | * L = 12^5 mod 221 = 248831 mod 221 = 35 | ||
* L = 12^5 mod 221 = 248831 mod 221 = 35 | * L = 12^5 mod 221 = 248831 mod 221 = 35 | ||
* O = 15^5 mod 221 = 759375 mod 221 = 65 | * O = 15^5 mod 221 = 759375 mod 221 = 65 | ||
Line 105: | Line 162: | ||
* 119^77 mod 221 = 8 which is 8th letter or H | * 119^77 mod 221 = 8 which is 8th letter or H | ||
* 197^77 mod 221 = 5 which is 5th letter or E | * 197^77 mod 221 = 5 which is 5th letter or E | ||
+ | * 35^77 mod 221 = 12 which is 12th letter or L | ||
* 35^77 mod 221 = 12 which is 12th letter or L | * 35^77 mod 221 = 12 which is 12th letter or L | ||
* 65^77 mod 221 = 15 which is 15th letter or O | * 65^77 mod 221 = 15 which is 15th letter or O | ||
+ | We have decrypted the message to the string HELLO. | ||
We then send the plaintext HELLO back to the website. | We then send the plaintext HELLO back to the website. | ||
Line 118: | Line 177: | ||
^App ^Passkeys | ^App ^Passkeys | ||
- | |Bitwarden|Browser only|Free: 2 users, 2 collections, | + | |Bitwarden|Browser only|Free: 2 users, 2 collections, |
|1Password|on Android | |1Password|on Android | ||
|Dashlane |yes, mobile only |Free: 1 device at a time, 25 passwords. Paid=" | |Dashlane |yes, mobile only |Free: 1 device at a time, 25 passwords. Paid=" | ||
- | |KeepassXC|browser | + | |KeepassXC|using browser |
|Apple|requires iOS & iPadOS 16, MacOS 13 or later.|No charge. [[https:// | |Apple|requires iOS & iPadOS 16, MacOS 13 or later.|No charge. [[https:// | ||
|Google|yes | |Google|yes | ||
- | |||
- | [[https:// | ||
- | NR4PT: Not ready for prime time (my opinion) | ||
Line 134: | Line 190: | ||
* [[https:// | * [[https:// | ||
* [[https:// | * [[https:// | ||
+ | * [[https:// | ||
+ | * [[https:// |
passkey.1710125747.txt.gz · Last modified: 2024.03.10 19:55 by Steve Isenberg