DEV Community

Konrad Kurek
Konrad Kurek

Posted on • Edited on

Secrets 101: A fun and practical basic guide to avoiding leaks and not becoming a meme

Ah, secrets - the underrated unsung heroes of software development powering your apps, securing your data, and sometimes making into public GitHub repositories.

Funny meme

-- Image from Reddit --

Sensitive data leaked, accident? Intention? We will never know. But what we know is this: how to manage secrets securely is not optional, it's a must-have skill for every developer. Let's get into how to avoid making headlines with bad news.


๐Ÿค” Why Should You Care About Secrets Management?

Secrets are just the backstage passes of the app: the keys to databases and APIs, among other things. Unfortunately, bad things happen when you mishandle secrets, such as:

  • A data breach๐Ÿ“‰
  • Unauthorized entry๐Ÿšจ
  • Unplanned costs associated with abuse of paid services. ๐Ÿ’ฐ
  • An embarrassing moment in your team's Slack channel๐Ÿ˜…

The risks extend beyond just development as it's just as important to keep sensitive values (like the production database credentials) secure during deployment.

Let's break it down into how you can securely handle secrets in both development and deployment.


๐Ÿ” Secrets and Version Control: Best Practices

Version control systems like Git are indispensable for teamwork, but they can also expose secrets if not handled carefully.
๐Ÿšซ What Not to Do:

  • Don't upload .env or secrets files directly to your repository. (always place file names in .gitignore)
  • Don't hardcode sensitive values in your source code.
  • Don't name files something like super_secret.json and think nobody would notice.

โœ… Better Way:

The golden rule is to encrypt and centralize your secrets. Here's how:

  • Encrypt your secrets or .env file before going ahead to commit them to the repository. ๐Ÿ”’

Not encrypted:

$ cat .env
API_KEY=<your_api_key>
DB_PASSWORD=<your_db_password>
...
Enter fullscreen mode Exit fullscreen mode

Encrypted:

$ cat .env.encrypted
AH6Z9YQAUZyy3SrYZcbqge6QvWtC93f/d853XfVBm8qOvepGLUGvoRfMW7urZpjIsfWy4wb4c3T4p7LQ
Enter fullscreen mode Exit fullscreen mode

โ˜๏ธ Better, more secure, able to be "accidentaly" (or not๐Ÿ˜‚) shared?

  • Enabling a shared decryption key to allow a team of members access to such a file locally. ๐Ÿ”‘
  • Automate such encryption with a lightweight script for easy onboarding of new developers with some simple instructions. ๐Ÿ› ๏ธ
  • Always keep unencrypted env files in .gitignore, better not to have one that have leaked one ! I know that I'm redundant in this but it is basic rule. ๐ŸคŒ

This keeps your secrets safe even if someone accidentally finds this encrypted file in your repository.


๐Ÿ’ฅ Keeping Secrets Secure During Deployment

Ideal secrets management does not come to an end soon after your code goes into production. Just as important is its deployment phase, during which sensitive values are protected and never let out into logs, errors, or (may this never happen) public dashboards.

Here are several best practices for deployment:

  • Use environment variables for injecting secrets at run time; that way, they won't be in your codebase.
  • Rotate passwords and keys regularly: That little effort today might save gaining a big headache later.
  • Utilize safe CI/CD expose secret inject during builds and deployments.

Automation is in your corner on this one: secrets should be touched in as little manual fashion as possible. ๐Ÿค–


โ˜๏ธŽ Think about cloud providers key management options

There are plenty of options, You or your company may use one of them that will make easier to keep encrypted variables safe. Established secret management solutions such as HashiCorp Vault, AWS Secrets Manager, or Azure Key Vault are probably best options for medium to large projects/companies. You may also use mentioned services as keystore for your encrypted env files. But personally when I hear cloud i have ๐Ÿค‘ such a facial expression. For no-cost or small projects cloud services may be overkill.


๐Ÿ—‚๏ธ One Central File to Rule Them All

The best way to do secrets management is to centralize your sensitive values. Having all secrets in a single secure file (and well encrypted of course) will:

  • Lower Duplication.
  • Reduce the likelihood of accidental exposure.
  • Simple Update across teams and environments.

It's organized, safe, and always ready approach for development process. And naming it do_not_open.txt.encrypted (without encryption at all) is not considered as secure. ๐Ÿ˜‚


Conclusive Thoughts๐Ÿ’ญ

It is possible that manipulating secrets may not seem the most exciting part of software development, but it is an essential activity. By following best practices such as encryption, automation, and centralization, one will avoid leaks. Also, it will save a great deal of time in future troubles and make systems secure.

You are supposed to remember whenever you are tempted to commit that .env file: all this effort seems really small compared to what goes into - protecting your team, and securing those secrets-your API keys will steer clear of memes. โœŒ๏ธ.

Keep yourself and your sensitive data secured ๐Ÿ”
And wish you not to become meme ๐Ÿ˜‰

Top comments (0)