Developer posts secret key on GitHub, loses $40K in 2 minutes (cointelegraph.com)
from AnActOfCreation@programming.dev to technology@lemmy.world on 07 Jun 2024 15:39
https://programming.dev/post/15186600

#technology

threaded - newest

Xantar@lemmy.dbzer0.com on 07 Jun 2024 16:00 next collapse

That’s the kind of mistake you only make once.

Sabata11792@ani.social on 07 Jun 2024 16:19 next collapse

I wouldn’t survive that mistake.

Xantar@lemmy.dbzer0.com on 07 Jun 2024 17:27 collapse

Well, either you do it once :P

FiniteBanjo@lemmy.today on 09 Jun 2024 03:55 collapse

either way*

FiniteBanjo@lemmy.today on 09 Jun 2024 03:55 collapse

Some speculate that AI assisting him in programming could have made the error, in which case I hope he gets fucked by it again in the future.

dhork@lemmy.world on 07 Jun 2024 16:05 next collapse

I have no sympathy for him, if he is a crypto developer he knows how important those private keys are. And he also knows people scrape public areas all the time looking for keys just like that. The whole point of crypto is to be immutable, so that money is simply lost to him now.

He seems to know how much of a dumb mistake that was, although his description of himself was a bit more colorful.

redcalcium@lemmy.institute on 08 Jun 2024 01:13 next collapse

The whole point of crypto is to be immutable, so that money is simply lost to him now.

IIRC there are several cases where some group of people lost big enough coins and force most of the miners to fork to get their money back. Not bitcoin though.

jol@discuss.tchncs.de on 08 Jun 2024 09:56 next collapse

If that doesn’t make everyone lose 100% trust in coins that do that, I don’t know what will.

jaaaardvark@lemm.ee on 08 Jun 2024 15:20 collapse

Ethereum, en.m.wikipedia.org/wiki/Ethereum_Classic#The_DAO_…

overload@sopuli.xyz on 10 Jun 2024 06:56 collapse

That’s insane that this really happened.

CallMeButtLove@lemmy.world on 08 Jun 2024 13:36 collapse

You’re not wrong about how important those keys are and how he definitely should have known better. But I at least have a little sympathy for the guy. Everyone makes mistakes from time to time, even with important stuff. Hopefully they are lucky enough not to lose 40k on one but unfortunately he wasn’t. Whether he should have known better or not, that just plain sucks.

bear@slrpnk.net on 07 Jun 2024 16:05 next collapse

Incredibly funny story, incredibly awful website.

lowleveldata@programming.dev on 07 Jun 2024 16:08 next collapse

It must be automated for it to happen in 2 minutes. Which implies these kind of things happen often enough for someone to write a script for it.

partial_accumen@lemmy.world on 07 Jun 2024 16:29 next collapse

If it was a script I wrote, it would have successfully stolen the $40k, but also stolen my own money and deposit both sets of money into a second intended victims account because I forgot to clear a variable before the main loop runs again.

bigkahuna1986@lemmy.ml on 07 Jun 2024 17:30 next collapse

You always mess up some mundane detail!

Klear@sh.itjust.works on 08 Jun 2024 09:59 next collapse

Might have happened in this case too, you never know.

acchariya@lemmy.world on 08 Jun 2024 12:00 collapse

It would have deposited the funds in an account “foobar123” and been lost forever

tiramichu@lemm.ee on 07 Jun 2024 16:31 next collapse

Yes, it absolutely is automated.

There are bots running constantly looking for things that match patterns for exploitable credentials in public commits.

AWS credentials

SSH keys

Crypto wallets

Bank card info

If you push secrets to a public github repo, they will be exploited almost immediately.

daddy32@lemmy.world on 07 Jun 2024 22:00 collapse

The scanning part is definitely automated by many different actors (for the gains or the “lulz”), but being this fast, also automated key usage (account draining) must have been implemented which is a bit more impressive…

Voroxpete@sh.itjust.works on 08 Jun 2024 13:06 collapse

Not really. All of the underlying mechanics of crypto are so simple that they can be very easily interacted with by bots. Bots make up the vast majority of all crypto trades; mostly wash trading, but also front-running attacks, scams or outright thefts like this one. There are so many exploitable flaws in crypto that every bug is basically a self-executing bug bounty.

Theharpyeagle@lemmy.world on 07 Jun 2024 22:10 next collapse

Oh yes absolutely, there are bots constantly crawling any open source code. A friend of mine accidentally leaked their discord API key, nuked a whole server within minutes.

