From dc68681a81ac88284f3340f9361ac2ae469d714f Mon Sep 17 00:00:00 2001 From: ingalls Date: Sun, 20 Oct 2024 15:20:30 -0600 Subject: [PATCH] Use AccessPoints --- cloudformation/lib/api.js | 38 ++++++++++++++++++++++++++++++++++---- cloudformation/lib/efs.js | 36 ++++++++++++++++++++++++++++++++++++ 2 files changed, 70 insertions(+), 4 deletions(-) diff --git a/cloudformation/lib/api.js b/cloudformation/lib/api.js index c5df1b1..fa5172f 100644 --- a/cloudformation/lib/api.js +++ b/cloudformation/lib/api.js @@ -148,7 +148,11 @@ export default { }, TaskDefinition: { Type: 'AWS::ECS::TaskDefinition', - DependsOn: ['LDAPMasterSecret'], + DependsOn: [ + 'LDAPMasterSecret', + 'EFSAccessPointLDAP', + 'EFSAccessPointSLAPD' + ], Properties: { Family: cf.stackName, Cpu: 1024, @@ -162,9 +166,24 @@ export default { ExecutionRoleArn: cf.getAtt('ExecRole', 'Arn'), TaskRoleArn: cf.getAtt('TaskRole', 'Arn'), Volumes: [{ - Name: cf.stackName, + Name: cf.join([cf.stackName, '-ldap']), EFSVolumeConfiguration: { - FilesystemId: cf.ref('EFS') + FilesystemId: cf.ref('EFS'), + TransitEncryption: 'ENABLED', + AuthorizationConfig: { + AccessPointId: cf.ref('EFSAccessPointLDAP') + }, + RootDirectory: '/' + } + },{ + Name: cf.join([cf.stackName, '-slapd']), + EFSVolumeConfiguration: { + FilesystemId: cf.ref('EFS'), + TransitEncryption: 'ENABLED', + AuthorizationConfig: { + AccessPointId: cf.ref('EFSAccessPointSLAPD') + }, + RootDirectory: '/' } }], ContainerDefinitions: [{ @@ -172,7 +191,10 @@ export default { Image: cf.join([cf.accountId, '.dkr.ecr.', cf.region, '.amazonaws.com/coe-ecr-auth:', cf.ref('GitSha')]), MountPoints: [{ ContainerPath: '/var/lib/ldap', - SourceVolume: cf.stackName + SourceVolume: cf.join([cf.stackName, '-ldap']), + }, { + ContainerPath: '/etc/ldap/slapd.d', + SourceVolume: cf.join([cf.stackName, '-slapd']), }], PortMappings: [{ ContainerPort: 389 @@ -248,6 +270,14 @@ export default { API: { Description: 'API ELB', Value: cf.join(['http://', cf.getAtt('ELB', 'DNSName')]) + }, + LDAPAdminUsername: { + Description: 'LDAP Admin Username', + Value: cf.sub('{{resolve:secretsmanager:${AWS::StackName}/admin:SecretString:username:AWSCURRENT}}') + }, + LDAPAdminPassword: { + Description: 'LDAP Admin Password', + Value: cf.sub('{{resolve:secretsmanager:${AWS::StackName}/admin:SecretString:password:AWSCURRENT}}') } } }; diff --git a/cloudformation/lib/efs.js b/cloudformation/lib/efs.js index 20a03a8..fac6d0e 100644 --- a/cloudformation/lib/efs.js +++ b/cloudformation/lib/efs.js @@ -26,6 +26,42 @@ export default { }] } }, + EFSAccessPointLDAP: { + Type: 'AWS::EFS::AccessPoint', + Properties: { + FileSystemId: cf.ref('EFS'), + PosixUser: { + Uid: 0, + Gid: 0 + }, + RootDirectory: { + CreationInfo: { + OwnerGid: 0, + OwnerUid: 0, + Permissions: '0777' + }, + Path: '/ldap' + }, + } + }, + EFSAccessPointSLAPD: { + Type: 'AWS::EFS::AccessPoint', + Properties: { + FileSystemId: cf.ref('EFS'), + PosixUser: { + Uid: 0, + Gid: 0 + }, + RootDirectory: { + CreationInfo: { + OwnerGid: 0, + OwnerUid: 0, + Permissions: '0777' + }, + Path: '/slapd.d' + }, + } + }, EFSMountTargetSubnetPrivateA: { Type: 'AWS::EFS::MountTarget', Properties: {