Skip to content
This repository has been archived by the owner on Oct 3, 2023. It is now read-only.

Latest commit

 

History

History
175 lines (139 loc) · 10.5 KB

CHANGELOG.md

File metadata and controls

175 lines (139 loc) · 10.5 KB

Change Log

All notable changes to this project will be documented in this file.

Unreleased

  • Added: Optional parameters "security_allow_no_token"
  • Added: Optional parameters "security_token_lifetime_no_refresh"

[0.1.17] 2020-12-18

  • Added: optional SMS cleanup lambda

[0.1.16] 2020-12-14

  • Added: Missing variables for proxy URLs
  • Added: New parameter "reduced_metrics_whitelist"
  • Added: New optional parameters and secret to proxy verification requests to a third party

[0.1.15] 2020-11-26

  • Updated: Set default "download_schedule" to offset from "upload_schedule"
  • Updated: Give access to "time_zone" parameter to all services that write metrics
  • Updated: Remove "CALLBACK_REQUEST" from "metrics_config".
  • Added: New parameter "push_cors_origin" to control CORS headers in push service

[0.1.14] 2020-11-13

  • Added: self isolation notices support.
  • Updated: Remove "TOKEN_RENEWAL" from "metrics_config" to capture it on backend.
  • Update: Updated policies for CI user to allow required lambda access.

[v0.1.12] 2020-10-28

  • Updated: Set queue visibility timeout based on lambda timeout
  • Added: "api_gateway_customizations_binary_types" variable to configure api gateway to serve custom binary types
  • Added: "api_gateway_customizations_md5" variable to trigger api gateway stage deployments on both internal and external changes
  • Added: Lambda policy option to allow sending SES emails based on a from whitelist
  • Updated: Increased default timeouts and memory size for lambdas
  • Added: Lambda options to manage S3 access content in the policy
  • Updated: Restricted ci-user permissions

[v0.1.11] 2020-10-08

  • Added: Optional parameters "security_callback_rate_limit_request_count" and "security_callback_rate_limit_secs"

[v0.1.10] 2020-10-07

  • Updated: "lambda_callback_timeout" variable default to 180s as we have observed current 15s is insufficent for many tenants
  • Updated: "lambda_exposures_timeout" variable default to 180s as we have observed current 60s is insufficent for many tenants
  • Updated: "lambda_sms_timeout" variable default to 180s as we have observed current 15s is insufficent for many tenants
  • Added: "cso_schedule" variable to control the cso lambda schedule
  • Deleted: ci-user security access key credentials, so they are not included in the statefile and output
  • Added: CloudWatch container insights activation option - default is disabled
  • Added: "api_gateway_timeout_milliseconds" variable to control the API Gateway

[v0.1.9] 2020-09-29

  • Removed: Cloudwatch dashboard
  • Added: Bastion "bastion_instance_type" variable
  • Added: Push API TLS policy as a parameter
  • Changed: Modified lambda exposures default timeout
  • Changed: Modified lambda exposures default memory allocation
  • Added: Added extra ci-user privs to add vertical annotations to cloudwatch graphs
  • Added: Push API TLS policy as a parameter

[v0.1.8] 2020-09-23

  • Added: Added "attach_waf" variable to attach/detach WAF to ALBs and API Gateway
  • Added: Added "disable_valid_key_check" variable to flag whether to disable check if key is still valid when generating export files
  • Added: Added "variance_offset_mins" variable to add to lifetime of keys to check if they are still valid
  • Added: Added "onset_date_mandatory" variable to control whether onsetDate/symptomDate is mandatory
  • Added: New "api_gateway_minimum_compression_size" to allow compression configuration on the APIGateway
  • Added: New variables to control ECS scaling adjustments
    • api_ecs_autoscale_scale_down_adjustment
    • api_ecs_autoscale_scale_up_adjustment
    • push_ecs_autoscale_scale_down_adjustment
    • push_ecs_autoscale_scale_up_adjustment
  • Added: SUPPORT_REQUESTS.md
  • Added: Headers Cache-Control, Pragma, Strict-Transport-Security
  • Changed: Push API TLS 1.2 enforcement

[v0.1.7] 2020-09-17

  • Updated: Set "upload_max_keys" to "15" by default due to ENS changes
  • Updated: moved lambda common resources in a separate file
  • Updated: Added outputs: lambda security group, default tags, resources prefix id
  • Removed: Redundant aws providers with aliases "us" and "root", we no longer use these
  • Removed: Redundant template provider - we no longer use
  • Added: Include additional mock APIGateway for HEAD /api/healthcheck
  • Added: Added "db_pool_size" variable to control pg max pool size - Can be used by ECS API and ECS Push services
  • Updated: Allow stats lambda to access "time_zone" parameter
  • Updated: Added additional resources to the operators group policy for MFA
  • Fix: Adjusted values displayed in the CloudWatch dashboard, so take into consideration doubled logs in ApiGateway logs

