/aws-service-catalog-enforce-template-constraints

Lambda function to freeze EC2 instance creation to t2.medium/small for Service Catalog portfolios

Primary LanguagePythonMIT No AttributionMIT-0

aws-service-catalog-enforce-template-constraints

A lambda function written in Python to freeze EC2 instance creation to t2.medium/small for Service Catalog portfolios

Pre-Requisite: You have already created an SNS Topic tied to the Budgets Alert

This is how you do it:https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/budgets-sns-policy.html

Go to Lambda Console -> Create-Function->Author From Scratch->Add Trigger->Select SNS -> Choose the correct SNS (the one you created for Budgets Alert) from the list->Check the Enable Trigger on the same page

alt text

It should look like this:

alt text

Click Next -> Enter a name for the function-> In the Description, enter "Enforce Template Constraints for ServiceCatalog -> Choose Python2.7 as RunTime-> Paste the contents of enforce-template-constraints.py in the Lambda Function Code block -> Enter lambda_function.lambda_handler in the Handler-> Create a custom role. Name it service-catalog-lambda-role->Enter the following policy


{
    "Version": "2012-10-17",
    "Statement": [
        {
            "Action": [
                "servicecatalog:*",
                "s3:*",
                "cloudformation:ValidateTemplate",
                "iam:GetRole"
            ],
            "Resource": [
                "*"
            ],
            "Effect": "Allow"
        },
        {
            "Action": [
                "logs:CreateLogGroup",
                "logs:CreateLogStream",
                "logs:PutLogEvents"
            ],
            "Resource": "arn:aws:logs:*:*:*",
            "Effect": "Allow"
        }
    ]
}

On the Configure function page-> choose Next-> Review the configuration settings before choosing Create function

alt text

License Summary

This sample code is made available under the MIT-0 license. See the LICENSE file.