@aws-mdaa/dataops-job-l3-construct 1.2.0 → 1.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +137 -294
- package/lib/dataops-job-l3-construct.js +9 -11
- package/lib/index.js +1 -3
- package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/lib/index.js +2 -4
- package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/package.json +13 -17
- package/node_modules/@aws-mdaa/s3-inventory-helper/lib/index.js +2 -4
- package/node_modules/@aws-mdaa/s3-inventory-helper/package.json +13 -17
- package/node_modules/lodash/README.md +2 -2
- package/node_modules/lodash/_baseUnset.js +47 -2
- package/node_modules/lodash/core.js +1 -1
- package/node_modules/lodash/core.min.js +1 -1
- package/node_modules/lodash/lodash.js +43 -4
- package/node_modules/lodash/lodash.min.js +57 -57
- package/node_modules/lodash/package.json +1 -1
- package/package.json +32 -48
- package/node_modules/lodash/flake.lock +0 -40
- package/node_modules/lodash/flake.nix +0 -20
- package/node_modules/lodash/release.md +0 -48
|
@@ -1,10 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
1
2
|
/*!
|
|
2
3
|
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
3
4
|
* SPDX-License-Identifier: Apache-2.0
|
|
4
5
|
*/
|
|
5
|
-
|
|
6
|
-
"use strict";
|
|
7
|
-
|
|
8
6
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
7
|
exports.InventoryHelper = void 0;
|
|
10
8
|
const s3_constructs_1 = require("@aws-mdaa/s3-constructs");
|
|
@@ -221,4 +219,4 @@ class InventoryHelper {
|
|
|
221
219
|
}
|
|
222
220
|
}
|
|
223
221
|
exports.InventoryHelper = InventoryHelper;
|
|
224
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"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","sourcesContent":["/*!\n * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { MdaaBucket } from '@aws-mdaa/s3-constructs';\nimport { Database } from '@aws-cdk/aws-glue-alpha';\nimport { CfnTable, CfnTableProps } from 'aws-cdk-lib/aws-glue';\nimport { Effect, PolicyStatement } from 'aws-cdk-lib/aws-iam';\nimport { IBucket, Inventory, InventoryFormat, InventoryFrequency, InventoryObjectVersion } from 'aws-cdk-lib/aws-s3';\nimport { Construct } from 'constructs';\n\nexport interface BucketInventory {\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Name of the S3 bucket for which inventory data has been generated. Identifies the source bucket in inventory data organization and enables bucket-specific inventory querying through Glue table partitions.\n   *\n   * Use cases: Source bucket identification; Inventory data organization; Multi-bucket inventory management\n   *\n   * AWS: AWS S3 bucket name for inventory source identification in Glue table partitions\n   *\n   * Validation: Must be valid S3 bucket name (3-63 characters, lowercase, no underscores)\n   **/\n  readonly bucketName: string;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Name of the S3 inventory configuration that generated the inventory data for the specified bucket. Enables multiple inventory configurations per bucket and organized inventory data management.\n   *\n   * Use cases: Inventory configuration identification; Multiple inventories per bucket; Inventory data organization\n   *\n   * AWS: AWS S3 inventory configuration name for inventory data identification in Glue table partitions\n   *\n   * Validation: Must be valid S3 inventory configuration name matching the inventory ID used in S3 inventory setup\n   **/\n  readonly inventoryName: string;\n}\n\n/** Helper class for creating S3 Inventories and associated Glue/Athena resources for querying these inventories. */\nexport class InventoryHelper {\n  /**\n   * Helper method for creating an S3 inventory.\n   * @param destinationBucket The bucket where S3 inventory data will be written\n   * @param inventoryId The S3 inventory ID\n   * @param objectsPrefix The object prefix from which inventory will be produced (on the bucket to which the inventory config is applied)\n   * @param destinationPrefix The object prefix under which inventory will be written on the destination bucket.\n   * @returns An S3 Inventory Config which can be applied to a bucket in order to produce periodic inventory data.\n   */\n  public static createInvConfig(\n    destinationBucket: IBucket,\n    inventoryId: string,\n    objectsPrefix?: string,\n    destinationPrefix?: string,\n    destinationAccount?: string,\n  ): Inventory {\n    const bucketOwner = destinationAccount ? `${destinationAccount}` : destinationAccount;\n    return {\n      destination: {\n        bucket: destinationBucket,\n        /**\n         * Q-ENHANCED-PROPERTY\n         * Required S3 prefix for inventory report destination organization enabling systematic inventory file organization and management. Provides the S3 key prefix for inventory report storage enabling organized inventory data management and efficient retrieval of inventory reports.\n         *\n         * Use cases: Inventory organization; Report storage; Data management; Systematic file organization\n         *\n         * AWS: S3 inventory configuration destination prefix for inventory report organization and storage\n         *\n         * Validation: Must be valid S3 prefix string; required for inventory report destination organization\n         */\n        prefix: MdaaBucket.formatS3Prefix(destinationPrefix),\n        bucketOwner: bucketOwner,\n      },\n      format: InventoryFormat.PARQUET,\n      frequency: InventoryFrequency.DAILY,\n      includeObjectVersions: InventoryObjectVersion.ALL,\n      inventoryId: inventoryId,\n      objectsPrefix: MdaaBucket.formatS3Prefix(objectsPrefix, false, true),\n      optionalFields: [\n        'Size',\n        'LastModifiedDate',\n        'StorageClass',\n        'ETag',\n        'IsMultipartUploaded',\n        'ReplicationStatus',\n        'EncryptionStatus',\n        'ObjectLockRetainUntilDate',\n        'ObjectLockMode',\n        'ObjectLockLegalHoldStatus',\n        'IntelligentTieringAccessTier',\n      ],\n    };\n  }\n\n  /**\n   * Helper method for creating a Glue table which can be used to query inventory data generated by an S3 Inventory config\n   * @param scope Stack in which the table will be created\n   * @param tableNamePrefix Will be used to prefix the table name.\n   * @param locationBucketName The bucket where the inventory data is stored.\n   * @param inventoryBucket The bucket for which inventory data has been generated\n   * @param database The Glue database in which the table will be created\n   * @param inventoryName The name of the S3 Inventory config\n   * @param locationPrefix The S3 Prefix on the location bucket where the inventory is stored.\n   * @returns A Glue table which can be used to query S3 inventory data in an S3 bucket.\n   */\n  public static createGlueInvTable(\n    scope: Construct,\n    catalogId: string,\n    tableNamePrefix: string,\n    database: Database,\n    locationBucketName: string,\n    bucketInventories: BucketInventory[],\n    locationPrefix?: string,\n  ): CfnTable {\n    const location = locationPrefix\n      ? `s3://${locationBucketName}/${MdaaBucket.formatS3Prefix(locationPrefix)}/`\n      : `s3://${locationBucketName}/`;\n    const tableInput = {\n      name: `${tableNamePrefix}_inv`.replace(/-/gi, '_'),\n      parameters: {\n        EXTERNAL: 'TRUE',\n        'projection.enabled': 'true',\n        'projection.dt.type': 'date',\n        'projection.dt.range': '2022-01-01-00-00,NOW',\n        'projection.dt.format': 'yyyy-MM-dd-HH-mm',\n        'projection.dt.interval': '1',\n        'projection.dt.interval.unit': 'HOURS',\n        'projection.bucket_inventory.type': 'enum',\n        'projection.bucket_inventory.values': bucketInventories\n          .map(x => `${x.bucketName}/${x.inventoryName}`)\n          .join(','),\n        'storage.location.template': location + '${bucket_inventory}/hive/dt=${dt}',\n      },\n      tableType: 'EXTERNAL_TABLE',\n      partitionKeys: [\n        {\n          name: 'bucket_inventory',\n          type: 'string',\n        },\n        {\n          name: 'dt',\n          type: 'string',\n        },\n      ],\n      storageDescriptor: {\n        columns: [\n          {\n            name: 'bucket',\n            type: 'string',\n          },\n          {\n            name: 'key',\n            type: 'string',\n          },\n          {\n            name: 'version_id',\n            type: 'string',\n          },\n          {\n            name: 'is_latest',\n            type: 'boolean',\n          },\n          {\n            name: 'is_delete_marker',\n            type: 'boolean',\n          },\n          {\n            name: 'size',\n            type: 'bigint',\n          },\n          {\n            name: 'last_modified_date',\n            type: 'timestamp',\n          },\n          {\n            name: 'e_tag',\n            type: 'string',\n          },\n          {\n            name: 'storage_class',\n            type: 'string',\n          },\n          {\n            name: 'is_multipart_uploaded',\n            type: 'boolean',\n          },\n          {\n            name: 'replication_status',\n            type: 'string',\n          },\n          {\n            name: 'encryption_status',\n            type: 'string',\n          },\n          {\n            name: 'intelligent_tiering_tier',\n            type: 'string',\n          },\n          // ,\n          // {\n          //     name: \"object_lock_retain_until_date\",\n          //     type: \"timestamp\"\n          // },\n          // {\n          //     name: \"object_lock_mode\",\n          //     type: \"string\"\n          // },\n          // {\n          //     name: \"object_lock_legal_hold_status\",\n          //     type: \"string\"\n          // }\n        ],\n        location: location,\n        inputFormat: 'org.apache.hadoop.hive.ql.io.SymlinkTextInputFormat',\n        outputFormat: 'org.apache.hadoop.hive.ql.io.HiveIgnoreKeyTextOutputFormat',\n        compressed: false,\n        numberOfBuckets: -1,\n        serdeInfo: {\n          serializationLibrary: 'org.apache.hadoop.hive.ql.io.parquet.serde.ParquetHiveSerDe',\n          parameters: {\n            'serialization.format': '1',\n          },\n        },\n      },\n    };\n\n    const tableProps: CfnTableProps = {\n      catalogId: catalogId,\n      databaseName: database.databaseName,\n      tableInput: tableInput,\n    };\n    return new CfnTable(scope, `inv-table-${tableNamePrefix}`, tableProps);\n  }\n\n  /**\n   * Helper method to generate an S3 Bucket Policy Statement allowing S3 service to write inventories to a bucket.\n   * @param sourceBucketArn The bucket arn for which inventory data is being produced\n   * @param bucketArn  The bucket arn where inventory will be stored\n   * @param srcAccount The account which owns the source bucket from which inventory is being produced.\n   * @param inventoryPrefix The prefix on the destination bucket where inventory data will be stored.\n   * @returns A policy statement which permits the S3 service principal to write inventory for the source bucket/account to the destination bucket.\n   */\n  public static createInventoryBucketPolicyStatement(\n    bucketArn: string,\n    srcAccount: string,\n    sourceBucketArn?: string,\n    inventoryPrefix?: string,\n  ): PolicyStatement {\n    const resource = inventoryPrefix\n      ? `${bucketArn}/${MdaaBucket.formatS3Prefix(inventoryPrefix)}/*`\n      : `${bucketArn}/*`;\n    const allowS3Inventory = new PolicyStatement({\n      sid: 'AllowS3Inventory',\n      effect: Effect.ALLOW,\n      resources: [resource],\n      actions: ['s3:PutObject'],\n    });\n    allowS3Inventory.addCondition('StringEquals', {\n      'aws:SourceAccount': srcAccount,\n      's3:x-amz-acl': 'bucket-owner-full-control',\n    });\n    if (sourceBucketArn) {\n      allowS3Inventory.addCondition('ArnLike', {\n        'aws:SourceArn': sourceBucketArn,\n      });\n    }\n    allowS3Inventory.addServicePrincipal('s3.amazonaws.com');\n    return allowS3Inventory;\n  }\n}\n"]}
|
|
222
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"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","sourcesContent":["/*!\n * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { MdaaBucket } from '@aws-mdaa/s3-constructs';\nimport { Database } from '@aws-cdk/aws-glue-alpha';\nimport { CfnTable, CfnTableProps } from 'aws-cdk-lib/aws-glue';\nimport { Effect, PolicyStatement } from 'aws-cdk-lib/aws-iam';\nimport { IBucket, Inventory, InventoryFormat, InventoryFrequency, InventoryObjectVersion } from 'aws-cdk-lib/aws-s3';\nimport { Construct } from 'constructs';\n\nexport interface BucketInventory {\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Name of the S3 bucket for which inventory data has been generated. Identifies the source bucket in inventory data organization and enables bucket-specific inventory querying through Glue table partitions.\n   *\n   * Use cases: Source bucket identification; Inventory data organization; Multi-bucket inventory management\n   *\n   * AWS: AWS S3 bucket name for inventory source identification in Glue table partitions\n   *\n   * Validation: Must be valid S3 bucket name (3-63 characters, lowercase, no underscores)\n   **/\n  readonly bucketName: string;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Name of the S3 inventory configuration that generated the inventory data for the specified bucket. Enables multiple inventory configurations per bucket and organized inventory data management.\n   *\n   * Use cases: Inventory configuration identification; Multiple inventories per bucket; Inventory data organization\n   *\n   * AWS: AWS S3 inventory configuration name for inventory data identification in Glue table partitions\n   *\n   * Validation: Must be valid S3 inventory configuration name matching the inventory ID used in S3 inventory setup\n   **/\n  readonly inventoryName: string;\n}\n\n/** Helper class for creating S3 Inventories and associated Glue/Athena resources for querying these inventories. */\nexport class InventoryHelper {\n  /**\n   * Helper method for creating an S3 inventory.\n   * @param destinationBucket The bucket where S3 inventory data will be written\n   * @param inventoryId The S3 inventory ID\n   * @param objectsPrefix The object prefix from which inventory will be produced (on the bucket to which the inventory config is applied)\n   * @param destinationPrefix The object prefix under which inventory will be written on the destination bucket.\n   * @returns An S3 Inventory Config which can be applied to a bucket in order to produce periodic inventory data.\n   */\n  public static createInvConfig(\n    destinationBucket: IBucket,\n    inventoryId: string,\n    objectsPrefix?: string,\n    destinationPrefix?: string,\n    destinationAccount?: string,\n  ): Inventory {\n    const bucketOwner = destinationAccount ? `${destinationAccount}` : destinationAccount;\n    return {\n      destination: {\n        bucket: destinationBucket,\n        /**\n         * Q-ENHANCED-PROPERTY\n         * Required S3 prefix for inventory report destination organization enabling systematic inventory file organization and management. Provides the S3 key prefix for inventory report storage enabling organized inventory data management and efficient retrieval of inventory reports.\n         *\n         * Use cases: Inventory organization; Report storage; Data management; Systematic file organization\n         *\n         * AWS: S3 inventory configuration destination prefix for inventory report organization and storage\n         *\n         * Validation: Must be valid S3 prefix string; required for inventory report destination organization\n         */\n        prefix: MdaaBucket.formatS3Prefix(destinationPrefix),\n        bucketOwner: bucketOwner,\n      },\n      format: InventoryFormat.PARQUET,\n      frequency: InventoryFrequency.DAILY,\n      includeObjectVersions: InventoryObjectVersion.ALL,\n      inventoryId: inventoryId,\n      objectsPrefix: MdaaBucket.formatS3Prefix(objectsPrefix, false, true),\n      optionalFields: [\n        'Size',\n        'LastModifiedDate',\n        'StorageClass',\n        'ETag',\n        'IsMultipartUploaded',\n        'ReplicationStatus',\n        'EncryptionStatus',\n        'ObjectLockRetainUntilDate',\n        'ObjectLockMode',\n        'ObjectLockLegalHoldStatus',\n        'IntelligentTieringAccessTier',\n      ],\n    };\n  }\n\n  /**\n   * Helper method for creating a Glue table which can be used to query inventory data generated by an S3 Inventory config\n   * @param scope Stack in which the table will be created\n   * @param tableNamePrefix Will be used to prefix the table name.\n   * @param locationBucketName The bucket where the inventory data is stored.\n   * @param inventoryBucket The bucket for which inventory data has been generated\n   * @param database The Glue database in which the table will be created\n   * @param inventoryName The name of the S3 Inventory config\n   * @param locationPrefix The S3 Prefix on the location bucket where the inventory is stored.\n   * @returns A Glue table which can be used to query S3 inventory data in an S3 bucket.\n   */\n  public static createGlueInvTable(\n    scope: Construct,\n    catalogId: string,\n    tableNamePrefix: string,\n    database: Database,\n    locationBucketName: string,\n    bucketInventories: BucketInventory[],\n    locationPrefix?: string,\n  ): CfnTable {\n    const location = locationPrefix\n      ? `s3://${locationBucketName}/${MdaaBucket.formatS3Prefix(locationPrefix)}/`\n      : `s3://${locationBucketName}/`;\n    const tableInput = {\n      name: `${tableNamePrefix}_inv`.replace(/-/gi, '_'),\n      parameters: {\n        EXTERNAL: 'TRUE',\n        'projection.enabled': 'true',\n        'projection.dt.type': 'date',\n        'projection.dt.range': '2022-01-01-00-00,NOW',\n        'projection.dt.format': 'yyyy-MM-dd-HH-mm',\n        'projection.dt.interval': '1',\n        'projection.dt.interval.unit': 'HOURS',\n        'projection.bucket_inventory.type': 'enum',\n        'projection.bucket_inventory.values': bucketInventories\n          .map(x => `${x.bucketName}/${x.inventoryName}`)\n          .join(','),\n        'storage.location.template': location + '${bucket_inventory}/hive/dt=${dt}',\n      },\n      tableType: 'EXTERNAL_TABLE',\n      partitionKeys: [\n        {\n          name: 'bucket_inventory',\n          type: 'string',\n        },\n        {\n          name: 'dt',\n          type: 'string',\n        },\n      ],\n      storageDescriptor: {\n        columns: [\n          {\n            name: 'bucket',\n            type: 'string',\n          },\n          {\n            name: 'key',\n            type: 'string',\n          },\n          {\n            name: 'version_id',\n            type: 'string',\n          },\n          {\n            name: 'is_latest',\n            type: 'boolean',\n          },\n          {\n            name: 'is_delete_marker',\n            type: 'boolean',\n          },\n          {\n            name: 'size',\n            type: 'bigint',\n          },\n          {\n            name: 'last_modified_date',\n            type: 'timestamp',\n          },\n          {\n            name: 'e_tag',\n            type: 'string',\n          },\n          {\n            name: 'storage_class',\n            type: 'string',\n          },\n          {\n            name: 'is_multipart_uploaded',\n            type: 'boolean',\n          },\n          {\n            name: 'replication_status',\n            type: 'string',\n          },\n          {\n            name: 'encryption_status',\n            type: 'string',\n          },\n          {\n            name: 'intelligent_tiering_tier',\n            type: 'string',\n          },\n          // ,\n          // {\n          //     name: \"object_lock_retain_until_date\",\n          //     type: \"timestamp\"\n          // },\n          // {\n          //     name: \"object_lock_mode\",\n          //     type: \"string\"\n          // },\n          // {\n          //     name: \"object_lock_legal_hold_status\",\n          //     type: \"string\"\n          // }\n        ],\n        location: location,\n        inputFormat: 'org.apache.hadoop.hive.ql.io.SymlinkTextInputFormat',\n        outputFormat: 'org.apache.hadoop.hive.ql.io.HiveIgnoreKeyTextOutputFormat',\n        compressed: false,\n        numberOfBuckets: -1,\n        serdeInfo: {\n          serializationLibrary: 'org.apache.hadoop.hive.ql.io.parquet.serde.ParquetHiveSerDe',\n          parameters: {\n            'serialization.format': '1',\n          },\n        },\n      },\n    };\n\n    const tableProps: CfnTableProps = {\n      catalogId: catalogId,\n      databaseName: database.databaseName,\n      tableInput: tableInput,\n    };\n    return new CfnTable(scope, `inv-table-${tableNamePrefix}`, tableProps);\n  }\n\n  /**\n   * Helper method to generate an S3 Bucket Policy Statement allowing S3 service to write inventories to a bucket.\n   * @param sourceBucketArn The bucket arn for which inventory data is being produced\n   * @param bucketArn  The bucket arn where inventory will be stored\n   * @param srcAccount The account which owns the source bucket from which inventory is being produced.\n   * @param inventoryPrefix The prefix on the destination bucket where inventory data will be stored.\n   * @returns A policy statement which permits the S3 service principal to write inventory for the source bucket/account to the destination bucket.\n   */\n  public static createInventoryBucketPolicyStatement(\n    bucketArn: string,\n    srcAccount: string,\n    sourceBucketArn?: string,\n    inventoryPrefix?: string,\n  ): PolicyStatement {\n    const resource = inventoryPrefix\n      ? `${bucketArn}/${MdaaBucket.formatS3Prefix(inventoryPrefix)}/*`\n      : `${bucketArn}/*`;\n    const allowS3Inventory = new PolicyStatement({\n      sid: 'AllowS3Inventory',\n      effect: Effect.ALLOW,\n      resources: [resource],\n      actions: ['s3:PutObject'],\n    });\n    allowS3Inventory.addCondition('StringEquals', {\n      'aws:SourceAccount': srcAccount,\n      's3:x-amz-acl': 'bucket-owner-full-control',\n    });\n    if (sourceBucketArn) {\n      allowS3Inventory.addCondition('ArnLike', {\n        'aws:SourceArn': sourceBucketArn,\n      });\n    }\n    allowS3Inventory.addServicePrincipal('s3.amazonaws.com');\n    return allowS3Inventory;\n  }\n}\n"]}
|
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
"name": "Amazon Web Services",
|
|
6
6
|
"url": "https://aws.amazon.com/solutions"
|
|
7
7
|
},
|
|
8
|
-
"version": "1.
|
|
8
|
+
"version": "1.4.0",
|
|
9
9
|
"main": "lib/index.js",
|
|
10
10
|
"types": "lib/index.d.ts",
|
|
11
11
|
"license": "Apache-2.0",
|
|
@@ -17,25 +17,21 @@
|
|
|
17
17
|
"test-coverage": "jest --passWithNoTests --coverage"
|
|
18
18
|
},
|
|
19
19
|
"devDependencies": {
|
|
20
|
-
"@types/jest": "29.5.
|
|
21
|
-
"@types/node": "
|
|
20
|
+
"@types/jest": "29.5.14",
|
|
21
|
+
"@types/node": "22.9.0",
|
|
22
22
|
"@types/prettier": "2.6.0",
|
|
23
|
-
"jest": "29.
|
|
24
|
-
"ts-jest": "29.
|
|
25
|
-
"ts-node": "10.9.
|
|
26
|
-
"typescript": "
|
|
27
|
-
"typescript-json-schema": "0.
|
|
28
|
-
},
|
|
29
|
-
"overrides": {
|
|
30
|
-
"aws-cdk-lib": "2.201.0",
|
|
31
|
-
"@types/babel__traverse": "7.18.2"
|
|
23
|
+
"jest": "29.7.0",
|
|
24
|
+
"ts-jest": "29.4.6",
|
|
25
|
+
"ts-node": "10.9.2",
|
|
26
|
+
"typescript": "5.9.3",
|
|
27
|
+
"typescript-json-schema": "0.67.1"
|
|
32
28
|
},
|
|
33
29
|
"dependencies": {
|
|
34
|
-
"@aws-cdk/aws-glue-alpha": "2.
|
|
35
|
-
"@aws-mdaa/naming": "1.
|
|
36
|
-
"@aws-mdaa/s3-constructs": "1.
|
|
37
|
-
"aws-cdk-lib": "2.
|
|
38
|
-
"cdk-nag": "2.37.
|
|
30
|
+
"@aws-cdk/aws-glue-alpha": "2.220.0-alpha.0",
|
|
31
|
+
"@aws-mdaa/naming": "1.4.0",
|
|
32
|
+
"@aws-mdaa/s3-constructs": "1.4.0",
|
|
33
|
+
"aws-cdk-lib": "2.220.0",
|
|
34
|
+
"cdk-nag": "2.37.55",
|
|
39
35
|
"constructs": "10.0.96"
|
|
40
36
|
},
|
|
41
37
|
"gitHead": "8b49a2b371014baec046605ffdbfe38951099c31",
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
# lodash v4.17.
|
|
1
|
+
# lodash v4.17.23
|
|
2
2
|
|
|
3
3
|
The [Lodash](https://lodash.com/) library exported as [Node.js](https://nodejs.org/) modules.
|
|
4
4
|
|
|
@@ -28,7 +28,7 @@ var at = require('lodash/at');
|
|
|
28
28
|
var curryN = require('lodash/fp/curryN');
|
|
29
29
|
```
|
|
30
30
|
|
|
31
|
-
See the [package source](https://github.com/lodash/lodash/tree/4.17.
|
|
31
|
+
See the [package source](https://github.com/lodash/lodash/tree/4.17.23-npm) for more details.
|
|
32
32
|
|
|
33
33
|
**Note:**<br>
|
|
34
34
|
Install [n_](https://www.npmjs.com/package/n_) for Lodash use in the Node.js < 6 REPL.
|
|
@@ -3,6 +3,12 @@ var castPath = require('./_castPath'),
|
|
|
3
3
|
parent = require('./_parent'),
|
|
4
4
|
toKey = require('./_toKey');
|
|
5
5
|
|
|
6
|
+
/** Used for built-in method references. */
|
|
7
|
+
var objectProto = Object.prototype;
|
|
8
|
+
|
|
9
|
+
/** Used to check objects for own properties. */
|
|
10
|
+
var hasOwnProperty = objectProto.hasOwnProperty;
|
|
11
|
+
|
|
6
12
|
/**
|
|
7
13
|
* The base implementation of `_.unset`.
|
|
8
14
|
*
|
|
@@ -13,8 +19,47 @@ var castPath = require('./_castPath'),
|
|
|
13
19
|
*/
|
|
14
20
|
function baseUnset(object, path) {
|
|
15
21
|
path = castPath(path, object);
|
|
16
|
-
|
|
17
|
-
|
|
22
|
+
|
|
23
|
+
// Prevent prototype pollution, see: https://github.com/lodash/lodash/security/advisories/GHSA-xxjr-mmjv-4gpg
|
|
24
|
+
var index = -1,
|
|
25
|
+
length = path.length;
|
|
26
|
+
|
|
27
|
+
if (!length) {
|
|
28
|
+
return true;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
var isRootPrimitive = object == null || (typeof object !== 'object' && typeof object !== 'function');
|
|
32
|
+
|
|
33
|
+
while (++index < length) {
|
|
34
|
+
var key = path[index];
|
|
35
|
+
|
|
36
|
+
// skip non-string keys (e.g., Symbols, numbers)
|
|
37
|
+
if (typeof key !== 'string') {
|
|
38
|
+
continue;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
// Always block "__proto__" anywhere in the path if it's not expected
|
|
42
|
+
if (key === '__proto__' && !hasOwnProperty.call(object, '__proto__')) {
|
|
43
|
+
return false;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
// Block "constructor.prototype" chains
|
|
47
|
+
if (key === 'constructor' &&
|
|
48
|
+
(index + 1) < length &&
|
|
49
|
+
typeof path[index + 1] === 'string' &&
|
|
50
|
+
path[index + 1] === 'prototype') {
|
|
51
|
+
|
|
52
|
+
// Allow ONLY when the path starts at a primitive root, e.g., _.unset(0, 'constructor.prototype.a')
|
|
53
|
+
if (isRootPrimitive && index === 0) {
|
|
54
|
+
continue;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
return false;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
var obj = parent(object, path);
|
|
62
|
+
return obj == null || delete obj[toKey(last(path))];
|
|
18
63
|
}
|
|
19
64
|
|
|
20
65
|
module.exports = baseUnset;
|
|
@@ -25,5 +25,5 @@ return G(2,n)},o.pick=$n,o.slice=function(n,t,r){var e=null==n?0:n.length;return
|
|
|
25
25
|
return t(n),n},o.thru=function(n,t){return t(n)},o.toArray=function(n){return M(n)?n.length?A(n):[]:W(n)},o.values=W,o.extend=Bn,Y(o,o),o.clone=function(n){return V(n)?Nn(n)?A(n):k(n,_n(n)):n},o.escape=function(n){return(n=Q(n))&&rn.test(n)?n.replace(tn,fn):n},o.every=function(n,t,r){return t=r?Z:t,f(n,g(t))},o.find=An,o.forEach=z,o.has=function(n,t){return null!=n&&pn.call(n,t)},o.head=q,o.identity=X,o.indexOf=P,o.isArguments=n,o.isArray=Nn,o.isBoolean=function(n){return true===n||false===n||H(n)&&"[object Boolean]"==hn.call(n);
|
|
26
26
|
},o.isDate=function(n){return H(n)&&"[object Date]"==hn.call(n)},o.isEmpty=function(t){return M(t)&&(Nn(t)||L(t)||U(t.splice)||n(t))?!t.length:!_n(t).length},o.isEqual=function(n,t){return b(n,t)},o.isFinite=function(n){return typeof n=="number"&&gn(n)},o.isFunction=U,o.isNaN=function(n){return K(n)&&n!=+n},o.isNull=function(n){return null===n},o.isNumber=K,o.isObject=V,o.isRegExp=function(n){return H(n)&&"[object RegExp]"==hn.call(n)},o.isString=L,o.isUndefined=function(n){return n===Z},o.last=function(n){
|
|
27
27
|
var t=null==n?0:n.length;return t?n[t-1]:Z},o.max=function(n){return n&&n.length?a(n,X,v):Z},o.min=function(n){return n&&n.length?a(n,X,_):Z},o.noConflict=function(){return on._===this&&(on._=vn),this},o.noop=function(){},o.reduce=C,o.result=function(n,t,r){return t=null==n?Z:n[t],t===Z&&(t=r),U(t)?t.call(n):t},o.size=function(n){return null==n?0:(n=M(n)?n:_n(n),n.length)},o.some=function(n,t,r){return t=r?Z:t,E(n,g(t))},o.uniqueId=function(n){var t=++sn;return Q(n)+t},o.each=z,o.first=q,Y(o,function(){
|
|
28
|
-
var n={};return s(o,function(t,r){pn.call(o.prototype,r)||(n[r]=t)}),n}(),{chain:false}),o.VERSION="4.17.
|
|
28
|
+
var n={};return s(o,function(t,r){pn.call(o.prototype,r)||(n[r]=t)}),n}(),{chain:false}),o.VERSION="4.17.23",mn("pop join replace reverse split push shift sort splice unshift".split(" "),function(n){var t=(/^(?:replace|split)$/.test(n)?String.prototype:an)[n],r=/^(?:push|sort|unshift)$/.test(n)?"tap":"thru",e=/^(?:pop|join|replace|shift)$/.test(n);o.prototype[n]=function(){var n=arguments;if(e&&!this.__chain__){var u=this.value();return t.apply(Nn(u)?u:[],n)}return this[r](function(r){return t.apply(Nn(r)?r:[],n);
|
|
29
29
|
})}}),o.prototype.toJSON=o.prototype.valueOf=o.prototype.value=function(){return w(this.__wrapped__,this.__actions__)},typeof define=="function"&&typeof define.amd=="object"&&define.amd?(on._=o, define(function(){return o})):cn?((cn.exports=o)._=o,un._=o):on._=o}).call(this);
|
|
@@ -12,7 +12,7 @@
|
|
|
12
12
|
var undefined;
|
|
13
13
|
|
|
14
14
|
/** Used as the semantic version number. */
|
|
15
|
-
var VERSION = '4.17.
|
|
15
|
+
var VERSION = '4.17.23';
|
|
16
16
|
|
|
17
17
|
/** Used as the size to enable large array optimizations. */
|
|
18
18
|
var LARGE_ARRAY_SIZE = 200;
|
|
@@ -3766,7 +3766,7 @@
|
|
|
3766
3766
|
if (isArray(iteratee)) {
|
|
3767
3767
|
return function(value) {
|
|
3768
3768
|
return baseGet(value, iteratee.length === 1 ? iteratee[0] : iteratee);
|
|
3769
|
-
}
|
|
3769
|
+
};
|
|
3770
3770
|
}
|
|
3771
3771
|
return iteratee;
|
|
3772
3772
|
});
|
|
@@ -4370,8 +4370,47 @@
|
|
|
4370
4370
|
*/
|
|
4371
4371
|
function baseUnset(object, path) {
|
|
4372
4372
|
path = castPath(path, object);
|
|
4373
|
-
|
|
4374
|
-
|
|
4373
|
+
|
|
4374
|
+
// Prevent prototype pollution, see: https://github.com/lodash/lodash/security/advisories/GHSA-xxjr-mmjv-4gpg
|
|
4375
|
+
var index = -1,
|
|
4376
|
+
length = path.length;
|
|
4377
|
+
|
|
4378
|
+
if (!length) {
|
|
4379
|
+
return true;
|
|
4380
|
+
}
|
|
4381
|
+
|
|
4382
|
+
var isRootPrimitive = object == null || (typeof object !== 'object' && typeof object !== 'function');
|
|
4383
|
+
|
|
4384
|
+
while (++index < length) {
|
|
4385
|
+
var key = path[index];
|
|
4386
|
+
|
|
4387
|
+
// skip non-string keys (e.g., Symbols, numbers)
|
|
4388
|
+
if (typeof key !== 'string') {
|
|
4389
|
+
continue;
|
|
4390
|
+
}
|
|
4391
|
+
|
|
4392
|
+
// Always block "__proto__" anywhere in the path if it's not expected
|
|
4393
|
+
if (key === '__proto__' && !hasOwnProperty.call(object, '__proto__')) {
|
|
4394
|
+
return false;
|
|
4395
|
+
}
|
|
4396
|
+
|
|
4397
|
+
// Block "constructor.prototype" chains
|
|
4398
|
+
if (key === 'constructor' &&
|
|
4399
|
+
(index + 1) < length &&
|
|
4400
|
+
typeof path[index + 1] === 'string' &&
|
|
4401
|
+
path[index + 1] === 'prototype') {
|
|
4402
|
+
|
|
4403
|
+
// Allow ONLY when the path starts at a primitive root, e.g., _.unset(0, 'constructor.prototype.a')
|
|
4404
|
+
if (isRootPrimitive && index === 0) {
|
|
4405
|
+
continue;
|
|
4406
|
+
}
|
|
4407
|
+
|
|
4408
|
+
return false;
|
|
4409
|
+
}
|
|
4410
|
+
}
|
|
4411
|
+
|
|
4412
|
+
var obj = parent(object, path);
|
|
4413
|
+
return obj == null || delete obj[toKey(last(path))];
|
|
4375
4414
|
}
|
|
4376
4415
|
|
|
4377
4416
|
/**
|