AWS Secrets Manager
Hands-On
Demo
data:image/s3,"s3://crabby-images/5eb98/5eb9895ff9b960ce3cba7a98b87c0d0e57ddef7a" alt=""
Agenda
In this demo, we will:
- Create a secret in AWS Secrets Manager
- Retrieve and use the secret
- Create a Lambda function to access the secret
- Test the Lambda function
- Clean up resources
data:image/s3,"s3://crabby-images/55f2c/55f2ca33299cf59dcc6e61a749b13746b3b93b9c" alt=""
Demo Overview
data:image/s3,"s3://crabby-images/2a74d/2a74d10a514b1901cf4ca921c01bad359c028e32" alt=""
Choose secret type
admin
MySecurePassword123!
data:image/s3,"s3://crabby-images/14c24/14c24d13c2c439ce0a3ee3e1dbde110c3b930229" alt=""
data:image/s3,"s3://crabby-images/a9095/a9095949dae8d5ad0a2fadb4a2d0926fbbc66b3a" alt=""
Secret name and description
demo/db/credentials
data:image/s3,"s3://crabby-images/39b32/39b32f1a011a138226ac9ca72c2f1d808516cc6d" alt=""
data:image/s3,"s3://crabby-images/997f3/997f3ecf4377a6305110ac0429c01a1845fe60ec" alt=""
data:image/s3,"s3://crabby-images/955c1/955c14c156cf20b48c0f1808bd80894f3cfeb9fa" alt=""
data:image/s3,"s3://crabby-images/977d0/977d030e5f998237f1f675681b6841f41895a69c" alt=""
data:image/s3,"s3://crabby-images/6eaae/6eaae2121b5907233755a68e26c29b6130eaccf8" alt=""
Review
data:image/s3,"s3://crabby-images/d7ef3/d7ef38ce7f301ea12863cc0c93cfe0ca88132a27" alt=""
Secret configuration
data:image/s3,"s3://crabby-images/7b926/7b9265f37b621dca6770badaa0e3d27e10affa03" alt=""
Rotation schedule
data:image/s3,"s3://crabby-images/2a6c8/2a6c8eacec13114211205b6c73dd839bcc7a1e74" alt=""
data:image/s3,"s3://crabby-images/53752/537528bbf35f663a212df7a8908e59355098bc70" alt=""
Secrets List
data:image/s3,"s3://crabby-images/9f1b8/9f1b8215962e16c01064c658a89c52baeff94e2a" alt=""
Retrieve and view the secret value.
data:image/s3,"s3://crabby-images/31b73/31b73567a053c27c2b008f50ce5d03c0946fa208" alt=""
Create Lambda function
SecretsManagerDemo
data:image/s3,"s3://crabby-images/87589/8758938a147d2d365fd603169a8d2a94f163a9cd" alt=""
data:image/s3,"s3://crabby-images/6a325/6a325c1904ef523fad5dec17bfe6a6bb3d3b1da0" alt=""
data:image/s3,"s3://crabby-images/c3337/c333745ad44340658536d90b854a0270d6f54f25" alt=""
import json
import boto3
from botocore.exceptions import ClientError
def get_secret():
secret_name = "demo/db/credentials"
region_name = "us-east-1"
# Create a Secrets Manager client
session = boto3.session.Session()
client = session.client(
service_name='secretsmanager',
region_name=region_name
)
try:
get_secret_value_response = client.get_secret_value(
SecretId=secret_name
)
except ClientError as e:
# For a list of exceptions thrown, see
# https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_GetSecretValue.html
raise e
# Decrypts secret using the associated KMS key.
secret = get_secret_value_response['SecretString']
# Parse the JSON string into a Python dictionary
return json.loads(secret)
def lambda_handler(event, context):
try:
secret_dict = get_secret()
# Print the entire secret structure for debugging
print(f"Secret structure: {json.dumps(secret_dict)}")
# In this case, the username is the key and the password is the value
username = list(secret_dict.keys())[0]
password = secret_dict[username]
return {
'statusCode': 200,
'body': json.dumps(f"Successfully retrieved secret. Username: {username}, Password: {password}")
}
except Exception as e:
print(f"Error: {str(e)}")
return {
'statusCode': 500,
'body': json.dumps(f"Error retrieving secret: {str(e)}")
}
data:image/s3,"s3://crabby-images/558da/558da1469772b18ad786abac1a1341e9d6510eaf" alt=""
Edit Execution role
data:image/s3,"s3://crabby-images/2e5f6/2e5f66fcab0dda2b52977f6da12ffc735b4f93b0" alt=""
SecretsManagerDemo-role
data:image/s3,"s3://crabby-images/4b861/4b86106b414412066056534c56e1c501cf62e6a7" alt=""
data:image/s3,"s3://crabby-images/8ce98/8ce98b1ec9ee675d862d45580af0ec87d58f2c1c" alt=""
Manually Create Inline Policy
data:image/s3,"s3://crabby-images/0dbce/0dbce21c2c6dc169e7db339830da2e47eb077532" alt=""
Copy Paste the Secrets Manager Secret's ARN
data:image/s3,"s3://crabby-images/8ce98/8ce98b1ec9ee675d862d45580af0ec87d58f2c1c" alt=""
data:image/s3,"s3://crabby-images/b0444/b04443b82f087bc6e8217d38a60f65d1dff7bafe" alt=""
data:image/s3,"s3://crabby-images/7380d/7380d658f5063e92873ed082255cad82bbdb476e" alt=""
data:image/s3,"s3://crabby-images/c2907/c29070c00cfbcafa8d252c272abe72181897ed3a" alt=""
data:image/s3,"s3://crabby-images/1d494/1d4942c21eefb91b433fb07b2379d9fc8f18074c" alt=""
SecretsManagerDemoPolicy
Review and create
data:image/s3,"s3://crabby-images/51c0c/51c0cbde92b0fa85486fe2169a4dbd85f05f7cec" alt=""
data:image/s3,"s3://crabby-images/ca7f3/ca7f3e8aadb66b0a67da407a738743a8421a5153" alt=""
Test the Lambda Function
data:image/s3,"s3://crabby-images/6826a/6826afcca5a37aadc88fa9f7a386973e1ee72c1b" alt=""
Execution Result
Clean Up
data:image/s3,"s3://crabby-images/bf1b3/bf1b31c93b2e382b0f71e391977b138286e5b652" alt=""
Delete secret
data:image/s3,"s3://crabby-images/58f7a/58f7ae3b58213c31a4022caef4c2d2f1a941938a" alt=""
data:image/s3,"s3://crabby-images/3d337/3d337413bfdb488dda7681fc2d7076b23aa3c3b7" alt=""
Delete function
data:image/s3,"s3://crabby-images/399b5/399b5888508935d6e0a77576a479a728333801cd" alt=""
data:image/s3,"s3://crabby-images/5a065/5a065d7ea20c59b14ffe72c3b5dd7cb19ad6f08d" alt=""
Delete Lambda Execution Role
data:image/s3,"s3://crabby-images/351db/351db23f8a19c0abf3bf070a88ef912d2e155c28" alt=""
🙏
Thanks
for
Watching
AWS Secrets Manager - Hands-On Demo
By Deepak Dubey
AWS Secrets Manager - Hands-On Demo
AWS Secrets Manager - Hands-On Demo
- 196