nucleative@lemmy.world on 08 Jun 2024 09:32 collapse

There must be bots trolling GitHub for API keys, crypto secret keys, and other such valuable data

Bishma@discuss.tchncs.de on 07 Jun 2024 16:09 next collapse

If there was any sort of password / highly entropic string detection in their build pipeline it would have caught a wallet’s keys. They aren’t an excuse for lack of diligence, but they should still be in every pipeline where passwords or keys might have to get used.

I’m terrible about building pipelines for most of my personal projects though, so I’m throwing rocks from my glass house here.

barsquid@lemmy.world on 07 Jun 2024 17:08 next collapse

I like your CI plan but maybe they just needed some sort of sane policy. Like never commit plaintext keys to any repo. Never work with a $40k key in a new project under development. Never convert a private repo to public.

sugar_in_your_tea@sh.itjust.works on 10 Jun 2024 14:32 collapse

A CI pipeline wouldn’t fix this since the code would be committed before the pipelines run. This needs to be caught on the dev’s machine with a pre-commit or pre-push hook.

darklamer@lemmy.dbzer0.com on 07 Jun 2024 16:50 next collapse

The developer said he forgot that his secret keys were in the repository.

If you have your secret keys in your repository you’ve already fucked up, long before you accidentally make that repository public.

tal@lemmy.today on 07 Jun 2024 17:08 next collapse

Ehhh. I mean, I have local repositories that contain things that I wouldn’t want to share with the world. Using git to manage files isn’t equivalent to wanting to publish publicly on github.

I could imagine ways that private information could leak. Like, okay, say you have some local project, and you’re committing notes in a text file to the project. It’s local, so you don’t need to sanitize it, can put any related information into the notes. Or maybe you have a utility script that does some multi-machine build, has credentials embedded in it. But then over time, you clean the thing up for release and forget that the material is in the git history, and ten years later, do an open-source release or something.

I do kind of think that there’s an argument that someone should make a “lint”-type script to automatically run on GitHub pushes to try and sanity-check and maybe warn about someone pushing out material that maybe they don’t want to be pushing to the world. It’ll never be a 100% solution, but it could maybe catch some portion of leakage.

Bookmeat@lemmy.world on 07 Jun 2024 17:22 next collapse

Users often don’t take care to separate private and public environments. They just dump all their stuff into one and expect their brain to make the correct decision all the time.

Put your private data into a private space. Never put private data into a mixed use space or a public space.

e.g. Don’t use your personal email at work. Don’t use your personal phone for business. Don’t put your passwords or crypto keys in the same github or gitlab account or even instance and don’t reuse passwords and keys, etc.

tal@lemmy.today on 07 Jun 2024 18:27 collapse

Put your private data into a private space. Never put private data into a mixed use space or a public space.

Sure, but nothing I said conflicts with that.

I’m talking about a situation where someone has a private repository, and then one day down the line decide that they want to transition it to a public repository.

You’re not creating the repository with the intention that it is public, nor intending to mix information that should be public and private together.

barsquid@lemmy.world on 08 Jun 2024 04:22 collapse

If you don’t have a policy of never committing private keys to any repo, you should choose a policy of never transitioning any private repo to public. IMO if you don’t choose strict and effective policy with low cognitive burden, you will burn yourself sooner or later.

samuelc@lemmy.world on 07 Jun 2024 18:36 next collapse

That’s exactly what pre-commit.com project is doing

fart_pickle@lemmy.world on 07 Jun 2024 20:33 collapse

Having plain text secrets, or having secrets at all in a repository is always a bad practice. Even if it’s a super-duper private/local/no one will ever see this repo.

NOT_RICK@lemmy.world on 07 Jun 2024 17:32 next collapse

And that’s why you always leave a note recheck your .gitignore file before committing

bamboo@lemmy.blahaj.zone on 07 Jun 2024 17:43 next collapse

Does Microsoft’s GitHub offer any pre-receive hook configuration to reject commits pushed that contain private keys? Surely that would be a better feature to opt all users into rather than Windows Copilot.

alexdeathway@programming.dev on 07 Jun 2024 18:04 next collapse

they notify but that’s all

redcalcium@lemmy.institute on 08 Jun 2024 01:08 next collapse

They notify but iirc only if you push a commit to a public repo. The dev in the article pushed it to a private repo, then later made the repo public.

PumaStoleMyBluff@lemmy.world on 08 Jun 2024 12:15 collapse

