Code Signing for Lambda
Description
AWS Signer is a fully managed code-signing service to ensure the trust and integrity of a code. Organizations validate code against a digital signature to confirm that the code is unaltered and from a trusted publisher. With AWS Signer, security administrators have a single place to define the signing environment, including what AWS Identity and Access Management (IAM) role can sign code and in what regions. AWS Signer manages the code-signing certificate public and private keys and enables central management of the code-signing lifecycle.
Solution Schema
data:image/s3,"s3://crabby-images/15350/153504f7e24e4fc4f28ee3da163aa05aa00e1518" alt="signer"
Configs - Lambda (#1)
1.Lambda code
Create simple lambda and save it in lambda_function.py file
def lambda_handler(event, context): print ('\n\n****************************') print ("Hi, I'm Lambda") print ("more interesting stuff can be found at https://www.radkowski.pro/howtos") print ('\n\n****************************')
2.Lambda zip file
Create zip package
data:image/s3,"s3://crabby-images/5a157/5a157d3165cff1e98299b3d0c47456e5a1256db7" alt="l1"
Configs - S3 (#1)
3.Create S3 Bucket
Using AWS S3 Console, create S3 bucket to store ziped code
data:image/s3,"s3://crabby-images/384fd/384fd3951f8e56ee0fb54c091494b9725a25f3ec" alt="s1"
4.Upload ziped Lambda
Upload zip file created in step #2
data:image/s3,"s3://crabby-images/a92cd/a92cdd1ae9852b3a240015ca8aa8cfbafe07f11f" alt="s2"
5.Lambda S3 URI
Using object overview tab, copy object S3 URI
data:image/s3,"s3://crabby-images/f21d1/f21d1fc013d5bf0f32f55287436c84c2175a100d" alt="s3"
Configs - AWS Signer
6.Signing Profile
Using AWS Console, open AWS Signer. Next, create new Signing Profile
data:image/s3,"s3://crabby-images/be2ad/be2ada6507dc153e8fc37fae8f118fe5e5c8b123" alt="sig1"
7.Signing Job (#1)
Open AWS Signer Console, create a new Signing Job. Provide information about source lambda zip S3 URI (captured in step #5), lambda version, and destination S3 bucket/folder.
data:image/s3,"s3://crabby-images/97381/97381d159770f130bdb2264d3775dd7d7d7b3bca" alt="sig3"
8.Signing Job (#2)
Oncej ob started, you should see status In Progress
data:image/s3,"s3://crabby-images/501f5/501f57736bf404b2457aa3e9e60c79c49cbe2d6c" alt="sig4"
9.Signing Job (#3)
Status Succeeded confirms, that lambda has been signed successfully.
data:image/s3,"s3://crabby-images/c0df5/c0df529a42320dbcae2042de5f8cac4c90a084a5" alt="sig5"
Configs - S3 (#2)
10.Siged Lambda (#1)
Come back to S3 Console. You should see another file that represents the signed Lambda zip file.
data:image/s3,"s3://crabby-images/c00c4/c00c4e62d599e4b196eded22bc67c98429851334" alt="ss1"
11.Siged Lambda (#2)
Collect Signed Lambda object URL
data:image/s3,"s3://crabby-images/26f1b/26f1b333754f55f335c1ba384f6a3856ef90199f" alt="ss2"
Configs - Lambda (#2)
12.Signing Configuration
Use AWS Console to select Lambda service. nest select Code signing Configuration to create a new config. Select Signing Profile created in step #6 as well as prefered validation policy.
data:image/s3,"s3://crabby-images/28b1f/28b1f251e47490a54e1853b81f7331463edc3176" alt="ll1"
13.Create new Lambda function
Using Lambda Console, create new Lambda (Author from scratch).
data:image/s3,"s3://crabby-images/8c417/8c4175dbe1f7e7c1151e0fcb60ab933df7b03de7" alt="ll2"
14.Enable Code Signing (#1)
Update configuration for previously created lambda - edit Code Signing section
data:image/s3,"s3://crabby-images/5317f/5317f8245f456d1952f2dfb461d6fc202e63fe11" alt="ll3"
15.Enable Code Signing (#2)
Select Code Signing Configuration created in step #12
data:image/s3,"s3://crabby-images/0fbb3/0fbb3d20b2172a1ed7b44d31c8589bfedfc35801" alt="ll4"
16.Enable Code Signing (#3)
Come back to Lambda settings and upload the signed lambda zip file captured in step #11. Bear in mind, that you will not be able to modify lambda code directly, as it's already configured to use code signing.
data:image/s3,"s3://crabby-images/69c31/69c313543bb1a6683518860d0145a490277e9364" alt="ll5"
17.Upload signed lambda
Lambda has been uploaded successfully. As it has been signed, inline editing is no longer available.
data:image/s3,"s3://crabby-images/57c5e/57c5ee0449ba9dc30eedb5795f1bd74bebb77e0e" alt="ll6"
Test Area
18.Signed lambda test
Using Lambda Console, execute the test to confirm that Lambda works as expected.
data:image/s3,"s3://crabby-images/54fdb/54fdb9ad96dc6e39b7800e52310fcb5d30f635b1" alt="t1"
19.Nonsigned lambda test
As validation policy (step #12) has been set to Enforce, try to upload non signed lambda will fail.
data:image/s3,"s3://crabby-images/fe738/fe738432288beae24e7d05fec171ba26221f4710" alt="t2"