:doc:`SSM <../../ssm>` / Client / create_resource_data_sync

*************************
create_resource_data_sync
*************************



.. py:method:: SSM.Client.create_resource_data_sync(**kwargs)

  

  A resource data sync helps you view data from multiple sources in a single location. Amazon Web Services Systems Manager offers two types of resource data sync: ``SyncToDestination`` and ``SyncFromSource``.

   

  You can configure Systems Manager Inventory to use the ``SyncToDestination`` type to synchronize Inventory data from multiple Amazon Web Services Regions to a single Amazon Simple Storage Service (Amazon S3) bucket. For more information, see `Creating a resource data sync for Inventory <https://docs.aws.amazon.com/systems-manager/latest/userguide/inventory-create-resource-data-sync.html>`__ in the *Amazon Web Services Systems Manager User Guide*.

   

  You can configure Systems Manager Explorer to use the ``SyncFromSource`` type to synchronize operational work items (OpsItems) and operational data (OpsData) from multiple Amazon Web Services Regions to a single Amazon S3 bucket. This type can synchronize OpsItems and OpsData from multiple Amazon Web Services accounts and Amazon Web Services Regions or ``EntireOrganization`` by using Organizations. For more information, see `Setting up Systems Manager Explorer to display data from multiple accounts and Regions <https://docs.aws.amazon.com/systems-manager/latest/userguide/Explorer-resource-data-sync.html>`__ in the *Amazon Web Services Systems Manager User Guide*.

   

  A resource data sync is an asynchronous operation that returns immediately. After a successful initial sync is completed, the system continuously syncs data. To check the status of a sync, use the  ListResourceDataSync.

   

  .. note::

    

    By default, data isn't encrypted in Amazon S3. We strongly recommend that you enable encryption in Amazon S3 to ensure secure data storage. We also recommend that you secure access to the Amazon S3 bucket by creating a restrictive bucket policy.

    

  

  See also: `AWS API Documentation <https://docs.aws.amazon.com/goto/WebAPI/ssm-2014-11-06/CreateResourceDataSync>`_  


  **Request Syntax**
  ::

    response = client.create_resource_data_sync(
        SyncName='string',
        S3Destination={
            'BucketName': 'string',
            'Prefix': 'string',
            'SyncFormat': 'JsonSerDe',
            'Region': 'string',
            'AWSKMSKeyARN': 'string',
            'DestinationDataSharing': {
                'DestinationDataSharingType': 'string'
            }
        },
        SyncType='string',
        SyncSource={
            'SourceType': 'string',
            'AwsOrganizationsSource': {
                'OrganizationSourceType': 'string',
                'OrganizationalUnits': [
                    {
                        'OrganizationalUnitId': 'string'
                    },
                ]
            },
            'SourceRegions': [
                'string',
            ],
            'IncludeFutureRegions': True|False,
            'EnableAllOpsDataSources': True|False
        }
    )
    
  :type SyncName: string
  :param SyncName: **[REQUIRED]** 

    A name for the configuration.

    

  
  :type S3Destination: dict
  :param S3Destination: 

    Amazon S3 configuration details for the sync. This parameter is required if the ``SyncType`` value is SyncToDestination.

    

  
    - **BucketName** *(string) --* **[REQUIRED]** 

      The name of the S3 bucket where the aggregated data is stored.

      

    
    - **Prefix** *(string) --* 

      An Amazon S3 prefix for the bucket.

      

    
    - **SyncFormat** *(string) --* **[REQUIRED]** 

      A supported sync format. The following format is currently supported: JsonSerDe

      

    
    - **Region** *(string) --* **[REQUIRED]** 

      The Amazon Web Services Region with the S3 bucket targeted by the resource data sync.

      

    
    - **AWSKMSKeyARN** *(string) --* 

      The ARN of an encryption key for a destination in Amazon S3. Must belong to the same Region as the destination S3 bucket.

      

    
    - **DestinationDataSharing** *(dict) --* 

      Enables destination data sharing. By default, this field is ``null``.

      

    
      - **DestinationDataSharingType** *(string) --* 

        The sharing data type. Only ``Organization`` is supported.

        

      
    
  
  :type SyncType: string
  :param SyncType: 

    Specify ``SyncToDestination`` to create a resource data sync that synchronizes data to an S3 bucket for Inventory. If you specify ``SyncToDestination``, you must provide a value for ``S3Destination``. Specify ``SyncFromSource`` to synchronize data from a single account and multiple Regions, or multiple Amazon Web Services accounts and Amazon Web Services Regions, as listed in Organizations for Explorer. If you specify ``SyncFromSource``, you must provide a value for ``SyncSource``. The default value is ``SyncToDestination``.

    

  
  :type SyncSource: dict
  :param SyncSource: 

    Specify information about the data sources to synchronize. This parameter is required if the ``SyncType`` value is SyncFromSource.

    

  
    - **SourceType** *(string) --* **[REQUIRED]** 

      The type of data source for the resource data sync. ``SourceType`` is either ``AwsOrganizations`` (if an organization is present in Organizations) or ``SingleAccountMultiRegions``.

      

    
    - **AwsOrganizationsSource** *(dict) --* 

      Information about the ``AwsOrganizationsSource`` resource data sync source. A sync source of this type can synchronize data from Organizations.

      

    
      - **OrganizationSourceType** *(string) --* **[REQUIRED]** 

        If an Amazon Web Services organization is present, this is either ``OrganizationalUnits`` or ``EntireOrganization``. For ``OrganizationalUnits``, the data is aggregated from a set of organization units. For ``EntireOrganization``, the data is aggregated from the entire Amazon Web Services organization.

        

      
      - **OrganizationalUnits** *(list) --* 

        The Organizations organization units included in the sync.

        

      
        - *(dict) --* 

          The Organizations organizational unit data source for the sync.

          

        
          - **OrganizationalUnitId** *(string) --* 

            The Organizations unit ID data source for the sync.

            

          
        
    
    
    - **SourceRegions** *(list) --* **[REQUIRED]** 

      The ``SyncSource`` Amazon Web Services Regions included in the resource data sync.

      

    
      - *(string) --* 

      
  
    - **IncludeFutureRegions** *(boolean) --* 

      Whether to automatically synchronize and aggregate data from new Amazon Web Services Regions when those Regions come online.

      

    
    - **EnableAllOpsDataSources** *(boolean) --* 

      When you create a resource data sync, if you choose one of the Organizations options, then Systems Manager automatically enables all OpsData sources in the selected Amazon Web Services Regions for all Amazon Web Services accounts in your organization (or in the selected organization units). For more information, see `Setting up Systems Manager Explorer to display data from multiple accounts and Regions <https://docs.aws.amazon.com/systems-manager/latest/userguide/Explorer-resource-data-sync.html>`__ in the *Amazon Web Services Systems Manager User Guide*.

      

    
  
  
  :rtype: dict
  :returns: 
    
    **Response Syntax**

    
    ::

      {}
      
    **Response Structure**

    

    - *(dict) --* 
  
  **Exceptions**
  
  *   :py:class:`SSM.Client.exceptions.InternalServerError`

  
  *   :py:class:`SSM.Client.exceptions.ResourceDataSyncCountExceededException`

  
  *   :py:class:`SSM.Client.exceptions.ResourceDataSyncAlreadyExistsException`

  
  *   :py:class:`SSM.Client.exceptions.ResourceDataSyncInvalidConfigurationException`

  