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

Pinpoint pools #1246

Merged
merged 31 commits into from
Apr 22, 2024
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
Show all changes
31 commits
Select commit Hold shift + click to select a range
92cfc1b
add script for now to create pinpoint pools
sastels Apr 10, 2024
620c7d4
add pinpoint logs and iam
sastels Apr 10, 2024
be982f1
mor copy-pasta
sastels Apr 10, 2024
2dc2d4f
Merge branch 'main' into pinpoint-pools
sastels Apr 10, 2024
e75ecde
tweak
sastels Apr 11, 2024
2abdc8e
fix arn
sastels Apr 11, 2024
80437f5
turn off pinpoint logging on dev
sastels Apr 11, 2024
1603e0b
failures working now
sastels Apr 12, 2024
7418845
add pinpoint_to_sqs_sms_callbacks lambda
sastels Apr 12, 2024
3356c7c
add ecr for pinpoint lambda
sastels Apr 12, 2024
fafbcc2
tweak
sastels Apr 15, 2024
2673807
Merge branch 'main' into pinpoint-pools
sastels Apr 15, 2024
2d2fdb4
and new lambda to staging workflows
sastels Apr 15, 2024
7c008a4
fix lambda files
sastels Apr 15, 2024
069937a
script only creates things that don't exist
sastels Apr 15, 2024
4014c52
Merge branch 'main' into pinpoint-pools
sastels Apr 15, 2024
7c3c352
Merge branch 'main' into pinpoint-pools
sastels Apr 16, 2024
755f96c
always create receipt log groups
sastels Apr 16, 2024
3884b71
put pinpoint_to_sqs_sms_callbacks code together
sastels Apr 16, 2024
1f797b1
fix sns_to_sqs_sms_callbacks bootstrap image
sastels Apr 16, 2024
e5a4c31
Merge branch 'main' into pinpoint-pools
sastels Apr 17, 2024
d56acf1
Merge branch 'main' into pinpoint-pools
sastels Apr 17, 2024
0f098a4
move ecr stuff mack to ecr module
sastels Apr 17, 2024
528fe73
Merge branch 'main' into pinpoint-pools
sastels Apr 17, 2024
2c0864e
fix
sastels Apr 17, 2024
bf6818f
Merge branch 'main' into pinpoint-pools
sastels Apr 22, 2024
bf7bd27
Merge branch 'main' into pinpoint-pools
sastels Apr 22, 2024
6628b60
Merge branch 'main' into pinpoint-pools
sastels Apr 22, 2024
5ce907c
run pool creation script
sastels Apr 22, 2024
9b27183
fix copypasta
sastels Apr 22, 2024
68cc48b
dont need bootstrap for script
sastels Apr 22, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
41 changes: 40 additions & 1 deletion aws/common/cloudwatch_log.tf
Original file line number Diff line number Diff line change
Expand Up @@ -44,8 +44,47 @@
}
}

# TODO fix the count line after it's working. Right now we want these in dev for testing
resource "aws_cloudwatch_log_group" "pinpoint_shortcode_deliveries" {
count = var.cloudwatch_enabled ? 1 : 1
name = "sns/${var.region}/${var.account_id}/PinPointShortcodeDirectPublishToPhoneNumber"
retention_in_days = var.sensitive_log_retention_period_days
tags = {
CostCenter = "notification-canada-ca-${var.env}"
}
}
Fixed Show fixed Hide fixed

resource "aws_cloudwatch_log_group" "pinpoint_shortcode_deliveries_failures" {
count = var.cloudwatch_enabled ? 1 : 1
name = "sns/${var.region}/${var.account_id}/PinPointShortcodeDirectPublishToPhoneNumber/Failure"
retention_in_days = var.sensitive_log_retention_period_days

tags = {
CostCenter = "notification-canada-ca-${var.env}"
}
}
Fixed Show fixed Hide fixed

resource "aws_cloudwatch_log_group" "pinpoint_longcode_deliveries" {
count = var.cloudwatch_enabled ? 1 : 1
name = "sns/${var.region}/${var.account_id}/PinPointLongcodeDirectPublishToPhoneNumber"
retention_in_days = var.sensitive_log_retention_period_days
tags = {
CostCenter = "notification-canada-ca-${var.env}"
}
}
Fixed Show fixed Hide fixed

