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

Separate PCA instances in one AWS Account #213

Open
hyde-mattholgate opened this issue Nov 14, 2023 · 8 comments
Open

Separate PCA instances in one AWS Account #213

hyde-mattholgate opened this issue Nov 14, 2023 · 8 comments
Assignees
Labels
feature - on roadmap This feature is on the roadmap.

Comments

@hyde-mattholgate
Copy link

Is it possible to deploy multiple instances of the PCA CloudFormation stack in one account? We are currently getting CloudFormation deploy errors when trying to deploy a second instance of the CloudFormation stack in an account. Both instances have Kendra enabled which might be causing the issue.

@MikeGrande
Copy link

I had asked the same thing and per a week ago was told(by AWS) because of conflicts on resources its one PCA deployment per account.

@chrislott
Copy link
Contributor

Thanks both - we have put this on the roadmap for an upcoming release.

@hyde-mattholgate
Copy link
Author

Thanks both for the replies.

Chris would it be possible to tell me the exact resources used in the CloudFormation stacks that have the conflicts? We are looking to see if we can get multiple instances working ourselves by amending the CloudFormation.

@chrislott
Copy link
Contributor

It is all the ssm parameters found in the pca-ssm/cfn template. The issue is they have hardcoded names.

The way I plan on fixing this is by passing the name of the main stack to this nested stack, and prepending the stack name to the parameter names. This will guarantee a unique parameter store name.

I will also pass the main stack name to all the nested stacks and Lambda functions that read from those parameters, so they can find the correct parameter for their PCA application.

If you are able to get to it, we would love a pull request! 😀

@hyde-mattholgate
Copy link
Author

hyde-mattholgate commented Nov 27, 2023

Hi @chrislott I have submitted an initial PR to create a parameter for the main stack name and to preprend this stack name to the first resource in ssm.template

Please could you review and let me know if this is along the correct lines for what you meant and if so I can amend all the SSM parameters and look at passing the name to the nested stacks and Lambdas. This is one of my first times writing CloudFormation (more of a Terraform person ...) so my syntax might be slightly off, for example for the new resource name in the SSM template I was not sure about the quotation marks: Name: !Sub "'${MainStackName}'-BulkUploadBucket"

Also - do you know which lambdas will need the MainStackName parameter passing to them or do you know an easy way of finding out?

Thanks

@chrislott
Copy link
Contributor

Hi @hyde-mattholgate ,

Happy new year! Just reviewed the PR, and this is exactly what I would do. The next step is to make sure all the Lambda functions also have the main stack name as an env variable, and that the code is modified to read the specific parameter for that stack. If you're able to add this to your PR, I will accept and merge it in. If not, no worries, as this is one of our priorities for an upcoming release.

Chris

@chrislott chrislott added the feature - on roadmap This feature is on the roadmap. label Jan 17, 2024
@akashbhandari999
Copy link

Hi @chrislott
Is there any update on this?

@rstrahan
Copy link
Contributor

Hi @akashbhandari999 - sorry for the delays.. @chrislott has left AWS
@kishd - can you pick up this thread? IMHO this is well worth fixing, since it's reasonable, and common, for people to attempt multiple PCA deployments in a single account add region.
I will close the related PR #216 for now since a) it has conflicts, and b) i feel it's a partial (non functioning) solution since it doesn;t include matching updates for the various Cfn templates that consume the hardcoded SSM parameter names as nested stack parameters. We need a new PR that addresses the whole solution holistically.

@rstrahan rstrahan assigned kishd and unassigned chrislott Aug 12, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feature - on roadmap This feature is on the roadmap.
Projects
None yet
Development

No branches or pull requests

6 participants