December 23, 2024
By Matt Wicks
On 15th December 2024, TinaCMS identified unauthorized activity involving compromised AWS access keys. These keys were exploited to send unauthorized emails (targeting the general French community, not Tina customers specifically) using our Amazon Simple Email Service (SES) infrastructure.
 Figure: the emails sent were in French
Figure: the emails sent were in French
As an automated measure, the impacted key was revoked. Afterwards, our team confirmed the extent of the incident using CloudTrail logs, investigated root cause, and took steps (described below) to secure our systems.
Outbound email functionality, including user invitations, was impacted. This has since been resolved.
We apologize for this, and we are confident that it won’t happen again.
Incident start: 15th December 2024, 16:33 GMT+11
Time of Detection: 15th December 2024, 19:05 GMT+11
Type of Incident: Unauthorized use of AWS access keys
Services Impacted:
Nature of Access:
Verification:
The unauthorized access was traced to a vulnerability in our CI/CD pipeline. During the build process, a step in the GitHub Actions workflow inadvertently wrote the GitHub Actions Runner’s environment variables, including sensitive AWS access keys, to a JavaScript file.
The JavaScript file containing the keys was subsequently deployed and served publicly as part of TinaCloud, allowing attackers to obtain the access keys directly from the front-end code.
Customer Data:
✅ Based off CloudTrail logs, there was no evidence of unauthorized access to customer data.
This includes content databases, end user login information, access to application secrets.
Affected Systems:
⚠️ Amazon SES for email-sending functionality
User Impact:
❌ Temporary suspension of email services impacted workflows, including user invitations
- ✅ Done - Revoked all access keys
All compromised and legacy AWS access keys were revoked immediately 
- ✅ Done - Verification of access:
CloudTrail logs were reviewed to identify and confirm systems accessed by the unauthorized actor 
- ✅ Done - Confirmed security controls:
MFA (Multi-Factor Authentication) is enabled on all user accounts that have console access
Revoked access to all unnecessary users 
- ✅ Done - Suspension of email sending:
Outbound email services were temporarily suspended whilst we were ascertaining root cause and AWS’s review.
Services have now been restored. 
- ✅ Done - CI/CD AWS access
Authentication for the GitHub Actions has been upgraded from long lived Access Keys to OIDC 
- ✅ Done - Build process
The build process was reviewed, and the handling of environment variables was updated.
The use of process.env was replaced with import.meta, following best practices outlined in  Vite’s documentation- , to prevent sensitive data from being exposed in build artifacts. 
- ✅ Done - Repository secrets audit
A thorough audit of all GitHub repositories is being conducted to identify any other sensitive information that may have been inadvertently exposed in past builds or commits 
- [TODO] Hardened IAM policies
IAM policies tied to CI/CD systems have been reviewed and updated to ensure adherence to least privilege principles, removing unnecessary permissions, especially those with root or administrative access 
- [TODO] IP allow listing for AWS access
AWS IAM role usage has been restricted to trusted IP ranges, particularly for CI/CD systems and other sensitive operations 
- [TODO] Continuous monitoring and alerts
Continuous monitoring tools like Amazon GuardDuty, AWS CloudTrail Insights, and AWS Security Hub will be implemented to detect and alert on suspicious activity, such as new access key creation or unusual IP access 
- [TODO] Automated security scans
Automated tools will be integrated into the CI/CD pipeline to proactively detect secrets or vulnerabilities during code builds 
- Report suspicious emails: If you received unauthorized or suspicious emails from TinaCMS, please report them to  security@tina.io
- Verify email origin: Ensure any emails claiming to be from TinaCMS are legitimate 
- Stay updated: Follow our official communication channels for real-time updates 
For questions, concerns, or further information, please contact:
TinaCMS remains committed to protecting our systems and maintaining transparency.
🦙 The Tina herd