Returns all Systems Manager (SSM) documents in the current Amazon Web Services account and Amazon Web Services Region. You can limit the results of this request by using a filter.
See also: AWS API Documentation
list-documents is a paginated operation. Multiple API calls may be issued in order to retrieve the entire data set of results. You can disable pagination by providing the --no-paginate argument.
When using --output text and the --query argument on a paginated response, the --query argument must extract data from the results of the following query expressions: DocumentIdentifiers
  list-documents
[--document-filter-list <value>]
[--filters <value>]
[--cli-input-json | --cli-input-yaml]
[--starting-token <value>]
[--page-size <value>]
[--max-items <value>]
[--generate-cli-skeleton <value>]
[--debug]
[--endpoint-url <value>]
[--no-verify-ssl]
[--no-paginate]
[--output <value>]
[--query <value>]
[--profile <value>]
[--region <value>]
[--version <value>]
[--color <value>]
[--no-sign-request]
[--ca-bundle <value>]
[--cli-read-timeout <value>]
[--cli-connect-timeout <value>]
[--cli-binary-format <value>]
[--no-cli-pager]
[--cli-auto-prompt]
[--no-cli-auto-prompt]
--document-filter-list (list)
This data type is deprecated. Instead, use
Filters.Constraints:
- min:
1(structure)
This data type is deprecated. Instead, use DocumentKeyValuesFilter .
key -> (string) [required]
The name of the filter.
Possible values:
Name
Owner
PlatformTypes
DocumentTypevalue -> (string) [required]
The value of the filter.
Constraints:
- min:
1
Shorthand Syntax:
key=string,value=string ...
JSON Syntax:
[
  {
    "key": "Name"|"Owner"|"PlatformTypes"|"DocumentType",
    "value": "string"
  }
  ...
]
--filters (list)
One or more
DocumentKeyValuesFilterobjects. Use a filter to return a more specific list of results. For keys, you can specify one or more key-value pair tags that have been applied to a document. Other valid keys includeOwner,Name,PlatformTypes,DocumentType, andTargetType. For example, to return documents you own useKey=Owner,Values=Self. To specify a custom key-value pair, use the formatKey=tag:tagName,Values=valueName.Note
This API operation only supports filtering documents by using a single tag key and one or more tag values. For example:Key=tag:tagName,Values=valueName1,valueName2Constraints:
- min:
0- max:
6(structure)
One or more filters. Use a filter to return a more specific list of documents.
For keys, you can specify one or more tags that have been applied to a document.
You can also use Amazon Web Services-provided keys, some of which have specific allowed values. These keys and their associated values are as follows:
DocumentType
ApplicationConfiguration
ApplicationConfigurationSchema
Automation
ChangeCalendar
Command
Package
Policy
SessionOwner
Note that only one
Ownercan be specified in a request. For example:Key=Owner,Values=Self.
Amazon
Private
Public
Self
ThirdPartyPlatformTypes
Linux
Windows
Nameis another Amazon Web Services-provided key. If you useNameas a key, you can use a name prefix to return a list of documents. For example, in the Amazon Web Services CLI, to return a list of all documents that begin withTe, run the following command:
aws ssm list-documents --filters Key=Name,Values=TeYou can also use the
TargetTypeAmazon Web Services-provided key. For a list of valid resource type values that can be used with this key, see Amazon Web Services resource and property types reference in the CloudFormation User Guide .If you specify more than two keys, only documents that are identified by all the tags are returned in the results. If you specify more than two values for a key, documents that are identified by any of the values are returned in the results.
To specify a custom key-value pair, use the format
Key=tag:tagName,Values=valueName.For example, if you created a key called region and are using the Amazon Web Services CLI to call the
list-documentscommand:aws ssm list-documents --filters Key=tag:region,Values=east,west Key=Owner,Values=SelfKey -> (string)
The name of the filter key.
Constraints:
- min:
1- max:
128Values -> (list)
The value for the filter key.
(string)
Constraints:
- min:
1- max:
256
Shorthand Syntax:
Key=string,Values=string,string ...
JSON Syntax:
[
  {
    "Key": "string",
    "Values": ["string", ...]
  }
  ...
]
--cli-input-json | --cli-input-yaml (string)
Reads arguments from the JSON string provided. The JSON string follows the format provided by --generate-cli-skeleton. If other arguments are provided on the command line, those values will override the JSON-provided values. It is not possible to pass arbitrary binary values using a JSON-provided value as the string will be taken literally. This may not be specified along with --cli-input-yaml.
--starting-token (string)
A token to specify where to start paginating. This is the
NextTokenfrom a previously truncated response.For usage examples, see Pagination in the AWS Command Line Interface User Guide .
--page-size (integer)
The size of each page to get in the AWS service call. This does not affect the number of items returned in the command’s output. Setting a smaller page size results in more calls to the AWS service, retrieving fewer items in each call. This can help prevent the AWS service calls from timing out.
For usage examples, see Pagination in the AWS Command Line Interface User Guide .
--max-items (integer)
The total number of items to return in the command’s output. If the total number of items available is more than the value specified, a
NextTokenis provided in the command’s output. To resume pagination, provide theNextTokenvalue in thestarting-tokenargument of a subsequent command. Do not use theNextTokenresponse element directly outside of the AWS CLI.For usage examples, see Pagination in the AWS Command Line Interface User Guide .
--generate-cli-skeleton (string)
Prints a JSON skeleton to standard output without sending an API request. If provided with no value or the value input, prints a sample input JSON that can be used as an argument for --cli-input-json. Similarly, if provided yaml-input it will print a sample input YAML that can be used with --cli-input-yaml. If provided with the value output, it validates the command inputs and returns a sample output JSON for that command. The generated JSON skeleton is not stable between versions of the AWS CLI and there are no backwards compatibility guarantees in the JSON skeleton generated.
--debug (boolean)
Turn on debug logging.
--endpoint-url (string)
Override command’s default URL with the given URL.
--no-verify-ssl (boolean)
By default, the AWS CLI uses SSL when communicating with AWS services. For each SSL connection, the AWS CLI will verify SSL certificates. This option overrides the default behavior of verifying SSL certificates.
--no-paginate (boolean)
Disable automatic pagination. If automatic pagination is disabled, the AWS CLI will only make one call, for the first page of results.
--output (string)
The formatting style for command output.
--query (string)
A JMESPath query to use in filtering the response data.
--profile (string)
Use a specific profile from your credential file.
--region (string)
The region to use. Overrides config/env settings.
--version (string)
Display the version of this tool.
--color (string)
Turn on/off color output.
--no-sign-request (boolean)
Do not sign requests. Credentials will not be loaded if this argument is provided.
--ca-bundle (string)
The CA certificate bundle to use when verifying SSL certificates. Overrides config/env settings.
--cli-read-timeout (int)
The maximum socket read time in seconds. If the value is set to 0, the socket read will be blocking and not timeout. The default value is 60 seconds.
--cli-connect-timeout (int)
The maximum socket connect time in seconds. If the value is set to 0, the socket connect will be blocking and not timeout. The default value is 60 seconds.
--cli-binary-format (string)
The formatting style to be used for binary blobs. The default format is base64. The base64 format expects binary blobs to be provided as a base64 encoded string. The raw-in-base64-out format preserves compatibility with AWS CLI V1 behavior and binary values must be passed literally. When providing contents from a file that map to a binary blob fileb:// will always be treated as binary and use the file contents directly regardless of the cli-binary-format setting. When using file:// the file contents will need to properly formatted for the configured cli-binary-format.
--no-cli-pager (boolean)
Disable cli pager for output.
--cli-auto-prompt (boolean)
Automatically prompt for CLI input parameters.
--no-cli-auto-prompt (boolean)
Disable automatically prompt for CLI input parameters.
To use the following examples, you must have the AWS CLI installed and configured. See the Getting started guide in the AWS CLI User Guide for more information.
Unless otherwise stated, all examples have unix-like quotation rules. These examples will need to be adapted to your terminal’s quoting rules. See Using quotation marks with strings in the AWS CLI User Guide .
Example 1: To list documents
The following list-documents example lists documents owned by the requesting account tagged with the custom tag.
aws ssm list-documents \
    --filters Key=Owner,Values=Self Key=tag:DocUse,Values=Testing
