Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Upgrade RDS certificate on Staging #3286

Merged
merged 4 commits into from
Jul 25, 2024

Conversation

TylerHendrickson
Copy link
Member

Description

This PR adds explicit configuration for setting the SSL/TLS certificate for RDS Aurora Postgres in Terraform and sets values for the new config in each environment. Deploying this change to the Staging environment will trigger rotation of the current rds-ca-2019 certificate to the new rds-ca-rsa2048-g1 certificate. It will NOT affect the certificate on Production.

Note that #3273 updated the CA bundle file used to verify SSL/TLS connections. Previously, the bundle was only compatible with the rds-ca-2019 certificate; the new bundle file is compatible with both rds-ca-2019 and rds-ca-rsa-2048-g1 certificates.

Per-environment configuration:

  • Sandbox:
    • Certificate identifier: rds-ca-rsa-2048-g1
    • Effect: The certificate in this environment has already been manually rotated, so this setting has no effect.
  • Staging:
    • Certificate identifier: rds-ca-rsa-2048-g1
    • Effect: As the Staging environment currently uses the rds-ca-2019 certificate, this change will prompt RDS to schedule a certificate upgrade in this environment.
  • Production:
    • Certificate identifier: rds-ca-2019
    • Effect: This environment currently uses the rds-ca-2019 certificate, so this setting has no effect.

@TylerHendrickson TylerHendrickson self-assigned this Jul 22, 2024
@TylerHendrickson TylerHendrickson requested a review from a team July 22, 2024 17:21
@github-actions github-actions bot added enhancement New feature or request Infra Issues related to the infrastructure underlying all the tools. terraform Pull requests that update Terraform code labels Jul 22, 2024
Copy link

github-actions bot commented Jul 22, 2024

QA Summary

QA Check Result
🌐 Client Tests
🔗 Server Tests
🤝 E2E Tests
📏 ESLint
🧹 TFLint

Test Coverage