The docs say they can reject if you enable push protection, which is also available for private repos, just as a paid feature. It’s free for public, but still needs to be enabled.

chilicheeselies@lemmy.world on 08 Jun 2024 15:18 collapse

They have something called advanced security that can scan for things like secrets. It works on PRs though, so not very helpful if you have a public repo.

[deleted] on 08 Jun 2024 11:16 next collapse

.

Scrollone@feddit.it on 08 Jun 2024 11:42 collapse

I can’t understand how people use git from the command line without a proper visual tool such as Sublime Merge

chilicheeselies@lemmy.world on 08 Jun 2024 15:16 collapse

Visual tooks are great, but they all have their own idea of how to manage files commits etc. Understand the cmd line and then you will understand your gui tools. I use a little of both, depending on the task

Faresh@lemmy.ml on 08 Jun 2024 12:12 collapse

You can also do git diff --cached to see all changes you added to the index.

BrianTheeBiscuiteer@lemmy.world on 07 Jun 2024 17:53 next collapse

One of the first things you should do in a repo is add a .gitignore file and make sure there are rules to ignore things like *secret* or *private* etc. Also, I pretty much never use git add . because I don’t like the laziness of it and EVERY TIME one of my coworkers checked in secrets they were using that command.

lurch@sh.itjust.works on 07 Jun 2024 20:05 next collapse

Even though that’s a good extra precaution, per person config data, such as keys, should be stored outside of the repo, eg. in the parent directory or better in the users home dir. There is zero reason to have it in the repo. Even if you use a VM/containers, you can add the config in an extra mount/share.

barsquid@lemmy.world on 08 Jun 2024 04:16 collapse

What’s the general consensus on storing encrypted data in the repo with the keys outside? I see people recommend that but I’m too paranoid and my secrets are very small in size so it hasn’t been necessary.

elephantium@lemmy.world on 08 Jun 2024 04:43 next collapse

I see some of that in my job. We put encrypted data in settings files, and the keys for decryption are provided on the VMs where we deploy. The developers never actually see the keys.

I suppose it’s as secure as the process for managing the production VMs, assuming the encryption isn’t just md5!

Takios@discuss.tchncs.de on 08 Jun 2024 07:18 next collapse

I’ve seen that done for configuration management like Salt or Ansible. The repos for that were always hosted on internal Gitlab instances though.

lurch@sh.itjust.works on 08 Jun 2024 09:21 collapse

the format of the encrypted file can give the attackers an advantage. if your code reads the decrypted file, the attacker can guess the first line is a comment or the name of a setting. a savvy person can combine that with the algorithm to perform a “known plaintext attack”, for example by generating a number of possible passwords that would lead to files starting like that.

barsquid@lemmy.world on 08 Jun 2024 10:19 next collapse

That’s smart. Anyone trying that should definitely have a machine-generated strong password!

Natanael@slrpnk.net on 08 Jun 2024 13:51 collapse

That’s not quite the definition of known plaintext attack (cryptography nerd here), that’s bruteforce with a “crib” to use older terminology (known patterns which allows you to test candidate keys).

A known plaintext attack is defined as an attack on the algorithm to extract the key faster than bruteforce with analytical attacks.

JimmyMcGill@lemmy.world on 07 Jun 2024 22:20 next collapse

I basically always do a git add -p

Very useful command and it works with other git commands as well.

Everytime a colleague asks me for help with git that’s the one rule I suggest them to use.

kambusha@sh.itjust.works on 08 Jun 2024 11:18 collapse

What does that do?

PumaStoleMyBluff@lemmy.world on 08 Jun 2024 12:09 collapse

Instead of just adding whole changed files, it starts an interactive mode where it shows every hunk of diffs one by one, and asks you to input yes or no for each change. Very helpful for doing your own mini code review or sanity check before you even commit.

iegod@lemm.ee on 08 Jun 2024 12:57 next collapse

I use vscode with plugins and manually add my files now. The workflow is beautiful.

PumaStoleMyBluff@lemmy.world on 08 Jun 2024 13:18 collapse

If you ever Stage Selected Range in VSCode, that accomplishes basically the same thing as git add -p!

JimmyMcGill@lemmy.world on 09 Jun 2024 23:35 collapse

That’s exactly why I do it

The s option is very useful to split the chunks.

Nithanim@programming.dev on 08 Jun 2024 09:09 next collapse