Output:
{
    "DocumentIdentifiers": [
        {
            "Name": "Example",
            "Owner": "29884EXAMPLE",
            "PlatformTypes": [
                "Windows",
                "Linux"
            ],
            "DocumentVersion": "1",
            "DocumentType": "Automation",
            "SchemaVersion": "0.3",
            "DocumentFormat": "YAML",
            "Tags": [
                {
                    "Key": "DocUse",
                    "Value": "Testing"
                }
            ]
        }
    ]
}
For more information, see AWS Systems Manager Documents in the AWS Systems Manager User Guide.
Example 2: To list shared documents
The following list-documents example lists shared documents, including private shared documents not owned by AWS.
aws ssm list-documents \
    --filters Key=Name,Values=sharedDocNamePrefix  Key=Owner,Values=Private
Output:
{
    "DocumentIdentifiers": [
        {
            "Name": "Example",
            "Owner": "12345EXAMPLE",
            "PlatformTypes": [
                "Windows",
                "Linux"
            ],
            "DocumentVersion": "1",
            "DocumentType": "Command",
            "SchemaVersion": "0.3",
            "DocumentFormat": "YAML",
            "Tags": []
        }
    ]
}
For more information, see AWS Systems Manager Documents in the AWS Systems Manager User Guide.
DocumentIdentifiers -> (list)
The names of the SSM documents.
(structure)
Describes the name of a SSM document.
Name -> (string)
The name of the SSM document.
Constraints:
- pattern:
^[a-zA-Z0-9_\-.:/]{3,128}$CreatedDate -> (timestamp)
The date the SSM document was created.DisplayName -> (string)
An optional field where you can specify a friendly name for the SSM document. This value can differ for each version of the document. If you want to update this value, see UpdateDocument .
Constraints:
- max:
1024- pattern:
^[\w\.\-\:\/ ]*$Owner -> (string)
The Amazon Web Services user that created the document.VersionName -> (string)
An optional field specifying the version of the artifact associated with the document. For example, 12.6. This value is unique across all versions of a document, and can’t be changed.
Constraints:
- pattern:
^[a-zA-Z0-9_\-.]{1,128}$PlatformTypes -> (list)
The operating system platform.
(string)
Possible values:
Windows
Linux
MacOSDocumentVersion -> (string)
The document version.
Constraints:
- pattern:
([$]LATEST|[$]DEFAULT|^[1-9][0-9]*$)DocumentType -> (string)
The document type.
Possible values:
Command
Policy
Automation
Session
Package
ApplicationConfiguration
ApplicationConfigurationSchema
DeploymentStrategy
ChangeCalendar
Automation.ChangeTemplate
ProblemAnalysis
ProblemAnalysisTemplate
CloudFormation
ConformancePackTemplate
QuickSetup
ManualApprovalPolicy
AutoApprovalPolicySchemaVersion -> (string)
The schema version.
Constraints:
- pattern:
([0-9]+)\.([0-9]+)DocumentFormat -> (string)
The document format, either JSON or YAML.
Possible values:
YAML
JSON
TEXTTargetType -> (string)
The target type which defines the kinds of resources the document can run on. For example,
/AWS::EC2::Instance. For a list of valid resource types, see Amazon Web Services resource and property types reference in the CloudFormation User Guide .Constraints:
- max:
200- pattern:
^\/[\w\.\-\:\/]*$Tags -> (list)
The tags, or metadata, that have been applied to the document.
Constraints:
- max:
1000(structure)
Metadata that you assign to your Amazon Web Services resources. Tags enable you to categorize your resources in different ways, for example, by purpose, owner, or environment. In Amazon Web Services Systems Manager, you can apply tags to Systems Manager documents (SSM documents), managed nodes, maintenance windows, parameters, patch baselines, OpsItems, and OpsMetadata.
Key -> (string) [required]
The name of the tag.
Constraints:
- min:
1- max:
128- pattern:
^([\p{L}\p{Z}\p{N}_.:/=+\-@]*)$Value -> (string) [required]
The value of the tag.
Constraints:
- min:
0- max:
256- pattern:
^([\p{L}\p{Z}\p{N}_.:/=+\-@]*)$Requires -> (list)
A list of SSM documents required by a document. For example, an
ApplicationConfigurationdocument requires anApplicationConfigurationSchemadocument.Constraints:
- min:
1(structure)
An SSM document required by the current document.
Name -> (string) [required]
The name of the required SSM document. The name can be an Amazon Resource Name (ARN).
Constraints:
- pattern:
^[a-zA-Z0-9_\-.:/]{3,128}$Version -> (string)
The document version required by the current document.
Constraints:
- pattern:
([$]LATEST|[$]DEFAULT|^[1-9][0-9]*$)RequireType -> (string)
The document type of the required SSM document.
Constraints:
- max:
128- pattern:
^[a-zA-Z0-9_\-.]{1,128}$VersionName -> (string)
An optional field specifying the version of the artifact associated with the document. For example, 12.6. This value is unique across all versions of a document, and can’t be changed.
Constraints:
- pattern:
^[a-zA-Z0-9_\-.]{1,128}$ReviewStatus -> (string)
The current status of a document review.
Possible values:
APPROVED
NOT_REVIEWED
PENDING
REJECTEDAuthor -> (string)
The user in your organization who created the document.
NextToken -> (string)
The token to use when requesting the next set of items. If there are no additional items to return, the string is empty.