resource "aws_cloudwatch_log_group" "pinpoint_longcode_deliveries_failures" {
count = var.cloudwatch_enabled ? 1 : 1
name = "sns/${var.region}/${var.account_id}/PinPointLongcodeDirectPublishToPhoneNumber/Failure"
retention_in_days = var.sensitive_log_retention_period_days

tags = {
CostCenter = "notification-canada-ca-${var.env}"
}
}
Fixed Show fixed Hide fixed

resource "aws_cloudwatch_log_group" "route53_resolver_query_log" {
count = var.cloudwatch_enabled ? 1 : 0
count = var.cloudwatch_enabled ? 1 : 1
name = "route53/${var.region}/${var.account_id}/DNS/logs"
retention_in_days = var.log_retention_period_days

Expand Down
46 changes: 46 additions & 0 deletions aws/common/iam.tf
Original file line number Diff line number Diff line change
Expand Up @@ -189,3 +189,49 @@ data "aws_iam_policy_document" "firehose_waf_logs" {
resource "aws_iam_service_linked_role" "spotInstances" {
aws_service_name = "spot.amazonaws.com"
}

# Pinpoint IAM

resource "aws_iam_role" "pinpoint_logs" {
name = "PinpointLogs"
assume_role_policy = data.aws_iam_policy_document.pinpoint_assume.json
}

resource "aws_iam_policy" "pinpoint_logs" {
name = "PinpointLogsPolicy"
path = "/"
policy = data.aws_iam_policy_document.pinpoint_logs.json
}

resource "aws_iam_role_policy_attachment" "pinpoint_logs" {
role = aws_iam_role.pinpoint_logs.name
policy_arn = aws_iam_policy.pinpoint_logs.arn
}

data "aws_iam_policy_document" "pinpoint_assume" {
statement {
actions = ["sts:AssumeRole"]
effect = "Allow"
principals {
type = "Service"
identifiers = ["sms-voice.amazonaws.com"]
}
}
}

data "aws_iam_policy_document" "pinpoint_logs" {
statement {
effect = "Allow"
actions = [
"logs:CreateLogStream",
"logs:DescribeLogStreams",
"logs:PutLogEvents"
]
resources = [
aws_cloudwatch_log_group.pinpoint_shortcode_deliveries[0].arn,
aws_cloudwatch_log_group.pinpoint_shortcode_deliveries_failures[0].arn,
aws_cloudwatch_log_group.pinpoint_longcode_deliveries[0].arn,
aws_cloudwatch_log_group.pinpoint_longcode_deliveries_failures[0].arn
]
}
}
19 changes: 19 additions & 0 deletions scripts/create_pinpoint_pools.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
#!/bin/bash

# Create 2 numbers to use to create the pools

number1=`aws pinpoint-sms-voice-v2 request-phone-number --iso-country-code CA --message-type TRANSACTIONAL --number-capabilities SMS --number-type LONG_CODE | jq -r ".PhoneNumberId"`
number2=`aws pinpoint-sms-voice-v2 request-phone-number --iso-country-code CA --message-type TRANSACTIONAL --number-capabilities SMS --number-type LONG_CODE | jq -r ".PhoneNumberId"`

# Create pools for the shortcode and longcodes

aws pinpoint-sms-voice-v2 create-pool --origination-identity $number1 --iso-country-code CA --message-type TRANSACTIONAL --tags Key=Name,Value=shortcode-pool
aws pinpoint-sms-voice-v2 create-pool --origination-identity $number2 --iso-country-code CA --message-type TRANSACTIONAL --tags Key=Name,Value=longcode-pool

# Create configuration sets

aws pinpoint-sms-voice-v2 create-configuration-set --configuration-set-name shortcode-configuration
aws pinpoint-sms-voice-v2 create-configuration-set --configuration-set-name longcode-configuration

# need to associate the configuration sets with CloudWatch log groups and / or SNS topics

Loading