data:image/s3,"s3://crabby-images/1e238/1e2386a0f95edf2af68386198eee4c9123fc2f63" alt="Surpass"
data:image/s3,"s3://crabby-images/1e238/1e2386a0f95edf2af68386198eee4c9123fc2f63" alt="Surpass"
Industry:
Transportation Startup
data:image/s3,"s3://crabby-images/5212c/5212c8a41e111a9a47a5977309a362879626c0a6" alt="Buldings Icon"
1. Initial state
Surpass is a strategic projects company that built a public-transportation planning system. They created a web app to allow Public Transportation Designers to create and test how new transportation lines would behave, work, and impact current traffic and usage.
Their state when they met us:
- Basic app, running locally on the developers' computers.
- No ability to work with the users.
- No environments set, or a possibility to collaborate live with other developers.
- No deployment pipelines or version management.
data:image/s3,"s3://crabby-images/e636c/e636ce761cbc47aecadc0436262170fe7fa57220" alt="Stack Icon"
2. Tech stack
data:image/s3,"s3://crabby-images/17082/17082ea6024e6ebd8c0a4c4a697f9001922fced2" alt="Target Icon"
3. Project goals
- Fully managed IaC-based infrastructure & environments.
- Developers' freedom, accessibility, and ease of use.
data:image/s3,"s3://crabby-images/7390d/7390db3d0f3d1cb6277eaab3011146389c632787" alt="Checklist Icon"
4. Decisions
Use Terraform/Terragrunt to manage the infrastructure:
This is the most flexible IaC approach, enabling full control and integration with AWS resources.Create Dev/Staging/Production environments entirely in code.Develop a deployment process to deploy changes initially to Dev and later to Staging & Prod, with the appropriate tests and branching strategies in Git.data:image/s3,"s3://crabby-images/5ae44/5ae447a8c1ac1c5ba43c938c3e2218a902aafc49" alt="Lock Icon"
5. Restrictions
We accounted for the following security-related restrictions:
- Geo-based access restriction.
- Usage of WAF & CloudFront.
- A solid access control system for the internal (Private VPC) system.
data:image/s3,"s3://crabby-images/45a79/45a79a749add40e305f2643c59664bf54656580b" alt="Map Icon"
6. Strategy
The goals, decisions, and restrictions led to the following strategy:
- Use Terragrunt to re-use Terraform code, ensuring better observability of environments and resources. This approach allowed us to change only configuration values between environments, avoiding changes to actual code logic.
- Manage all secrets in AWS Secrets Manager, accessing values from GitHub Action Pipelines with multiple values set per environment.
- Deploy the Dev stack first, then build Staging and Production environments to improve stability, applying the same strategy for later additions.
- Create sub-projects following the same method.
- Define the correct CI/CD pipelines and branch protections for an optimal review and deployment flow.
data:image/s3,"s3://crabby-images/57d9d/57d9d91300fe47105f31fb75ab3f2fe2497b8fd8" alt="Settings Icon"
7. The process
The process of creating Surpass' infrastructure was methodical and detailed:
- Create the Terraform module, deploy it using Terragrunt, and check for usability.
- Request feedback from the Dev team or the customer and make adjustments.
- Manage and organize the code and Infrastructure modules.
This iterative methodology allowed us to:
- Be agile.
- Re-use code.
- Adhere to customer and developer requirements.
- Deliver value quickly, in small and manageable parts, while keeping everything tidy and neat.
data:image/s3,"s3://crabby-images/86bd8/86bd87b4b1a0002f1044fac0ca6a537d09ba5b4f" alt="Chart Icon"
8. Results
The entire infrastructure is managed using Terraform.Identical Dev/Staging/Production environments were created, with differences limited to each module's inputs (mostly the same).Migration between AWS accounts (due to various reasons) was 10x faster compared to non-Terraform setups.Each change, addition, and modification of the environment was recorded and managed in the Git repository containing Terraform/Terragrunt code.The codebase remained clean and organized.System services were completely isolated and inaccessible to the public web.data:image/s3,"s3://crabby-images/6c1c1/6c1c1f7d68616c4ad494c5411113632cdc26a0b9" alt="Table Icon"
9. Before & After