script> !function(w,d){if(!w.rdt){var p=w.rdt=function(){p.sendEvent?p.sendEvent.apply(p,arguments):p.callQueue.push(arguments)};p.callQueue=[];var t=d.createElement("script");t.src="https://www.redditstatic.com/ads/pixel.js",t.async=!0;var s=d.getElementsByTagName("script")[0];s.parentNode.insertBefore(t,s)}}(window,document);rdt('init','a2_gak5ncm47xiy');rdt('track', 'PageVisit');
ATTACK

Trouble Keeping Track of Your Keys? So Does Toyota: Lessons Learned from a Key Management Breach

Nir Valtman
CEO & Co-Founder
October 12, 2022
Nir is an experienced information & application security leader, most recently as VP security at Finastra and CISO at Kabbage. Nir is a frequent public speaker at leading conferences globally, including Black Hat, Defcon, BSides, and RSA.

TL;DR

Toyota disclosed a data leak caused by exposed access keys on GitHub. The lessons learned are that basic controls that provide high value for low effort were not implemented. This blog post will share quick wins toward the goal of securing your development ecosystem.

{{arnica-top-signup-banner="/template-pages/try-arnica-banner"}}

Introduction: What happened in the Toyota key management breach? 

  1. A hardcoded secret to the data server for Toyota’s connectivity app has been exposed publicly on GitHub for almost 5 years. This server stored customer data, including PII.
  2. The visibility of the source code repository was inadvertently changed to public in December 2017.
  3. Toyota blamed a development subcontractor for the error of pushing the hardcoded secret into the source code.

Quick win #1: Scan for hardcoded secrets

Many commercial and open-source products provide secret scanning capabilities. Each product has pros and cons, which I am not going to discuss in this blog post. But the quickest win would be either using a free unlimited secrets scanner (shameless promotion for Arnica) or run an open-source tool that iterates through all repositories and identifies hardcoded secrets. For example, you can install the free version of Semgrep and iterate through all repositories to find secrets and many other vulnerabilities, at least for the first iteration.  

Here are the steps to get there:

  1. Generate a GitHub Personal Access Token and grant it the “repo” scope.
  1. If your organization is protected by SAML, grant the access for this token into the organization.  
  2. Run the following Python script.
  1. Triage the results in the file and ask the devs to fix them.

Quick win #2: Get alerts when repositories become public

Setup a webhook to receive notifications when a repository’s visibility changes and notify the relevant stakeholders in their relevant channel. In this example, the webhook is automatically set within 5 minutes through Tines. Here are the steps:

  1. Create an account in Tines. You can use 3 workflows for free.
  2. Create a webhook step with its default settings. Copy the URL, as you will need it in the next step.
  1. Go to the webhook configurations page (https://github.com/organizations/{YOUR_ORG}/settings/hooks) and create a new webhook.
  2. Paste the URL from Tines, select the content type as “application/json” and change the events trigger to “let me select individual events.”
  1. Select the checkbox of “visibility changes” and click Save.
  1. Go back to Tines and add an email action. Set the action to send an email to a desired destination and include the repo name in the action, as in the screenshot below.
  1. Try to change a dummy repository from private to public and check your inbox. Here is the result on my side.

Quick win #3: Ensure CODEOWNERS is enforced  

Code reviews are vital for code quality and security. GitHub enables this capability via the  CODEOWNERS file. However, it is easy to misconfigure the file since it requires both the configuration of the file and the enforcement of the branch protection policy to require a review from the CODEOWNERS. Here is an example script that can help you to determine if any of the CODEOWNERS files and policies are misconfigured.

Caveat: the assumption of this script is that CODEOWNERS is configured in the default branch. At Arnica, we developed a more comprehensive classification mechanism to determine which branches are important to protect.  

Would this solution prevent the secret from appearing in git history? No, but it will enforce another set of eyes on code changes to help identify secrets and other risky code changes prior to pushing them to a production environment.

Conclusion: Prioritize key management for secure access control and to protect against potential breaches

The actions listed above will provide quick value, but as illustrated by Toyota’s recent leak, properly securing your development ecosystem requires a comprehensive analysis of developer permissions, identification of abnormal and risky developer behavior, and regular scans for hardcoded secrets.

THE LATEST UPDATES

More from our blog

How Arnica's Low-Reputation Package Detection Could Have Prevented the XML-RPC npm Package Breach
How Arnica's Low-Reputation Package Detection Could Have Prevented the XML-RPC npm Package Breach
December 4, 2024
New York Times Data Breach Reveals Secrets & Source Code
New York Times Data Breach Reveals Secrets & Source Code
January 6, 2025
Rabbit r1 Data Breach Again Shows The Dire Need for Improved Secrets Security
Rabbit r1 Data Breach Again Shows The Dire Need for Improved Secrets Security
January 6, 2025

{{arnica-bottom-signup-banner="/template-pages/try-arnica-banner"}}