Join devRant
Do all the things like
				++ or -- rants, post your own rants, comment on others' rants and build your customized dev avatar
				Sign Up
			Pipeless API
 
				From the creators of devRant, Pipeless lets you power real-time personalized recommendations and activity feeds using a simple API
				Learn More
			Search - "public and private key"
		- 
				    					
					
					This facts are killing me
 
 "During his own Google interview, Jeff Dean was asked the implications if P=NP were true. He said, "P = 0 or N = 1." Then, before the interviewer had even finished laughing, Jeff examined Google’s public certificate and wrote the private key on the whiteboard."
 
 "Compilers don't warn Jeff Dean. Jeff Dean warns compilers."
 
 "gcc -O4 emails your code to Jeff Dean for a rewrite."
 
 "When Jeff Dean sends an ethernet frame there are no collisions because the competing frames retreat back up into the buffer memory on their source nic."
 
 "When Jeff Dean has an ergonomic evaluation, it is for the protection of his keyboard."
 
 "When Jeff Dean designs software, he first codes the binary and then writes the source as documentation."
 
 "When Jeff has trouble sleeping, he Mapreduces sheep."
 
 "When Jeff Dean listens to mp3s, he just cats them to /dev/dsp and does the decoding in his head."
 
 "Google search went down for a few hours in 2002, and Jeff Dean started handling queries by hand. Search Quality doubled."
 
 "One day Jeff Dean grabbed his Etch-a-Sketch instead of his laptop on his way out the door. On his way back home to get his real laptop, he programmed the Etch-a-Sketch to play Tetris."
 
 "Jeff Dean once shifted a bit so hard, it ended up on another computer. "6
- 
				    					
					
					Wow... this is the perfect week for this topic.
 
 Thursday, is the most fucked off I’ve ever been at work.
 
 I’ll preface this story by saying that I won’t name names in the public domain to avoid anyone having something to use against me in court. But, I’m all for the freedom of information so please DM if you want to know who I’m talking about.
 
 Yesterday I handed in my resignation, to the company that looked after me for my first 5 years out of university.
 
 Thursday was my breaking point but to understand why I resigned you need a little back story.
 
 I’m a developer for a corporate in a team of 10 or so.
 
 The company that I work for is systemically incompetent and have shown me this without fail over the last 6 months.
 
 For the last year we’ve had a brilliant contracted, AWS Certified developer who writes clean as hell hybrid mobile apps in Ion3, node, couch and a tonne of other up to the minute technologies. Shout out to Morpheus you legend, I know you’re here.
 
 At its core my job as a developer is to develop and get a product into the end users hands.
 
 Morpheus was taking some shit, and coming back to his desk angry as fuck over the last few months... as one of the more experienced devs and someone who gives a fuck I asked him what was up.
 
 He told me, company want their mobile app that he’s developed on internal infrastructure... and that that wasn’t going to work.
 
 Que a week of me validating his opinion, looking through his work and bringing myself up to speed.
 
 I came to the conclusion that he’d done exactly what he was asked to, brilliant Work, clean code, great consideration to performance and UX in his design. He did really well. Crucially, the infrastructure proposed was self-contradicting, it wouldn’t work and if they tried to fudge it in it would barely fucking run.
 
 So I told everyone I had the same opinion as him.
 
 4 months of fucking arguing with internal PMs, managers and the project team go by... me and morpheus are told we’re not on the project.
 
 The breaking point for me came last Wednesday, given no knowledge of the tech, some project fannies said Morpheus should be removed and his contract terminated.
 
 I was up in fucking arms. He’d done everything really well, to see a fellow developer take shit for doing his job better than anyone else in [company] could was soul destroying.
 
 That was the straw on the camels back. We don’t come to work to take shit for doing a good job. We don’t allow our superiors to give people shit in our team when they’re doing nothing but a good job. And you know what: the opinion of the person that knows what they’re talking about is worth 10 times that of the fools who don’t.
 
 My manager told me to hold off, the person supposed to be supporting us told me to stand down. I told him I was going to get the app to the business lead because he fucking loves it and can tell us if there’s anything to change whilst architecture sorts out their outdated fucking ideas.
 
 Stand down James. Do nothing. Don’t do your job. Don’t back Morpheus with his skills and abilities well beyond any of ours. Do nothing.
 
 That was the deciding point for me, I said if Morpheus goes... I go... but then they continued their nonsense, so I’m going anyway.
 
 I made the decision Thursday, and Friday had recruiters chomping at the bit to put the proper “senior” back in my title, and pay me what I’m worth.
 
 The other issues that caused me to see this company in it’s true form:
 - I raised a key security issue, documented it, and passed it over to the security team.
 - they understood, and told the business users “we cannot use ArcGIS’ mobile apps, they don’t even pretend to be secure”
 - the business users are still using the apps going into the GDPR because they don’t understand the ramifications of the decisions they’re making.
 
 I noticed recently that [company] is completely unable to finish a project to time or budget... and that it’s always the developers put to blame.
 
 I also noticed that middle management is in a constant state of flux with reorganisations because in truth the upper managers know they need to sack them.
 
 For me though, it was that developers in [company], the people that know what they’re talking about; are never listened to.
 
 Fuck being resigned to doing a shit job.
 
 Fuck this company. On to one that can do it right.
 
 Morpheus you beautiful bastard I know you’ll be off soon too but I also feel I’ve made a friend for life. “Private cloud” my arse.
 
 Since making the decision Thursday I feel a lot more free, I have open job offers at places that do this well. I have a position of power in the company to demand what I need and get it. And I have the CEO and CTO’s ears perking up because their department is absolutely shocking.
 
 Freedom is a wonderful feeling.13
