System Manager Automation Document restriction to use the S3 PutObject

0

I'm trying to put up a reporting feature that utilises couple of AWS API calls done via the aws:executeAwsApi automation action. When getting to the PutObject operation, there is an error which doesn't seem to be described very well:

Step fails when it is Execute/Cancelling action. PutObject API is not supported. Please refer to Automation Service Troubleshooting Guide for more diagnosis details.

The FailureType is Verification , FailureStage is Invocation and the VerificationErrorMessage is PutObject API is not supported. I can't seem to find any reference about this neither in the System Manager Automation Troubleshooting Guide https://docs.aws.amazon.com/systems-manager/latest/userguide/automation-troubleshooting.html , nor in the aws:executeAwsApi page https://docs.aws.amazon.com/systems-manager/latest/userguide/automation-action-executeAwsApi.html

I know how to achieve the goal using boto3 and Lambda, but in the current case I'm trying to reach the end goal via SSM automation document. If there is a limitation to use certain API actions, why is this not in the docs (or I can't seem to find it)?

asked a year ago903 views
2 Answers
1

It's possible that the restriction on using the S3 PutObject operation in System Manager Automation documents is not explicitly documented. However, there are some limitations to what AWS API operations can be used in Automation documents, and it's possible that PutObject is one of them.

One way to work around this limitation would be to use a Lambda function instead of an Automation document, as you mentioned. Another option would be to use the AWS CLI command "aws s3 cp" instead of PutObject to copy the file to an S3 bucket. You can use the "aws:executeAwsApi" action to run the CLI command.

Here's an example of how to use "aws s3 cp" in an Automation document:

{
  "description": "Copy a file to S3",
  "schemaVersion": "0.3",
  "assumeRole": "{{ assumeRole }}",
  "mainSteps": [
    {
      "name": "CopyFileToS3",
      "action": "aws:executeAwsApi",
      "inputs": {
        "Service:": "ssm",
        "Api": "runShellScript",
        "Parameters": {
          "commands": [
            "aws s3 cp /path/to/local/file s3://my-bucket/path/to/destination/file"
          ]
        }
      }
    }
  ]
}

This example assumes that you have already configured your AWS CLI credentials on the instance where the Automation document will be run. If you need to specify credentials, you can add them to the "commands" parameter using the "--profile" option.

I hope this helps! Let me know if you have any further questions.

hash
answered a year ago
0

This is a valid solution if you are running the automation over an instance. However, I'm trying to run it with a target of AWS account (no EC2 involved), with a role that I supply externally. I made it work, using boto3 as a wrapper of the last action of publishing the report to S3 (again, I didn't want to utilise Lambda to full extend in this solution). The final step looks like this:

def script_handler(events, context):
          import boto3
          import json
          data = events['json']
          s3 = boto3.client('s3')
          file = json.dumps(data)
          s3.put_object(Body=file,Bucket='sample-bucket',Key='report.json')

This is aws:executeScript step where I provide the json input from the output of last step, similar to this:

inputpayload: json: '{{jstepName.stepOutput}}'

As a final word, I also managed to decode the official docs. There is a word about streaming operations (like PutObject): Most API operations are supported, although not all API operations have been tested. Streaming API operations, such as the GetObject operation, aren't supported. If you're not sure if an API operation you want to use is a streaming operation, review the Boto3 documentation for the service to determine if an API requires streaming inputs. https://docs.aws.amazon.com/systems-manager/latest/userguide/automation-action-executeAwsApi.html

answered a year ago

You are not logged in. Log in to post an answer.

A good answer clearly answers the question and provides constructive feedback and encourages professional growth in the question asker.

Guidelines for Answering Questions