Greengrass: Credentials in a Recipe Component

0

Hello,

What's the best practice for embedding credentials in a Greengrass Recipe Component configuration. I have a recipe that includes:

    Lifecycle:
      Install: pip3 install -r {artifacts:decompressedPath}/ComponentName/requirements.txt --extra-index-url=https://${USERNAME}:${PASSWORD}@company.jfrog.io/artifactory/api/pypi/company-pypi/simple

I'm not sure how best to make ${USERNAME} and ${PASSWORD} available during the install phase. Initially I was hoping to use the Secrets Manager component, but that'd require using the IoT SDK within the component code.

Thanks!

질문됨 10달 전290회 조회
1개 답변
0
수락된 답변

Use of SecretsManager provides secure way to provide credentials to Greengrass components.

You can use https://github.com/awslabs/aws-greengrass-labs-secretsmanagerclient to avoid having to code the interaction with the IPC API and be able to retrieve the secret directly in the lifecycle script.

An example on how to use it can be seen in https://github.com/awslabs/aws-greengrass-labs-nodered-auth/blob/9ff4371f76298aabeb9b4bb736fa86028ae6f09c/recipe.yaml#L35.

For your specific exmaple, the lifecyle recipe would contain something like:

Lifecycle:
    Install: |- 
        export USERNAME="{configuration:/USERNAME}"
        export PASSWORD=$(java -jar {aws.greengrass.labs.SecretsManagerClient:artifacts:path}/secrets.jar {configuration:/USERNAME})
        pip3 install -r {artifacts:decompressedPath}/ComponentName/requirements.txt --extra-index-url=https://${USERNAME}:${PASSWORD}@company.jfrog.io/artifactory/api/pypi/company-pypi/simple
AWS
전문가
답변함 10달 전
  • Awesome, thanks! I ended up not using the SecretsManagerClient but used it as inspiration for a custom implementation using the main SecretManager component and IPC client.

로그인하지 않았습니다. 로그인해야 답변을 게시할 수 있습니다.

좋은 답변은 질문에 명확하게 답하고 건설적인 피드백을 제공하며 질문자의 전문적인 성장을 장려합니다.

질문 답변하기에 대한 가이드라인

관련 콘텐츠