Skip to content

Latest commit

 

History

History
89 lines (74 loc) · 2.7 KB

Readme.md

File metadata and controls

89 lines (74 loc) · 2.7 KB

DynamoDB

  1. Create a table

Role (Lambda/Dynamo access)

  1. Create a role
  2. add policy with access to execute lambda
  3. add policy with dynamodb access

Lambda

  1. Create new lambda function
  2. Use the existing role
  3. Select runtime
  4. Load code
    1. Set CORS in your APP (OPTIONAL)
    2. Use SDK to hanlde DynamoDB
  5. Set handler
    1. example: AWSServerlessDemo1::AWSServerlessDemo1.LambdaEntryPoint::FunctionHandlerAsync
    2. Assembly::Namespace.Namespace::Class

Api Gateway

  1. Type: REST API
  2. Endpoint type: Regional
  3. Create a method
    1. Type: ANY
    2. Method request: lambda arn
    3. Integration request: LAMBDA_PROXY
    4. Method response: application/json
    5. HTTP Status: PROXY
  4. Create resource
    1. Check as a PROXY
    2. Set lambda name or arn
    3. Enable CORS
  5. Create a method within last resource
    1. Type: ANY
    2. Method request: lambda arn
    3. Integration request: LAMBDA_PROXY
    4. Method response: application/json
    5. HTTP Status: PROXY
  6. Deploy all configurations to required environments
  7. OPTIONAL: you can ser WEB ACL
  8. Set CORS rules

S3

  1. Create s3
  2. Permissions -> Public access - > Block public access to buckets and objects granted through new public bucket or access point policies (ON)
  3. Add policy
    1. Effect: Allow
    2. Principal: "AWS": "arn:aws:iam::cloudfront:user/CloudFront Origin Access Identity EXXXXXXXXXX"
    3. Action: s3:GetObject
    4. Resource: "arn:aws:s3:::<BUCKET_NAME>/*"
  4. Load files

Clouf Front

  1. Create a new one
  2. Type: WEB
  3. Origin Domain Name:
  4. Restict bucket access: yes
  5. View protocol policy: HTTP and HTTPS
  6. AWS WAF Web ACL: (pending)
  7. SSL Certificate Default CloudFront Certificate (...cloudfront.net)
  8. Default Root Object index.html
  9. Edit origins
    1. set origin: s3 name
    2. Restict bucket access: yes
    3. Origin Access Identity: Existing
    4. Identity: CloudFront OAI for aim Frontend S3
    5. Grant Read Permissions on Bucket: No
  10. Origin Access Identity is the id that you must use for set principal arn in your s3

WAF

  1. Create new one
  2. Type: CloudFront distribution
  3. Select last Cloud Front service
  4. Add rules

Sources

AWS Policy Generator Allow access to CloudFront S3 bucket from another account Policy Permissions Restricting Access to Amazon S3 Amazon S3 bucket only from a CloudFront distribution