[v0.1.6] 2020-09-10

  • Updated: CloudWatch dashboard to include more distinct metrics for ALB requests
  • Updated: CloudWatch dashboard RDS connections sum changed to average
  • Updated: Module versions, needed to ensure they result in no changes
    • alb.tf - Went with v8.2.0, cannot use latest as it requires AWS provider v3+ and TF v0.13+
    • labels.tf - Went with v0.19.2, is the latest at this time
    • networking.tf - Went with v2.48.0, is the latest at this time
    • rds.tf - Went with v0.31.0, cannot use latest, as it results in changes
  • Fix: Parameter "upload_token_lifetime_mins" was using the wrong variable value
  • Updated: Operators role can manage their MFA
  • Added: extra properties to configure SNS SMS preferences
  • Fix: sms cross region setup
  • Updated: Alter terraform version requirement so we can start using v0.13.*, we now have >= 0.12.29 < 0.14
  • Added: Enabled encryption on the CloudTrail and assets S3 buckets

[v0.1.5] 2020-09-09

  • Added: Included the ALB arns (api and push) as outputs
  • Updated: Fixed "time_zone" parameter value - used incorrect value previously
  • Added: Added parameter "security_code_removal_mins" to control number of minutes before a one-time upload code is removed from the database by the cleanup lambda
  • Added: Added parameter "upload_max_keys" to control maximum number of keys accepted per upload request
  • Added: Added option to configure SNS SMS spent quota
  • Added: Added option to configure SNS SMS delivery logs

[v0.1.4] 2020-09-04

  • Added: Added parameter "use_test_date_as_onset_date" to flag whether to use testDate as onsetDate if the latter is omitted
  • Added: Added required lambda "cleanup" to handle data cleanup which runs on a CloudWatch schedule
  • Added: Default "lambda_default_runtime" variable - nodejs12.x
  • Added: Option to use lambda custom runtimes, see the "lambda_custom_runtimes" variable
  • Added: Ignore filename in lambda lifecycle
  • Added: Added extra parameter "symptom_date_offset" to add an offset in hours to symptomDate or onsetDate in uploads
  • Added: Added "api_gateway_account_creation_enabled" variable to control APIGateway account creation as needed for CloudWatch logging, if one already exists you may NOT want to create
  • Added: Added extra parameter "TIME_ZONE" to set regional timezone for localised daily rate limiting
  • Added: Re-added field "CALLBACK_REQUEST" = 60 to default "metrics_config" parameter value
  • Added: Allow operators read the rds_readonly_user secret so they can connect to the RDS DB
  • Added: Support for lambdas using transactional SMS
  • Added: Added extra field "LOG_ERROR" = 60 to default "metrics_config" parameter value

[v0.1.3] 2020-08-25

  • Added: Option to use an S3 bucket as the source for lambdas, will be a global setting and we do not manage this bucket as this is a non default option
  • Added: Added option to send callback notifications using email via an SNS topic - subscription will not be automated
  • Fixed: Altered the ECS image so the custom vars are just for the image and do not include the tag, we append the tag if using a custom image using the tag var
  • Fixed: Fixed the "bastion_amazon_ssm_managed_instance_core" aws_iam_role_policy_attachment (Incorrect casing in name), this will result in a Terraform apply failure when applied, can run a second time to fix
  • Fixed: Removed RDS admin user access where not needed
  • Added: Added "verify" secret and changed "jwt_issuer" and "certificate_audience" parameters to support third party key server

[v0.1.2] 2020-08-14

  • Updated: Added explicit depends_on for the APIGateway /healthcheck resources, need this to be applied on all envs before we can remove this mock integration
  • Added: ALB logging - both ALBs log to the same bucket, using distinct prefixes - api and push
  • Updated: Upgraded AWS provider from = 2.68.0 to ~> 2.70.0
  • Updated: Switched to using templatefile function rather than deprecated template provider

[v0.1.1] 2020-08-13

  • Added: Added ability to set ECS image url and image tag overrides, this is based on @segfault's PR at covidgreen#4
  • Updated: Switched lambdas from using the AWSLambdaBasicExecutionRole to AWSLambdaVPCAccessExecutionRole managed policy
  • Updated: Renamed the "root_profile" var and "root" AWS provider to "dns" as this is confusing, removed a redundant aws provider "root_us"
  • Updated: Added changes @segfault added re explicit usage of the AWS CLI --output json usage in some of the scripts
  • Removed: Removed Terraform validate from the pre-commit hook config as this is being used as a module, have left the s3 backend config for now
  • Updated: Switched all the lambdas from nodejs10.x to nodejs12.x
  • Added: Use variables for the lambda memory size and timeout attributes with defaults, so we can configure via env-vars files
  • Removed: Extracted cti, gct and ni content into specific repos - Will not be managed by this repo
  • Added: Added new AWS parameters certificate_audience and jwt_issuer and removed security_exposure_limit AWS parameter
  • Added: Docs on the 2 approaches to managing a project - external to this repo and internal to this repo
  • Added: Added RDS reader/writer endpoint outputs
  • Added: Surfaced bastion ASG desired count as a variable, will need when we use this repo as a module
  • Added: Switched to using path.module prefixes for the CloudWatch dashboard template and the ECS container defintion templates
  • Fixed: Changed the create TF store backend script to cater for us-east-1 being a special case - Location constraints
  • Fixed: Replace all refs to cti, gct and ni with xyz in docs and shell script comments - this is just prep for the open source branch
  • Added: Added the following optional lambdas to the operators group execute list: daily-registrations-reporter, download and upload
  • Added: Pre-commit hook to include TF fmt, validation and linting
  • Fixed: Linting issues - no logic
  • Added: Split RDS user usage so we no longer need to use the master credentials

[v0.1.0] 2020-08-13

  • Initial content