- 
				    					
					
					I was working as a contractor for a client who just got enough funding to hire a full-time dev. I lovingly referred to him as "Mr. Koolaid" because he was obsessed with whatever the newest hotness was and cried constantly about how the 3-year-old code-base didn't use The Next Big Thing(tm). This was my first interaction with him:
 
 Mr. Koolaid: I'd like access to the github repository. My username is xxxx.
 
 Me: We currently aren't hosting the code on github. If you send me your public ssh key, I'll get you access to the private server.
 
 Mr. Koolaid: I'd like to access the github repository.
 
 Me: It's not on github; send me your public key and I'll get you access.
 
 Mr. Koolaid: Can we skype real quick? You don't need my public key to grant me access to the github repo.
 
 *Mr. Koolaid proceeds to forward me github's documentation on adding users to an organization and the documentation for adding users to a private repo. The email is written in a very passive-aggressive tone.*
 
 ಠ_ಠ9
- 
				    					
					
					Why nobody uses public/private key authentication for ssh and disable password auth?
 
 Am I the only one around here doing this?14
- 
				    					
					
					The solution for this one isn't nearly as amusing as the journey.
 
 I was working for one of the largest retailers in NA as an architect. Said retailer had over a thousand big box stores, IT maintenance budget of $200M/year. The kind of place that just reeks of waste and mismanagement at every level.
 
 They had installed a system to distribute training and instructional videos to every store, as well as recorded daily broadcasts to all store employees as a way of reducing management time spend with employees in the morning. This system had cost a cool 400M USD, not including labor and upgrades for round 1. Round 2 was another 100M to add a storage buffer to each store because they'd failed to account for the fact that their internet connections at the store and the outbound pipe from the DC wasn't capable of running the public facing e-commerce and streaming all the video data to every store in realtime. Typical massive enterprise clusterfuck.
 
 Then security gets involved. Each device at stores had a different address on a private megawan. The stores didn't generally phone home, home phoned them as an access control measure; stores calling the DC was verboten. This presented an obvious problem for the video system because it needed to pull updates.
 
 The brilliant Infosys resources had a bright idea to solve this problem:
 
 - Treat each device IP as an access key for that device (avg 15 per store per store).
 - Verify the request ip, then issue a redirect with ANOTHER ip unique to that device that the firewall would ingress only to the video subnet
 - Do it all with the F5
 
 A few months later, the networking team comes back and announces that after months of work and 10s of people years they can't implement the solution because iRules have a size limit and they would need more than 60,000 lines or 15,000 rules to implement it. Sad trombones all around.
 
 Then, a wild DBA appears, steps up to the plate and says he can solve the problem with the power of ORACLE! Few months later he comes back with some absolutely batshit solution that stored the individual octets of an IPV4, multiple nested queries to the same table to emulate subnet masking through some temp table spanning voodoo. Time to complete: 2-4 minutes per request. He too eventually gives up the fight, sort of, in that backhanded way DBAs tend to do everything. I wish I would have paid more attention to that abortion because the rationale and its mechanics were just staggeringly rube goldberg and should have been documented for posterity.
 
 So I catch wind of this sitting in a CAB meeting. I hear them talking about how there's "no way to solve this problem, it's too complex, we're going to need a lot more databases to handle this." I tune in and gather all it really needs to do, since the ingress firewall is handling the origin IP checks, is convert the request IP to video ingress IP, 302 and call it a day.
 
 While they're all grandstanding and pontificating, I fire up visual studio and:
 
 - write a method that encodes the incoming request IP into a single uint32
 - write an http module that keeps an in-memory dictionary of uint32,string for the request, response, converts the request ip and 302s the call with blackhole support
 - convert all the mappings in the spreadsheet attached to the meetings into a csv, dump to disk
 - write a wpf application to allow for easily managing the IP database in the short term
 - deploy the solution one of our stage boxes
 - add a TODO to eventually move this to a database
 
 All this took about 5 minutes. I interrupt their conversation to ask them to retarget their test to the port I exposed on the stage box. Then watch them stare in stunned silence as the crow grows cold.
 
 According to a friend who still works there, that code is still running in production on a single node to this day. And still running on the same static file database.
 
 #TheValueOfEngineers2
