-
Notifications
You must be signed in to change notification settings - Fork 2
Environment Management
An integration product like FAM is unusual in that it supports "customers" (teams developing digital products) and those customers need a permanent environment for each of their DEV, TEST, and PROD environments. This document describes the FAM approach to managing these permanent environments while supporting ongoing FAM developments.
Each customer needs to be able to configure three versions of their digital product (DEV, TEST, and PROD). Ideally, these three versions behave the same so that the customer can develop and test their product and be confident that their integration code will work when they deploy to production. The only changes between their environments should be configuration items like URLs or access keys.
In particular, the DEV and TEST integrations that are exposed to a customer are considered permanent production environments. Outages in these integrations may affect customer activities. The service levels to support non-production environments do not necessarily need to match the production environment, but outages and releases must still be communicated appropriately.
Each environment of a customer product (DEV, TEST, and PROD) must use the corresponding version of the identity provider
For example, the DEV integration for a product that uses BCeID Business must be authenticated with the DEV version of the BCeID login domain. In practice, this is not an issue for IDIR, since there is no "dev" or "test" IDIR domain (all IDIR integrations must use real IDIR accounts for testing). For BCeID, there is a "test" domain that is generally used for DEV and TEST environments. Nevertheless, FAM may in the future support an IDP that segregates DEV, TEST, and PROD domains and has different user sets in each.
The way to solve this is to have separate IDPs for DEV, TEST, and PROD for each identity provider, and to set up corresponding DEV, TEST and PROD clients for each digital product that integrate with the appropriate "level" of the IDP.
Each environment of a customer product (DEV, TEST, and PROD) must be able to have distinct authorization configuration data
For example, a digital product team may configure their DEV environment by assigning certain application roles to developers or configure their TEST environment by assigning certain application roles to QA resources. In production this may be inappropriate. Additionally, the users that have access control permissions for an application in PROD will almost certainly be restricted differently than in DEV and TEST.
Each FAM environment costs a certain amount of money to maintain in AWS. Replicating environments unnecessarily is to be avoided. In particular, the RDS Proxy component has a significant minimum hourly charge that will be multiplied by the number of instances.
Additionally, AWS Cognito charges based on the number of Active Monthly Users (AMU). If the same user record has activity in multiple Cognito user pools, the monthly cost for that user will be multiplied.
The FAM operational process extensively uses "Infrastructure as Code" (IaC) and "Configuration as Code" (CaC) techniques to automate system management. In order to test the infrastructure and configuration code before applying changes to FAM production, it is important that the infrastructure and configuration code for lower environments is as similar as possible as production. Ideally, the FAM DEV and TEST environments are identical to PROD.
Maintaining a separate code base for each environment is risky and takes more effort. Testing in production would be required for each release if the code to deploy and configure PROD diverges from the code for the lower environments.
The FAM team maintains a single instance of the architecture that is "Permanent" and supports customer DEV, TEST, and PROD environments. The FAM DEV and TEST environments have an identical architecture and configuration to that of PROD. All the environments share a set of OIDC configurations provided by the Pathfinder SSO Keycloak server.
Diagram here.
- Environment Management
- Release Management
- Creating a Release
- Database Backups and Restores
- OIDC Client Testing
- FAM Onboarding Ops Guide
- Setup AWS CloudWatch
- Setup AWS EC2 instance to connect to RDS Postgres Database
- Technical Troubleshooting
- Managing Terraform State
- Enable Cloudwatch Logs for API Gateway
- Update AWS CloudFront Certificate
- Verify IDIM BCeID Client SOAP Web Service