iam-floyd
Version:
AWS IAM policy statement generator with fluent interface
277 lines • 29.1 kB
JavaScript
"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":";;;AACA,yCAA+C;AAE/C;;;;GAIG;AACH,MAAa,WAAY,SAAQ,wBAAe;IAG9C;;;;OAIG;IACH,YAAY,GAAY;QACtB,KAAK,CAAC,GAAG,CAAC,CAAC;QARN,kBAAa,GAAG,cAAc,CAAC;QAwN5B,oBAAe,GAAoB;YAC3C,KAAK,EAAE;gBACL,aAAa;gBACb,eAAe;gBACf,gBAAgB;gBAChB,kBAAkB;gBAClB,yBAAyB;gBACzB,8BAA8B;gBAC9B,oBAAoB;gBACpB,wBAAwB;gBACxB,eAAe;aAChB;YACD,IAAI,EAAE;gBACJ,iBAAiB;gBACjB,2BAA2B;gBAC3B,uBAAuB;gBACvB,uBAAuB;gBACvB,kBAAkB;gBAClB,8BAA8B;gBAC9B,uBAAuB;gBACvB,aAAa;gBACb,cAAc;aACf;YACD,IAAI,EAAE;gBACJ,cAAc;aACf;SACF,CAAC;IAzOF,CAAC;IAED;;;;;;OAMG;IACI,aAAa;QAClB,OAAO,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC;IAChC,CAAC;IAED;;;;;;OAMG;IACI,eAAe;QACpB,OAAO,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC;IAClC,CAAC;IAED;;;;;;OAMG;IACI,iBAAiB;QACtB,OAAO,IAAI,CAAC,EAAE,CAAC,iBAAiB,CAAC,CAAC;IACpC,CAAC;IAED;;;;;;OAMG;IACI,2BAA2B;QAChC,OAAO,IAAI,CAAC,EAAE,CAAC,2BAA2B,CAAC,CAAC;IAC9C,CAAC;IAED;;;;;;OAMG;IACI,uBAAuB;QAC5B,OAAO,IAAI,CAAC,EAAE,CAAC,uBAAuB,CAAC,CAAC;IAC1C,CAAC;IAED;;;;;;OAMG;IACI,uBAAuB;QAC5B,OAAO,IAAI,CAAC,EAAE,CAAC,uBAAuB,CAAC,CAAC;IAC1C,CAAC;IAED;;;;;;OAMG;IACI,kBAAkB;QACvB,OAAO,IAAI,CAAC,EAAE,CAAC,kBAAkB,CAAC,CAAC;IACrC,CAAC;IAED;;;;;;OAMG;IACI,8BAA8B;QACnC,OAAO,IAAI,CAAC,EAAE,CAAC,8BAA8B,CAAC,CAAC;IACjD,CAAC;IAED;;;;;;OAMG;IACI,cAAc;QACnB,OAAO,IAAI,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC;IACjC,CAAC;IAED;;;;;;OAMG;IACI,uBAAuB;QAC5B,OAAO,IAAI,CAAC,EAAE,CAAC,uBAAuB,CAAC,CAAC;IAC1C,CAAC;IAED;;;;;;OAMG;IACI,aAAa;QAClB,OAAO,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC;IAChC,CAAC;IAED;;;;OAIG;IACI,cAAc;QACnB,OAAO,IAAI,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC;IACjC,CAAC;IAED;;;;;;OAMG;IACI,gBAAgB;QACrB,OAAO,IAAI,CAAC,EAAE,CAAC,gBAAgB,CAAC,CAAC;IACnC,CAAC;IAED;;;;;;OAMG;IACI,kBAAkB;QACvB,OAAO,IAAI,CAAC,EAAE,CAAC,kBAAkB,CAAC,CAAC;IACrC,CAAC;IAED;;;;OAIG;IACI,yBAAyB;QAC9B,OAAO,IAAI,CAAC,EAAE,CAAC,yBAAyB,CAAC,CAAC;IAC5C,CAAC;IAED;;;;;;OAMG;IACI,8BAA8B;QACnC,OAAO,IAAI,CAAC,EAAE,CAAC,8BAA8B,CAAC,CAAC;IACjD,CAAC;IAED;;;;;;OAMG;IACI,oBAAoB;QACzB,OAAO,IAAI,CAAC,EAAE,CAAC,oBAAoB,CAAC,CAAC;IACvC,CAAC;IAED;;;;;;OAMG;IACI,wBAAwB;QAC7B,OAAO,IAAI,CAAC,EAAE,CAAC,wBAAwB,CAAC,CAAC;IAC3C,CAAC;IAED;;;;;;OAMG;IACI,eAAe;QACpB,OAAO,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC;IAClC,CAAC;IA8BD;;;;;;;;;;;OAWG;IACI,SAAS,CAAC,cAAsB,EAAE,UAAkB,EAAE,WAAmB,EAAE,OAAgB,EAAE,MAAe,EAAE,SAAkB;QACrI,OAAO,IAAI,CAAC,EAAE,CAAC,OAAQ,SAAS,IAAI,IAAI,CAAC,gBAAiB,iBAAkB,MAAM,IAAI,IAAI,CAAC,aAAc,IAAK,OAAO,IAAI,IAAI,CAAC,cAAe,iBAAkB,cAAe,aAAc,UAAW,YAAa,WAAY,EAAE,CAAC,CAAC;IACtO,CAAC;IAED;;;;;;;;;;OAUG;IACI,UAAU,CAAC,cAAsB,EAAE,UAAkB,EAAE,OAAgB,EAAE,MAAe,EAAE,SAAkB;QACjH,OAAO,IAAI,CAAC,EAAE,CAAC,OAAQ,SAAS,IAAI,IAAI,CAAC,gBAAiB,iBAAkB,MAAM,IAAI,IAAI,CAAC,aAAc,IAAK,OAAO,IAAI,IAAI,CAAC,cAAe,iBAAkB,cAAe,aAAc,UAAW,EAAE,CAAC,CAAC;IAC7M,CAAC;IAED;;;;;;;;;OASG;IACI,cAAc,CAAC,cAAsB,EAAE,OAAgB,EAAE,MAAe,EAAE,SAAkB;QACjG,OAAO,IAAI,CAAC,EAAE,CAAC,OAAQ,SAAS,IAAI,IAAI,CAAC,gBAAiB,iBAAkB,MAAM,IAAI,IAAI,CAAC,aAAc,IAAK,OAAO,IAAI,IAAI,CAAC,cAAe,iBAAkB,cAAe,EAAE,CAAC,CAAC;IACpL,CAAC;CACF;AAjSD,kCAiSC","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"]}