- 
				    					
					
					I love how the Keybase Linux client installs itself straight into /keybase. Unix directory structure guidelines? Oh no, those don't apply to us. And after uninstalling the application they don't even remove the directory. Leaving dirt and not even having the courtesy to clean it up. Their engineers sure are one of a kind.
 
 Also, remember that EFAIL case? I received an email from them at the time, stating some stuff that was about as consistent as their respect for Unix directory structure guidelines. Overtyping straight from said email here:
 
 […] and our filesystem all do not use PGP.
 > whatever that means.
 
 The only time you'll ever use PGP encryption in Keybase is when you're sitting there thinking "Oh, I really want to use legacy PGP encryption."
 > Legacy encryption.. yeah right. Just as legacy as Vim is, isn't it?
 
 You have PGP as part of your cryptographic identity.
 > OH REALLY?! NO SHIT!!! I ACTIVELY USED 3 OS'S AND FAILED ON 2 BECAUSE OF YOUR SHITTY CLIENT, JUST TO UPLOAD MY FUCKING PUBLIC KEY!!!
 
 You'll want to remove your PGP key from your Keybase identity.
 > Hmm, yeah you might want to do so. Not because EFAIL or anything, just because Keybase clearly is a total failure on all levels.
 
 Written quickly,
 the Keybase team
 > Well that's fucking clear. Could've taken some time to think before hitting "Send" though.
 
 Don't get me wrong, I love the initiatives like this with all my heart, and greatly encourage secure messaging that leverages PGP. But when the implementation sucks this much, I start to ask myself questions about whether I should really trust this thing with my private conversations. Luckily I refrained from uploading my private key to their servers, otherwise I would've been really fucked.
- 
				    					
					
					Sent another developer instructions for generating an SSH key pair and to send me the public key. He did so. There was a problem getting it to work. So, naturally, he emailed me the private key.1
- 
				    					
					
					*me calculating rsa*
 "aight.. Public key is 9 and n"
 *calculating private key*
 *recalculating cause I fucked up*
 *recalculating cause I'm retarded*
 *3rd recalculation*
 "ok, I figured out my private key is 9 (and n)"
 
 .... Wait a second.1
