UNPKG

iam-floyd

Version:

AWS IAM policy statement generator with fluent interface

277 lines 29.1 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.CognitoSync = void 0; const shared_1 = require("../../shared"); /** * Statement provider for service [cognito-sync](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazoncognitosync.html). * * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement */ class CognitoSync extends shared_1.PolicyStatement { /** * Statement provider for service [cognito-sync](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazoncognitosync.html). * * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement */ constructor(sid) { super(sid); this.servicePrefix = 'cognito-sync'; this.accessLevelList = { Write: [ 'BulkPublish', 'DeleteDataset', 'RegisterDevice', 'SetCognitoEvents', 'SetDatasetConfiguration', 'SetIdentityPoolConfiguration', 'SubscribeToDataset', 'UnsubscribeFromDataset', 'UpdateRecords' ], Read: [ 'DescribeDataset', 'DescribeIdentityPoolUsage', 'DescribeIdentityUsage', 'GetBulkPublishDetails', 'GetCognitoEvents', 'GetIdentityPoolConfiguration', 'ListIdentityPoolUsage', 'ListRecords', 'QueryRecords' ], List: [ 'ListDatasets' ] }; } /** * Grants permission to initiate a bulk publish of all existing datasets for an Identity Pool to the configured stream * * Access Level: Write * * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_BulkPublish.html */ toBulkPublish() { return this.to('BulkPublish'); } /** * Grants permission to delete a specific dataset * * Access Level: Write * * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_DeleteDataset.html */ toDeleteDataset() { return this.to('DeleteDataset'); } /** * Grants permission to get metadata about a dataset by identity and dataset name * * Access Level: Read * * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_DescribeDataset.html */ toDescribeDataset() { return this.to('DescribeDataset'); } /** * Grants permission to get usage details (for example, data storage) about a particular identity pool * * Access Level: Read * * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_DescribeIdentityPoolUsage.html */ toDescribeIdentityPoolUsage() { return this.to('DescribeIdentityPoolUsage'); } /** * Grants permission to get usage information for an identity, including number of datasets and data usage * * Access Level: Read * * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_DescribeIdentityUsage.html */ toDescribeIdentityUsage() { return this.to('DescribeIdentityUsage'); } /** * Grants permission to get the status of the last BulkPublish operation for an identity pool * * Access Level: Read * * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_GetBulkPublishDetails.html */ toGetBulkPublishDetails() { return this.to('GetBulkPublishDetails'); } /** * Grants permission to get the events and the corresponding Lambda functions associated with an identity pool * * Access Level: Read * * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_GetCognitoEvents.html */ toGetCognitoEvents() { return this.to('GetCognitoEvents'); } /** * Grants permission to get the configuration settings of an identity pool * * Access Level: Read * * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_GetIdentityPoolConfiguration.html */ toGetIdentityPoolConfiguration() { return this.to('GetIdentityPoolConfiguration'); } /** * Grants permission to list datasets for an identity * * Access Level: List * * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_ListDatasets.html */ toListDatasets() { return this.to('ListDatasets'); } /** * Grants permission to get a list of identity pools registered with Cognito * * Access Level: Read * * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_ListIdentityPoolUsage.html */ toListIdentityPoolUsage() { return this.to('ListIdentityPoolUsage'); } /** * Grants permission to get paginated records, optionally changed after a particular sync count for a dataset and identity * * Access Level: Read * * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_ListRecords.html */ toListRecords() { return this.to('ListRecords'); } /** * Grants permission to query records * * Access Level: Read */ toQueryRecords() { return this.to('QueryRecords'); } /** * Grants permission to register a device to receive push sync notifications * * Access Level: Write * * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_RegisterDevice.html */ toRegisterDevice() { return this.to('RegisterDevice'); } /** * Grants permission to set the AWS Lambda function for a given event type for an identity pool * * Access Level: Write * * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_SetCognitoEvents.html */ toSetCognitoEvents() { return this.to('SetCognitoEvents'); } /** * Grants permission to configure datasets * * Access Level: Write */ toSetDatasetConfiguration() { return this.to('SetDatasetConfiguration'); } /** * Grants permission to set the necessary configuration for push sync * * Access Level: Write * * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_SetIdentityPoolConfiguration.html */ toSetIdentityPoolConfiguration() { return this.to('SetIdentityPoolConfiguration'); } /** * Grants permission to subscribe to receive notifications when a dataset is modified by another device * * Access Level: Write * * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_SubscribeToDataset.html */ toSubscribeToDataset() { return this.to('SubscribeToDataset'); } /** * Grants permission to unsubscribe from receiving notifications when a dataset is modified by another device * * Access Level: Write * * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_UnsubscribeFromDataset.html */ toUnsubscribeFromDataset() { return this.to('UnsubscribeFromDataset'); } /** * Grants permission to post updates to records and add and delete records for a dataset and user * * Access Level: Write * * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_UpdateRecords.html */ toUpdateRecords() { return this.to('UpdateRecords'); } /** * Adds a resource of type dataset to the statement * * https://docs.aws.amazon.com/cognito/latest/developerguide/synchronizing-data.html#understanding-datasets * * @param identityPoolId - Identifier for the identityPoolId. * @param identityId - Identifier for the identityId. * @param datasetName - Identifier for the datasetName. * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account. * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region. * @param partition - Partition of the AWS account [aws, aws-cn, aws-us-gov]; defaults to `aws`, unless using the CDK, where the default is the current Stack's partition. */ onDataset(identityPoolId, identityId, datasetName, account, region, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:cognito-sync:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:identitypool/${identityPoolId}/identity/${identityId}/dataset/${datasetName}`); } /** * Adds a resource of type identity to the statement * * https://docs.aws.amazon.com/cognito/latest/developerguide/identity-pools.html#authenticated-and-unauthenticated-identities * * @param identityPoolId - Identifier for the identityPoolId. * @param identityId - Identifier for the identityId. * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account. * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region. * @param partition - Partition of the AWS account [aws, aws-cn, aws-us-gov]; defaults to `aws`, unless using the CDK, where the default is the current Stack's partition. */ onIdentity(identityPoolId, identityId, account, region, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:cognito-sync:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:identitypool/${identityPoolId}/identity/${identityId}`); } /** * Adds a resource of type identitypool to the statement * * https://docs.aws.amazon.com/cognito/latest/developerguide/identity-pools.html * * @param identityPoolId - Identifier for the identityPoolId. * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account. * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region. * @param partition - Partition of the AWS account [aws, aws-cn, aws-us-gov]; defaults to `aws`, unless using the CDK, where the default is the current Stack's partition. */ onIdentitypool(identityPoolId, account, region, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:cognito-sync:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:identitypool/${identityPoolId}`); } } exports.CognitoSync = CognitoSync; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cognitosync.js","sourceRoot":"","sources":["cognitosync.ts"],"names":[],"mappings":"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","sourcesContent":["import { AccessLevelList } from '../../shared/access-level';\nimport { PolicyStatement } from '../../shared';\n\n/**\n * Statement provider for service [cognito-sync](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazoncognitosync.html).\n *\n * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement\n */\nexport class CognitoSync extends PolicyStatement {\n  public servicePrefix = 'cognito-sync';\n\n  /**\n   * Statement provider for service [cognito-sync](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazoncognitosync.html).\n   *\n   * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement\n   */\n  constructor(sid?: string) {\n    super(sid);\n  }\n\n  /**\n   * Grants permission to initiate a bulk publish of all existing datasets for an Identity Pool to the configured stream\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_BulkPublish.html\n   */\n  public toBulkPublish() {\n    return this.to('BulkPublish');\n  }\n\n  /**\n   * Grants permission to delete a specific dataset\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_DeleteDataset.html\n   */\n  public toDeleteDataset() {\n    return this.to('DeleteDataset');\n  }\n\n  /**\n   * Grants permission to get metadata about a dataset by identity and dataset name\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_DescribeDataset.html\n   */\n  public toDescribeDataset() {\n    return this.to('DescribeDataset');\n  }\n\n  /**\n   * Grants permission to get usage details (for example, data storage) about a particular identity pool\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_DescribeIdentityPoolUsage.html\n   */\n  public toDescribeIdentityPoolUsage() {\n    return this.to('DescribeIdentityPoolUsage');\n  }\n\n  /**\n   * Grants permission to get usage information for an identity, including number of datasets and data usage\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_DescribeIdentityUsage.html\n   */\n  public toDescribeIdentityUsage() {\n    return this.to('DescribeIdentityUsage');\n  }\n\n  /**\n   * Grants permission to get the status of the last BulkPublish operation for an identity pool\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_GetBulkPublishDetails.html\n   */\n  public toGetBulkPublishDetails() {\n    return this.to('GetBulkPublishDetails');\n  }\n\n  /**\n   * Grants permission to get the events and the corresponding Lambda functions associated with an identity pool\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_GetCognitoEvents.html\n   */\n  public toGetCognitoEvents() {\n    return this.to('GetCognitoEvents');\n  }\n\n  /**\n   * Grants permission to get the configuration settings of an identity pool\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_GetIdentityPoolConfiguration.html\n   */\n  public toGetIdentityPoolConfiguration() {\n    return this.to('GetIdentityPoolConfiguration');\n  }\n\n  /**\n   * Grants permission to list datasets for an identity\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_ListDatasets.html\n   */\n  public toListDatasets() {\n    return this.to('ListDatasets');\n  }\n\n  /**\n   * Grants permission to get a list of identity pools registered with Cognito\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_ListIdentityPoolUsage.html\n   */\n  public toListIdentityPoolUsage() {\n    return this.to('ListIdentityPoolUsage');\n  }\n\n  /**\n   * Grants permission to get paginated records, optionally changed after a particular sync count for a dataset and identity\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_ListRecords.html\n   */\n  public toListRecords() {\n    return this.to('ListRecords');\n  }\n\n  /**\n   * Grants permission to query records\n   *\n   * Access Level: Read\n   */\n  public toQueryRecords() {\n    return this.to('QueryRecords');\n  }\n\n  /**\n   * Grants permission to register a device to receive push sync notifications\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_RegisterDevice.html\n   */\n  public toRegisterDevice() {\n    return this.to('RegisterDevice');\n  }\n\n  /**\n   * Grants permission to set the AWS Lambda function for a given event type for an identity pool\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_SetCognitoEvents.html\n   */\n  public toSetCognitoEvents() {\n    return this.to('SetCognitoEvents');\n  }\n\n  /**\n   * Grants permission to configure datasets\n   *\n   * Access Level: Write\n   */\n  public toSetDatasetConfiguration() {\n    return this.to('SetDatasetConfiguration');\n  }\n\n  /**\n   * Grants permission to set the necessary configuration for push sync\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_SetIdentityPoolConfiguration.html\n   */\n  public toSetIdentityPoolConfiguration() {\n    return this.to('SetIdentityPoolConfiguration');\n  }\n\n  /**\n   * Grants permission to subscribe to receive notifications when a dataset is modified by another device\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_SubscribeToDataset.html\n   */\n  public toSubscribeToDataset() {\n    return this.to('SubscribeToDataset');\n  }\n\n  /**\n   * Grants permission to unsubscribe from receiving notifications when a dataset is modified by another device\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_UnsubscribeFromDataset.html\n   */\n  public toUnsubscribeFromDataset() {\n    return this.to('UnsubscribeFromDataset');\n  }\n\n  /**\n   * Grants permission to post updates to records and add and delete records for a dataset and user\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/cognitosync/latest/APIReference/API_UpdateRecords.html\n   */\n  public toUpdateRecords() {\n    return this.to('UpdateRecords');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'BulkPublish',\n      'DeleteDataset',\n      'RegisterDevice',\n      'SetCognitoEvents',\n      'SetDatasetConfiguration',\n      'SetIdentityPoolConfiguration',\n      'SubscribeToDataset',\n      'UnsubscribeFromDataset',\n      'UpdateRecords'\n    ],\n    Read: [\n      'DescribeDataset',\n      'DescribeIdentityPoolUsage',\n      'DescribeIdentityUsage',\n      'GetBulkPublishDetails',\n      'GetCognitoEvents',\n      'GetIdentityPoolConfiguration',\n      'ListIdentityPoolUsage',\n      'ListRecords',\n      'QueryRecords'\n    ],\n    List: [\n      'ListDatasets'\n    ]\n  };\n\n  /**\n   * Adds a resource of type dataset to the statement\n   *\n   * https://docs.aws.amazon.com/cognito/latest/developerguide/synchronizing-data.html#understanding-datasets\n   *\n   * @param identityPoolId - Identifier for the identityPoolId.\n   * @param identityId - Identifier for the identityId.\n   * @param datasetName - Identifier for the datasetName.\n   * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.\n   * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.\n   * @param partition - Partition of the AWS account [aws, aws-cn, aws-us-gov]; defaults to `aws`, unless using the CDK, where the default is the current Stack's partition.\n   */\n  public onDataset(identityPoolId: string, identityId: string, datasetName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:cognito-sync:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:identitypool/${ identityPoolId }/identity/${ identityId }/dataset/${ datasetName }`);\n  }\n\n  /**\n   * Adds a resource of type identity to the statement\n   *\n   * https://docs.aws.amazon.com/cognito/latest/developerguide/identity-pools.html#authenticated-and-unauthenticated-identities\n   *\n   * @param identityPoolId - Identifier for the identityPoolId.\n   * @param identityId - Identifier for the identityId.\n   * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.\n   * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.\n   * @param partition - Partition of the AWS account [aws, aws-cn, aws-us-gov]; defaults to `aws`, unless using the CDK, where the default is the current Stack's partition.\n   */\n  public onIdentity(identityPoolId: string, identityId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:cognito-sync:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:identitypool/${ identityPoolId }/identity/${ identityId }`);\n  }\n\n  /**\n   * Adds a resource of type identitypool to the statement\n   *\n   * https://docs.aws.amazon.com/cognito/latest/developerguide/identity-pools.html\n   *\n   * @param identityPoolId - Identifier for the identityPoolId.\n   * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.\n   * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.\n   * @param partition - Partition of the AWS account [aws, aws-cn, aws-us-gov]; defaults to `aws`, unless using the CDK, where the default is the current Stack's partition.\n   */\n  public onIdentitypool(identityPoolId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:cognito-sync:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:identitypool/${ identityPoolId }`);\n  }\n}\n"]}