I never understood why everyone uses it as a ignore list. In my own and work repositories I always exclude everything by default and re-add stuff explicitly. I have had enough random crap checked in in the past by coworkers. Granted, the whole source folder is fully included but that has never been a problem.

andrew@lemmy.stuart.fun on 08 Jun 2024 16:04 next collapse

Better yet you can configure gitignore globally for git. I do this mostly to avoid polluting repo ignore files with my editor specific junk but *.key and similar can help prevent accidents.

git-scm.com/docs/gitignore

BrianTheeBiscuiteer@lemmy.world on 08 Jun 2024 16:38 next collapse

For personal projects that’s definitely a good idea. For team projects I like to keep that stuff in the project still so the “experience” of working in the project is mostly consistent.

bellsDoSing@lemm.ee on 09 Jun 2024 01:37 collapse

I started using git-secret 2 years ago. It’s nice for making secrets part of the repo, while not being readable by anyone that isn’t explicitely allowed to do so (using GPG).

Kazumara@discuss.tchncs.de on 09 Jun 2024 13:38 collapse

Better yet you can configure gitignore globally for git.

I think you really need the project specific gitignore as well, to make sure any other contributor that joins by default has the same protections in place.

sugar_in_your_tea@sh.itjust.works on 10 Jun 2024 14:27 collapse

git add -u is pretty nice, it only adds modified files.

I usually do git add -p which is interactive (helps avoid committing debugging prints and whatnot), but the other is nice for bigger refactors.

4stringscooter@lemmy.ml on 07 Jun 2024 22:40 collapse

I use this as a pre-commit hook github.com/americanexpress/earlybird

JoMiran@lemmy.ml on 07 Jun 2024 17:08 next collapse

I use a text file version of a novel to back up my keys, then I store the key map in multiple cloud drives. For example, if the word is “lighting” then my key map for that word would be 487,5 (line 487, word 5). Easy to crack, if you know what novel I am using.

AbidanYre@lemmy.world on 07 Jun 2024 17:13 collapse

That’s the copy protection on dozens of computer games from the 90s.

JoMiran@lemmy.ml on 07 Jun 2024 17:51 next collapse

Well, I am a Gen-X’r.

zarathustrad@lemmy.world on 08 Jun 2024 00:31 next collapse

To get my codes you have to play Alone in the Dark 2, and have the original 2 sided playing cards, then translate that into Brittanic runes and find the latitude and longitude of the given city on a cloth map from the original Ulitma.

downhomechunk@midwest.social on 08 Jun 2024 09:31 next collapse

Chuck Yeager’s air combat!

ArcaneSlime@lemmy.dbzer0.com on 09 Jun 2024 13:17 collapse

It’s also even older in use in communicating secretly, known as a Book Cipher. You and your recipient get the same copy of a book and agree to one of a few numbering schemes, the plaintext message becomes numbers that correspond with words in the book.

ThrowawayPermanente@sh.itjust.works on 07 Jun 2024 17:13 next collapse

What a muppet

Johanno@feddit.de on 08 Jun 2024 07:47 next collapse

They made 2 errors.

  1. Use crypto

  2. Storing the key anywhere close to the repo.

FiniteBanjo@lemmy.today on 09 Jun 2024 03:55 collapse

  1. Letting AI code for you
AngryCommieKender@lemmy.world on 09 Jun 2024 15:12 collapse

You need an escape backslash character (\) before the #3 so it doesn’t show as a #1.

FiniteBanjo@lemmy.today on 09 Jun 2024 18:29 collapse

Works fine for me, lemmy.today on desktop browser.

Sucks that your medium for viewing is wrong, maybe you should go complain about the wrongness to the people who maintain it?

todd_bonzalez@lemm.ee on 08 Jun 2024 13:26 next collapse

I can’t believe someone would be so stupid and careless as to develop Web3 software.

Blackmist@feddit.uk on 08 Jun 2024 14:32 next collapse

Did we not learn our lessons from Web 2.0?

lando55@lemmy.world on 09 Jun 2024 03:49 next collapse

Got me good

[deleted] on 09 Jun 2024 13:50 collapse

.

k_rol@lemmy.ca on 08 Jun 2024 13:33 next collapse

I’m sad I didn’t see any comments saying he shouldn’t be using a $40k wallet key to test his software in the first place. Anything could happen with simple code mistakes…just get an empty wallet or one with a few bucks in it.

CriticalMiss@lemmy.world on 09 Jun 2024 04:15 collapse

There’s a reason we use .env files and put them in gitignore.