- 
				    					
					
					I haven't ranted for today, but I figured that I'd post a summary.
 A public diary of sorts.. devRant is amazing, it even allows me to post the stuff that I'd otherwise put on a piece of paper and probably discard over time. And with keyboard support at that <3
 
 Today has been a productive day for me. Laptop got restored with a "pacman -Syu" over a Bluetooth mobile data tethering from my phone, said phone got upgraded to an unofficial Android 9 (Pie) thanks to a comment from @undef, etc.
 
 I've also made myself a reliable USB extension cord to be able to extend the 20-30cm USB-A male to USB-C male cord that Huawei delivered with my Nexus 6P. The USB-C to USB-C cord that allows for fast charging is unreliable.. ordered some USB-C plugs for that, in order to make some high power wire with that when they arrive.
 
 So that plug I've made.. USB-A male to USB-A female, in which my short USB-C to USB-A wire can plug in. It's a 1M wire, with 18AWG wire for its power lines and 28AWG wires for its data lines. The 18AWG power lines can carry up to 10A of current, while the 28AWG lines can carry up to 1A. All wires were made into 1M pieces. These resulted in a very low impedance path for all of them, my multimeter measured no more than 200 milliohms across them, though I'll have to verify and finetune that on my oscilloscope with 4-wire measurement.
 
 So the wire was good. Easy too, I just had to look up the pinout and replicate that on the male part.
 
 That's where the rant part comes in.. in fact I've got quite uncomfortable with sentences that don't include at least one swear word at this point. All hail to devRant for allowing me to put them out there without guilt.. it changed my very mind <3
 
 Microshaft WanBLowS.
 
 I've tried to plug my DIY extension cord into it, and plugged my phone and some USB stick into it of which I've completely forgot the filesystem. Windows certainly doesn't support it.. turns out that it was LUKS. More about that later.
 
 Windows returned that it didn't support either of them, due to "malfunctioning at the USB device". So I went ahead and plugged in my phone directly.. works without a problem. Then I went ahead and troubleshooted the wire I've just made with a multimeter, to check for shorts.. none at all.
 
 At that point I suspected that WanBLowS was the issue, so I booted up my (at the time) problematic Arch laptop and did the exact same thing there, testing that USB stick and my phone there by plugging it through the extension wire. Shit just worked like that. The USB stick was a LUKS medium and apparently a clone of my SanDisk rootfs that I'm storing my Arch Linux on my laptop at at the time.. an unfinished migration project (SanDisk is unstable, my other DM sticks are quite stable). The USB stick consumed about 20mA so no big deal for any USB controller. The phone consumed about 500mA (which is standard USB 2.0 so no surprise) and worked fine as well.. although the HP laptop dropped the voltage to ~4.8V like that, unlike 5.1V which is nominal for USB. Still worked without a problem.
 
 So clearly Windows is the problem here, and this provides me one more reason to hate that piece of shit OS. Windows lovers may say that it's an issue with my particular hardware, which maybe it is. I've done the Windows plugging solely through a USB 3.0 hub, which was plugged into a USB 3.0 port on the host. Now USB 3.0 is supposed to be able to carry up to 1A rather than 500mA, so I expect all the components in there to be beefier. I've also tested the hub as part of a review, and it can carry about 1A no problem, although it seems like its supply lines aren't shorted to VCC on the host, like a sensible hub would. Instead I suspect that it's going through the hub's controller.
 
 Regardless, this is clearly a bad design. One of the USB data lines is biased to ~3.3V if memory serves me right, while the other is biased to 300mV. The latter could impose a problem.. but again, the current path was of a very low impedance of 200milliohms at most. Meanwhile the direct connection that omits the ~200ohm extension wire worked just fine. Even 300mV wouldn't degrade significantly over such a resistance. So this is most likely a Windows problem.
 
 That aside, the extension cord works fine in Linux. So I've used that as a charging connection while upgrading my Arch laptop (which as you may know has internet issues at the time) over Bluetooth, through a shared BNEP connection (Bluetooth tethering) from my phone. Mobile data since I didn't set up my WiFi in this new Pie ROM yet. Worked fine, fixed my WiFi. Currently it's back in my network as my fully-fledged development host. So that way I'll be able to work again on @Floydian's LinkHub repository. My laptop's the only one who currently holds the private key for signing commits for git$(rm -rf ~/*)@nixmagic.com, hence why my development has been impeded. My tablet doesn't have them. Guess I'll commit somewhere tomorrow.
 
 (looks like my rant is too long, continue in comments)3
- 
				    					
					
					Since we are using the same password on all our servers (both QA and Production environment) my team somehow decided that it would be easier to copy the private SSH key for to ALL servers and add the public key to the authorized.keys file.
 
 This way we SSH without password and easily add it to new servers, it also means that anyone who gets into one server can get to all of them.
 
 I wasn't a fan of the same password on all servers, but this private key copying is just going against basic security principles.
 
 Do they want rogue connections? Because that's how you get them.1
- 
				    					
					
					When I think "the fundamental problem", the closest thing that comes to my mind is "unsolvable problem". P =/!= NP is a fundamental problem, the theory of everything is a fundamental problem.
 
 But we actually solved at least one such problem – the fundamental problem of cryptography.
 
 The problem was "how to establish a secure connection over a non-secure channel?" Like you can't exchange the key, it'll be exposed by definition.
 
 We solved it with a simple yet brilliant solution of asymmetrical cypher, that thing with public and private keys.
 
 It's fascinating to think that people died in WW2 over this, there were special operations to deliver fresh deciphering keys securely and now SSH and HTTPS are no-brainers that literally everyone use.10
- 
				    					
					
					Having gone to a bank to reset a password again today (Yes, I forgot it for like... 3rd time, don't judge me, its my backup bank account I need to access like... once a year), I was once again made to think - I come in, give them my state ID by which they authorize that I can even make a password reset request.
 
 Then they give me a tablet to... sign a contract addendum?
 
 Its not the contract part that always makes me stop and think though - its the "sign" part.
 
 I'd wager that I am not the only one who only ever uses a computer to write text these days. So... My handwriting got a lot jerkier, less dependable. Soooo... My signature can be wildly different each time.......
 
 And if my signature varies a lot... then... what is the point of having it on a piece of paper?
 
 I know its just a legal measure of some sort... And that, if it came down to someone impersonating me and I'd go to court with the bank, there would be specialists who can tell if a signature was forged or not... But...
 
 Come on, the computer world has so much more reliable, uncrackable, unforgable solutions already... Why... Don't all folks of the modern world already have some sort of... state-assigned private/public keypairs that could be used to sign official documents instead?
 
 It costs money, takes time to develop etc... But... Then, there would not only be no need to sign papers anymore... And it would be incredibly hard to forge.
 
 The key could even be encrypted, so the person wishing to sign something would have to know a PIN code or a password or something...
 
 tl;dr: I hate physical signatures as a method of authentication / authorization. I wish the modern world would use PKI cryptography instead...11
- 
				    					
					
					fuck.. FUCK FUCK FUCK!!!
 I'mma fakin EXPLODE!
 
 It was supposed to be a week, maybe two weeks long gig MAX. Now I'm on my 3rd (or 4th) week and still got plenty on my plate. I'm freaking STRESSED. Yelling at people for no reason, just because they interrupt my train of thought, raise a hand, walk by, breathe, stay quiet or simply are.
 
 FUCK!
 
 Pressure from all the fronts, and no time to rest. Sleeping 3-5 hours, falling asleep with this nonsense and breaking the day with it too.
 
 And now I'm fucking FINALLY CLOSE, I can see the light at the end of the tunne<<<<<TTTOOOOOOOOOOOOOTTTTT>>>>>>>
 
 All that was left was to finish up configuring a firewall and set up alerting. I got storage sorted out, customized a CSI provider to make it work across the cluster, raised, idk, a gazillion issues in GH in various repositories I depend on, practically debugged their issues and reported them.
 
 Today I'm on firewall. Liason with the client is pressured by the client bcz I'm already overdue. He propagates that pressure on to me. I have work. I have family, I have this side gig. I have people nagging me to rest. I have other commitments (you know.. eating (I practically finish my meal in under 3 minutes; incl. the 2min in the µ-wave), shitting (I plan it ahead so I could google issues on my phone while there), etc.)
 
 A fucking firewall was left... I configured it as it should be, and... the cluster stopped...clustering. inter-node comms stopped. `lsof` shows that for some reason nodes are accessing LAN IPs through their WAN NIC (go figure!!!) -- that's why they don't work!!
 
 Sooo.. my colleagues suggest me to make it faster/quicker and more secure -- disable public IPs and use a private LB. I spent this whole day trying to implement it. I set up bastion hosts, managed to hack private SSH key into them upon setup, FINALLY managed to make ssh work and the user_data script to trigger, only to find out that...
 
 ~]# ping 1.1.1.1
 ping: connect: Network is unreachable
 ~]#
 
 ... there's no nat.
 THERE"S NO FUCKING NAT!!!
 
 HOW CAN THERE BE NO NAT!?!?!????? MY HOME LAPTOP HAS A NAT, MY PHONE HAS A NAT, EVEN MY CAT HAS A MOTHER HUGGING NAT, AND THIS FUCKING INFRA HAS NO FUCKING NAT???????????????????????
 
 ALready under loads of pressure, and the whole day is wasted. And now I'll be spending time to fucking UNDO everything I did today. Not try something new. But UNDO. And hour or more for just that...
 
 I don't usually drink, but recently that bottom shelf bottle of Captain Morgan that smells and tastes like a bottle of medical spirit starts to feel very tempting.
 
 Soo.. how's your dayrant overdue tired no nat hcloud why there's no nat???? fuck frustrated waiting for concrete to settle angry hetzner need an outlet2
- 
				    					
					
					#justAthought
 
 I was reading about public and private keys yesterday, and i had a thought: don't you think the concept of "username" is being so badly misused?
 
 It can act as a great firewall, but we are just misusing it as an alternative to "login via email", because we are now so dumb to remember our email.
 You might think of my rant as being going back in time, but think about this: my profile shows the name titanlannister. if someone got access to my password, he/she can immediately take over my complete identity because devrant allows us to login via username/password combo.
 
 Now think of this: my username shows titanlannister. Anyone of you can write a post and mention me via @titanlannister, and this system will notify me. However even if you get my password, you are unable to hack into my profile, because my profile is only accessible via my email id/password combo, which you still don't know.
 
 This, I would call as Platform Public Key which adds a kind of semi firewall over default public/private key combination .
 
 What do you think?5
- 
				    					
					
					The only way I can edit Puppet config files is by git. And the only way I can git pull/push/commit/etc is generating a ssh key with a private key and give my public key to my supervisor to the git server (wherever that may be).
 
 Because I'm on Windows 10 and screwed up my installers, I completely forgot to backup my ssh keys before resetting it. FML2
- 
				    					
					
					I've created instructions for myself the next time I encounter cpanel.
 
 rallen@rallen ~ $ cheat cpanel
 #SSH'ing into the fucking cpanel
 #Figure out combination of 5 usernames and passwords given by client to log in.
 #Pray that WHM isn't involved.
 #Ignore several ssl warnings and cancel several .htaccess password prompts.
 #Call in to enable that shit.
 #Wait no less than 15 minutes on hold.
 #SSH enabled.
 #Create public private key pair.
 #Notice the ppk conversion for windows 'devs'. Sigh.
 #Copy key pair to ~/.ssh/
 #chmod that shit to 600.
 #Note for the user name it's not anything the clients given you or what you've named the key. Look in the cpanel for the /home/<user> directory.
 ssh -i ~/.ssh/key <user>@<dedicatedip>
- 
				    					
					
					I've been working for so long with API integrations and one part of that is security. We perform ssl key exchanges for 2-way verification and a large percent of those partners provides me with their own pkcs12 file which contains their private and public keys! What's the sense of the exchange!? I think they just implement it just to boast that they "know" how ssl works,
- 
				    					
					
					Q.14 - Suppose that R sends a msg 'm' which is digitally signed to M and the pair of private and public keys for M and R be denoted as K(x)- and K(x)+ for x=R,M respectively. Let K(x)(m) represent the encryption of 'm' with a key K(x) and H(m) is the message digest. Which of the following is the way of sending the msg 'm' along with the digital signature to M?
 A. [m, K(R)+(H(m))]
 B. [m, K(R)-(H(m))]
 C. [m, K(M)-(H(m))]
 D. [m, K(A)+(m)]
 E. WOW, REALLY ?5
- 
				    					
					
					On page 19 of the ethereum yellow paper: http://gavwood.com/paper.pdf it defines the address of a wallet as: A(pr) = Β[96...255](KEC(ECDSAPUBKEY(Pr))), which is the right most 160-bits of the Keccak hash of the public key generated by the private key.
 
 If I expose the public key to the network, do I allow people to impersonate me and sign transactions even though they don't have Tr, Ts, or Tw? My understanding is no, that without those values you can't hash the transaction.
 
 Subsequently, this leads me to wonder if the purpose of the address (besides identifying users) to obscure the public key so that the private key is at a less risk of being reversed? Or can the public key of any address be captured?
 
 If the public key of any address can be identified on the network or off network (without actually being the owner of that key), how do you do that? Are there any resources on how to perform this that are computationally easy?1
- 
				    					
					
					`load pubkey "/Users/karunamon/.ssh/id_rsa": invalid format`
 
 The fuck? I've been using this keyfile for ages. And that's the private key, not the public key.
 
 Maybe I'll try converting it to a different format.
 
 (20 minutes of ssh-keygen command attempts)
 
 Same error. I don't freaking get it. It works. I mean, I know my public key is..
 
 (public key is actually completely mangled with newlines everywhere)
 
 ..yknow what, my fault, but you could have at least given me the public key filename, ya jerk.1
- 
				    					
					
					Why are USB passkeys so expensive? I was under the impression that you 1) create a key pair, upload the public key to your google account and 2) store the private key on an old USB drive. But nooo, then you could copy the key I guess. Good luck convincing the average Joe to spend more than $10 on a fido/yubi/whatever key...3


