Coverage report for `packages/client`
St File % Stmts % Branch % Funcs % Lines Uncovered Line #s
🔴 All files 32.54 31.01 29.29 34.17
🔴  src 0 100 100 0
🔴   App.vue 0 100 100 0 2-9
🔴  src/arpa_reporter 0 100 100 0
🔴   App.vue 0 100 100 0 2-13
🟡  ...ter/components 57.57 40 46.8 59.78
🟡   AlertBox.vue 80 75 50 80 13
🔴   ...oadButton.vue 20 0 0 20 2-7,38-67
🟢   ...ileButton.vue 100 50 100 100 5
🟢   ...ttonSmall.vue 100 100 100 100
🟢   ...mplateBtn.vue 100 100 100 100
🟡   ...avigation.vue 67.74 63.63 52.63 67.74 ...13-219,228-235
🔴   StandardForm.vue 42.5 37.5 41.66 45.45 ...24-128,135-157
🟢  ...porter/helpers 84.61 79.48 87.5 84.61
🟢   form-helpers.js 84.21 79.48 85.71 84.21 7,16,25,81-83
🟢   short-uuid.js 100 100 100 100
🔴  ...eporter/router 0 0 0 0
🔴   index.js 0 0 0 0 20-131
🔴  ...reporter/store 3.92 0 2.17 4.12
🔴   index.js 3.92 0 2.17 4.12 11-14,32-261
🔴  ...reporter/views 40.98 25.13 41.37 42.91
🟢   AgenciesView.vue 100 0 100 100 16
🔴   AgencyView.vue 40.74 36.36 50 45.83 53-62,70-96
🔴   HomeView.vue 26.66 34.14 36.36 26.66 36-66,113,137-207
🔴   LoginView.vue 29.62 36.36 20 30.76 1,4,19-34,72-100
🔴   ...plateView.vue 27.02 35.71 45.45 25 ...2,30-37,69-113
🔴   ...ploadView.vue 24.24 16.66 33.33 26.66 1,30-31,116-144
🔴   ...eriodView.vue 48 18.18 75 52.17 64-90
🟡   ...riodsView.vue 57.57 28.57 60 59.37 101,132,149-171
🔴   ...pientView.vue 40 10.52 30.76 41.02 73-93,110-152
🔴   ...ientsView.vue 48.48 8.33 46.66 53.33 ...46,165-190,203
🟡   UploadView.vue 61.53 43.75 62.5 61.36 ...41-442,448-449
🔴   UploadsView.vue 16.66 0 0 18.18 59,110-287
🔴   UserView.vue 46.34 33.33 68.75 48.64 84,97-137
🟡   UsersView.vue 60 7.69 62.5 66.66 91-92,105-107,123
🔴   ...ationView.vue 37.03 18.18 26.66 41.66 ...19,238,246-270
🔴  src/components 40.07 30.76 44.04 40.89
🔴   ...vityTable.vue 18.75 0 28.57 19.35 115-185
🟡   BaseLayout.vue 68.18 53.84 60 68.18 175,222-234
🔴   CopyButton.vue 14.28 0 0 14.28 5,37-49
🔴   GrantsTable.vue 45.03 38.77 45 46.85 ...51-455,463-543
🔴   ...dUploader.vue 24.24 33.33 37.5 24.24 16,25,74-111
🔴   SearchFilter.vue 40.74 28 37.5 40 ...52,64,67,72-82
🔴   UserAvatar.vue 40 25 100 37.5 31-37
🔴  ...ponents/Modals 26.64 43.08 31.91 30.18
🔴   ...anization.vue 17.39 65.62 30 22.22 1-14,149-178
🔴   AddTeam.vue 45.45 55.55 61.53 57.69 ...04,210,222-245
🔴   AddUser.vue 36.66 66.66 60 37.5 ...40,145,148-176
🔴   ...anization.vue 15.38 64.28 14.28 16.66 1-15,58-78
🔴   EditTeam.vue 18.18 26.43 33.33 20.83 ...29,208,216-301
🔴   EditUser.vue 21.05 66.66 25 22.22 1,101-128
🔴   ...ilsLegacy.vue 22.03 0 0 24.07 131,177,205-369
🟡   ImportTeams.vue 50 41.17 50 53.33 28,64-69,81-82
🔴   ImportUsers.vue 42.85 60 40 46.15 29,65-80
🔴   ...archPanel.vue 27.9 15.78 23.52 28.57 ...68-178,211-255
🔴   SearchPanel.vue 21.62 63.26 32 27.58 ...77-380,386-458
🔴  src/helpers 15.2 18.81 16.21 15.57
🟢   constants.js 100 100 100 100
🟢   currency.js 100 100 100 100
🟢   dates.js 100 100 100 100
🔴   fetchApi.js 5.71 16.66 5.88 5.71 9-97
🔴   filters.js 4 0 0 4.54 19-51
🔴   form-helpers.js 0 0 0 0 5-82
🟡   gtag.js 77.77 90 75 77.77 12,51
🔴   ...patWarning.js 0 0 0 0 39-61
🟢  ...s/featureFlags 90.9 100 80 90.9
🟡   index.js 66.66 100 66.66 66.66 8
🟢   utils.js 100 100 100 100
🔴  src/mixin 20 0 28.57 20
🔴   ...zableTable.js 20 0 28.57 20 16-31,36-37,42
🔴  src/router 18.42 16.66 10.52 18.42
🔴   index.js 18.42 16.66 10.52 18.42 ...93-194,198-217
🟢  src/store 100 100 100 100
🟢   index.js 100 100 100 100
🔴  src/store/modules 3.58 0 4.72 3.77
🔴   agencies.js 5.26 100 8.33 5.55 13-70
🔴   alerts.js 20 100 20 20 10-24
🔴   grants.js 1.41 0 1.05 1.49 58-352
🔴   organization.js 33.33 100 33.33 33.33 21-25
🔴   roles.js 20 100 20 25 13-22
🔴   tenants.js 11.11 100 14.28 12.5 13-32
🔴   users.js 2.43 0 4.76 2.5 17-100
🔴  src/views 41.26 33.68 30.62 43.03
🔴   ...orterView.vue 25.58 51.85 18.18 26.82 ...,62,84,109-151
🟡   ...boardView.vue 50 17.64 50 52 89-98,114-125
🔴   ...tailsView.vue 31.14 11.76 14 32.2 ...60-521,527-554
🟢   GrantsView.vue 100 100 100 100
🔴   LoginView.vue 34.61 33.33 22.22 36 1,22,57,109-136
🟡   MyGrantsView.vue 77.77 66.66 66.66 77.77 1,69
🟡   ...ofileView.vue 77.27 75 42.85 77.27 1,32,63,130-134
🟢   NotFoundView.vue 100 100 100 100
🔴   ...tionsView.vue 47.05 57.14 41.66 53.33 ...97-100,114-118
🔴   ...ivityView.vue 46.42 23.8 43.75 46.42 ...01,114,120-134
🔴   TeamsView.vue 44.44 88.88 41.66 53.33 1,58,142,156-163
🟡   UsersView.vue 50 66.66 36.36 53.84 ...16-121,133-139
Coverage report for `packages/server`
St File % Stmts % Branch % Funcs % Lines Uncovered Line #s
🟡 All files 58.31 50.73 53.94 58.41
🟢  src 81.63 33.33 60 81.63
🟢   configure.js 81.63 33.33 60 81.63 42,61-68,97-99
🟢  src/arpa_reporter 98.75 66.66 100 98.75
🟢   configure.js 97.36 40 100 97.36 36
🟢   environment.js 100 100 100 100
🟢   use-request.js 100 100 100 100
🔴  src/arpa_reporter/db 38.58 32.92 44.44 40.16
🔴   arpa-subrecipients.js 13.15 4.34 15.38 14.28 23-92
🔴   reporting-periods.js 37.2 46.87 40 38.09 46,77-156
🟢   settings.js 100 83.33 100 100 13
🟡   uploads.js 50 28.57 52.38 51.42 18-29,84,99-124,141-150
🔴  src/arpa_reporter/lib 29.57 33.08 34.56 28.46
🟢   arpa-ec-codes.js 100 100 100 100
🔴   audit-report.js 21.44 19.35 24.19 21.32 ...28-529,554-684,732-758
🟡   ensure-async-context.js 75 100 50 100
🟢   format.js 90.62 90 90 91.3 41-42
🟡   log.js 75 50 50 75 13,25
🟡   preconditions.js 66.66 33.33 100 66.66 3
🔴   spreadsheet.js 9.09 0 0 9.09 15-32
🟢   validation-error.js 85.71 100 50 85.71 16
🔴  src/arpa_reporter/routes 40 14.92 14.28 40.6
🔴   agencies.js 22.58 0 0 23.33 13-21,26-53
🟡   application_settings.js 75 100 0 75 10-11
🟡   audit-report.js 68.91 58.33 100 68.91 57-58,64-78,100-116
🟢   exports.js 81.42 83.33 100 81.42 61-75,98-99
🔴   reporting-periods.js 20 0 0 20.43 ...25-137,143-149,154-180
🔴   subrecipients.js 23.8 0 0 23.8 12-13,17-27,31-48,52-63
🔴   uploads.js 28.28 7.89 9.09 29.16 ...33-154,164-166,173-180
🔴   users.js 19.6 0 0 20 15-35,39-44,48-81
🔴  src/arpa_reporter/services 42.83 30.41 45.71 43.22
🔴   generate-arpa-report.js 36.86 2.79 50 37.24 ...-974,983-996,1070-1137
🔴   get-template.js 21.62 0 0 21.62 18-79
🟡   persist-upload.js 68.6 90 69.56 68.67 ...58-200,221-235,273-295
🔴   records.js 20.75 0 11.11 21.15 38-204,221-276
🔴   revalidate-uploads.js 37.5 100 0 37.5 5-14
🔴   validate-upload.js 38.86 50.6 33.33 39.81 ...20,339,361,379-656,671
🟢   validation-rules.js 98.18 90 90.9 100 157,173
🟡  src/db 74.3 71.42 68.42 74.33
🟢   connection.js 100 50 100 100 6
🟢   constants.js 100 100 100 100
🟡   helpers.js 75 83.33 50 75 5,21-22
🟢   index.js 82.44 78.54 82.08 82.38 ...50-1416,1598-1599,1606
🟢   saved_search_migration.js 92 88.23 71.42 93.61 5,69,134
🔴   tenant_creation.js 10.58 2.7 0 11.11 15-40,48-210,220
🔴  src/db/arpa_reporter_db_shims 23.68 0 0 23.68
🔴   agencies.js 22.22 100 0 22.22 11-51
🔴   users.js 25 0 0 25 12-62
🟢  src/lib 86 79.51 91.42 85.94
🟢   access-helpers.js 93.54 89.18 100 93.54 96-97,102-103
🟢   agencyImporter.js 90.38 88.46 100 90.19 26,29,35,93-94
🟢   email.js 93.78 82.25 100 93.67 ...38,160-164,211,424-427
🔴   [gost-aws.js](h...[Comment body truncated]

Copy link

github-actions bot commented Jul 22, 2024

Terraform Summary

Step Result
🖌 Terraform Format & Style
⚙️ Terraform Initialization
🤖 Terraform Validation
📖 Terraform Plan

Hint: If "Terraform Format & Style" failed, run terraform fmt -recursive from the terraform/ directory and commit the results.

Output

Validation Output
stdout:
Success! The configuration is valid.


-------------------------------------
stderr:

Plan Summary
CHANGE RESOURCE
add module.website.aws_s3_object.origin_dist_artifact["assets/ActivityTable-Cbvppojk.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/ActivityTable-Cbvppojk.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/ArpaAnnualPerformanceReporterView-DLhnvXSp.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/ArpaAnnualPerformanceReporterView-DLhnvXSp.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/DashboardView-lLW11Nc6.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/DashboardView-lLW11Nc6.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/GrantDetailsLegacy-YVKRivZ8.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/GrantDetailsLegacy-YVKRivZ8.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/GrantDetailsView-H-mB8bhP.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/GrantDetailsView-H-mB8bhP.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/GrantsTable-CkEXTOEr.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/GrantsTable-CkEXTOEr.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/GrantsView-D6388Pkq.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/GrantsView-D6388Pkq.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/MyGrantsView-yIOdTscy.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/MyGrantsView-yIOdTscy.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/MyProfileView-ByWVjou4.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/MyProfileView-ByWVjou4.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/NotFoundView-C4O29nWI.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/NotFoundView-C4O29nWI.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/OrganizationsView-CPyDEt1k.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/OrganizationsView-CPyDEt1k.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/RecentActivityView-DaRVBZqt.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/RecentActivityView-DaRVBZqt.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/RecordUploader-BCJsOQNZ.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/RecordUploader-BCJsOQNZ.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/TeamsView-Do7J5J5_.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/TeamsView-Do7J5J5_.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/UsersView-B-6t44Es.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/UsersView-B-6t44Es.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/arpa_reporter-92asy4XY.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/arpa_reporter-92asy4XY.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/form-helpers-DFVjZNWg.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/form-helpers-DFVjZNWg.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/main-BTsUtqTf.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/main-BTsUtqTf.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/style-C1rh3oG0.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/style-C1rh3oG0.js.map"]
update module.api.aws_ecs_service.default[0]
module.api.module.grant_digest_scheduled_task.aws_iam_role_policy.default[0]
module.api.module.grant_digest_scheduled_task.aws_scheduler_schedule.default[0]
module.arpa_audit_report.aws_ecs_service.default
module.arpa_treasury_report.aws_ecs_service.default
module.consume_grants.aws_ecs_service.default
module.postgres.module.db.aws_rds_cluster_instance.this["one"]
module.website.aws_s3_object.deploy-config[0]
module.website.aws_s3_object.origin_dist_artifact["arpa_reporter/index.html"]
module.website.aws_s3_object.origin_dist_artifact["index.html"]
recreate module.api.aws_ecs_task_definition.default[0]
module.arpa_audit_report.aws_ecs_task_definition.consumer
module.arpa_treasury_report.aws_ecs_task_definition.consumer
module.consume_grants.aws_ecs_task_definition.consume_grants
delete module.website.aws_s3_object.origin_dist_artifact["assets/ActivityTable-C0OX1bPl.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/ActivityTable-C0OX1bPl.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/ArpaAnnualPerformanceReporterView-Dx2BFDBR.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/ArpaAnnualPerformanceReporterView-Dx2BFDBR.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/DashboardView-Dxoloxf3.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/DashboardView-Dxoloxf3.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/GrantDetailsLegacy-SeHGl2WA.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/GrantDetailsLegacy-SeHGl2WA.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/GrantDetailsView-YTYZWVBa.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/GrantDetailsView-YTYZWVBa.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/GrantsTable-CMvxRCa9.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/GrantsTable-CMvxRCa9.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/GrantsView-DKQT7WOJ.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/GrantsView-DKQT7WOJ.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/MyGrantsView-Do0Ag6cM.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/MyGrantsView-Do0Ag6cM.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/MyProfileView-CJqESJv0.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/MyProfileView-CJqESJv0.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/NotFoundView-Bb8plESH.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/NotFoundView-Bb8plESH.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/OrganizationsView-e71sZpac.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/OrganizationsView-e71sZpac.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/RecentActivityView-CRZsqh_u.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/RecentActivityView-CRZsqh_u.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/RecordUploader-Bvh9kwd4.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/RecordUploader-Bvh9kwd4.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/TeamsView-C_cKzNcF.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/TeamsView-C_cKzNcF.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/UsersView-CR47r7Gu.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/UsersView-CR47r7Gu.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/arpa_reporter-Bk_8Ojwu.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/arpa_reporter-Bk_8Ojwu.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/form-helpers-C5zh2FXG.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/form-helpers-C5zh2FXG.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/main-C47Zt01J.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/main-C47Zt01J.js.map"]
module.website.aws_s3_object.origin_dist_artifact["assets/style-BLUJUbBk.js"]
module.website.aws_s3_object.origin_dist_artifact["assets/style-BLUJUbBk.js.map"]

Pusher: @TylerHendrickson, Action: pull_request_target, Workflow: Continuous Integration

@TylerHendrickson TylerHendrickson requested a review from as1729 July 22, 2024 21:42
@TylerHendrickson TylerHendrickson merged commit c2e5dc1 into main Jul 25, 2024
19 checks passed
@TylerHendrickson TylerHendrickson deleted the feat/rds-cert-upgrade/staging branch July 25, 2024 21:31
@TylerHendrickson TylerHendrickson added the database-changes Includes schema migrations or other critical changes label Aug 8, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
database-changes Includes schema migrations or other critical changes enhancement New feature or request Infra Issues related to the infrastructure underlying all the tools. terraform Pull requests that update Terraform code
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants