@bitblit/ratchet-aws 4.0.419-alpha → 4.0.421-alpha
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/lib/batch/aws-batch-background-processor.d.ts +8 -0
- package/lib/batch/aws-batch-background-processor.js +46 -0
- package/lib/batch/aws-batch-background-processor.js.map +1 -0
- package/lib/batch/aws-batch-ratchet.d.ts +13 -0
- package/lib/batch/aws-batch-ratchet.js +56 -0
- package/lib/batch/aws-batch-ratchet.js.map +1 -0
- package/lib/batch/index.d.ts +2 -0
- package/lib/batch/index.js +3 -0
- package/lib/batch/index.js.map +1 -0
- package/lib/build/index.d.ts +1 -0
- package/lib/build/index.js +2 -0
- package/lib/build/index.js.map +1 -0
- package/lib/build/ratchet-aws-info.d.ts +5 -0
- package/lib/build/ratchet-aws-info.js +15 -0
- package/lib/build/ratchet-aws-info.js.map +1 -0
- package/lib/cache/index.d.ts +5 -0
- package/lib/cache/index.js +6 -0
- package/lib/cache/index.js.map +1 -0
- package/lib/cache/memory-storage-provider.d.ts +10 -0
- package/lib/cache/memory-storage-provider.js +28 -0
- package/lib/cache/memory-storage-provider.js.map +1 -0
- package/lib/cache/simple-cache-object-wrapper.d.ts +7 -0
- package/lib/cache/simple-cache-object-wrapper.js +2 -0
- package/lib/cache/simple-cache-object-wrapper.js.map +1 -0
- package/lib/cache/simple-cache-read-options.d.ts +5 -0
- package/lib/cache/simple-cache-read-options.js +2 -0
- package/lib/cache/simple-cache-read-options.js.map +1 -0
- package/lib/cache/simple-cache-storage-provider.d.ts +8 -0
- package/lib/cache/simple-cache-storage-provider.js +2 -0
- package/lib/cache/simple-cache-storage-provider.js.map +1 -0
- package/lib/cache/simple-cache.d.ts +14 -0
- package/lib/cache/simple-cache.js +65 -0
- package/lib/cache/simple-cache.js.map +1 -0
- package/lib/cloudwatch/cloud-watch-log-group-ratchet.d.ts +10 -0
- package/lib/cloudwatch/cloud-watch-log-group-ratchet.js +75 -0
- package/lib/cloudwatch/cloud-watch-log-group-ratchet.js.map +1 -0
- package/lib/cloudwatch/cloud-watch-logs-ratchet.d.ts +15 -0
- package/lib/cloudwatch/cloud-watch-logs-ratchet.js +174 -0
- package/lib/cloudwatch/cloud-watch-logs-ratchet.js.map +1 -0
- package/lib/cloudwatch/cloud-watch-metrics-ratchet.d.ts +10 -0
- package/lib/cloudwatch/cloud-watch-metrics-ratchet.js +57 -0
- package/lib/cloudwatch/cloud-watch-metrics-ratchet.js.map +1 -0
- package/lib/cloudwatch/index.d.ts +3 -0
- package/lib/cloudwatch/index.js +4 -0
- package/lib/cloudwatch/index.js.map +1 -0
- package/lib/daemon/daemon-like.d.ts +16 -0
- package/lib/daemon/daemon-like.js +2 -0
- package/lib/daemon/daemon-like.js.map +1 -0
- package/lib/daemon/daemon-process-create-options.d.ts +7 -0
- package/lib/daemon/daemon-process-create-options.js +2 -0
- package/lib/daemon/daemon-process-create-options.js.map +1 -0
- package/lib/daemon/daemon-process-state-public-token.d.ts +4 -0
- package/lib/daemon/daemon-process-state-public-token.js +2 -0
- package/lib/daemon/daemon-process-state-public-token.js.map +1 -0
- package/lib/daemon/daemon-process-state.d.ts +13 -0
- package/lib/daemon/daemon-process-state.js +2 -0
- package/lib/daemon/daemon-process-state.js.map +1 -0
- package/lib/daemon/daemon-stream-data-options.d.ts +5 -0
- package/lib/daemon/daemon-stream-data-options.js +2 -0
- package/lib/daemon/daemon-stream-data-options.js.map +1 -0
- package/lib/daemon/daemon-util.d.ts +17 -0
- package/lib/daemon/daemon-util.js +154 -0
- package/lib/daemon/daemon-util.js.map +1 -0
- package/lib/daemon/daemon.d.ts +32 -0
- package/lib/daemon/daemon.js +129 -0
- package/lib/daemon/daemon.js.map +1 -0
- package/lib/daemon/index.d.ts +7 -0
- package/lib/daemon/index.js +8 -0
- package/lib/daemon/index.js.map +1 -0
- package/lib/dao/example-prototype-dao-item.d.ts +8 -0
- package/lib/dao/example-prototype-dao-item.js +2 -0
- package/lib/dao/example-prototype-dao-item.js.map +1 -0
- package/lib/dao/index.d.ts +8 -0
- package/lib/dao/index.js +9 -0
- package/lib/dao/index.js.map +1 -0
- package/lib/dao/memory-prototype-dao-provider.d.ts +7 -0
- package/lib/dao/memory-prototype-dao-provider.js +11 -0
- package/lib/dao/memory-prototype-dao-provider.js.map +1 -0
- package/lib/dao/prototype-dao-config.d.ts +8 -0
- package/lib/dao/prototype-dao-config.js +2 -0
- package/lib/dao/prototype-dao-config.js.map +1 -0
- package/lib/dao/prototype-dao-db.d.ts +4 -0
- package/lib/dao/prototype-dao-db.js +2 -0
- package/lib/dao/prototype-dao-db.js.map +1 -0
- package/lib/dao/prototype-dao-provider.d.ts +5 -0
- package/lib/dao/prototype-dao-provider.js +2 -0
- package/lib/dao/prototype-dao-provider.js.map +1 -0
- package/lib/dao/prototype-dao.d.ts +15 -0
- package/lib/dao/prototype-dao.js +89 -0
- package/lib/dao/prototype-dao.js.map +1 -0
- package/lib/dao/s3-simple-dao.d.ts +15 -0
- package/lib/dao/s3-simple-dao.js +77 -0
- package/lib/dao/s3-simple-dao.js.map +1 -0
- package/lib/dao/simple-dao-item.d.ts +5 -0
- package/lib/dao/simple-dao-item.js +2 -0
- package/lib/dao/simple-dao-item.js.map +1 -0
- package/lib/dynamodb/dynamo-ratchet-like.d.ts +25 -0
- package/lib/dynamodb/dynamo-ratchet-like.js +2 -0
- package/lib/dynamodb/dynamo-ratchet-like.js.map +1 -0
- package/lib/dynamodb/dynamo-ratchet.d.ts +34 -0
- package/lib/dynamodb/dynamo-ratchet.js +671 -0
- package/lib/dynamodb/dynamo-ratchet.js.map +1 -0
- package/lib/dynamodb/dynamo-table-ratchet.d.ts +13 -0
- package/lib/dynamodb/dynamo-table-ratchet.js +140 -0
- package/lib/dynamodb/dynamo-table-ratchet.js.map +1 -0
- package/lib/dynamodb/hash-spreader.d.ts +15 -0
- package/lib/dynamodb/hash-spreader.js +66 -0
- package/lib/dynamodb/hash-spreader.js.map +1 -0
- package/lib/dynamodb/impl/dynamo-db-storage-provider.d.ts +25 -0
- package/lib/dynamodb/impl/dynamo-db-storage-provider.js +110 -0
- package/lib/dynamodb/impl/dynamo-db-storage-provider.js.map +1 -0
- package/lib/dynamodb/impl/dynamo-db-sync-lock.d.ts +10 -0
- package/lib/dynamodb/impl/dynamo-db-sync-lock.js +71 -0
- package/lib/dynamodb/impl/dynamo-db-sync-lock.js.map +1 -0
- package/lib/dynamodb/impl/dynamo-expiring-code-provider.d.ts +12 -0
- package/lib/dynamodb/impl/dynamo-expiring-code-provider.js +25 -0
- package/lib/dynamodb/impl/dynamo-expiring-code-provider.js.map +1 -0
- package/lib/dynamodb/impl/dynamo-runtime-parameter-provider.d.ts +11 -0
- package/lib/dynamodb/impl/dynamo-runtime-parameter-provider.js +37 -0
- package/lib/dynamodb/impl/dynamo-runtime-parameter-provider.js.map +1 -0
- package/lib/dynamodb/index.d.ts +8 -0
- package/lib/dynamodb/index.js +9 -0
- package/lib/dynamodb/index.js.map +1 -0
- package/lib/ec2/ec2-ratchet.d.ts +16 -0
- package/lib/ec2/ec2-ratchet.js +114 -0
- package/lib/ec2/ec2-ratchet.js.map +1 -0
- package/lib/ec2/index.d.ts +1 -0
- package/lib/ec2/index.js +2 -0
- package/lib/ec2/index.js.map +1 -0
- package/lib/ecr/ecr-unused-image-cleaner-options.d.ts +7 -0
- package/lib/ecr/ecr-unused-image-cleaner-options.js +2 -0
- package/lib/ecr/ecr-unused-image-cleaner-options.js.map +1 -0
- package/lib/ecr/ecr-unused-image-cleaner-output.d.ts +7 -0
- package/lib/ecr/ecr-unused-image-cleaner-output.js +2 -0
- package/lib/ecr/ecr-unused-image-cleaner-output.js.map +1 -0
- package/lib/ecr/ecr-unused-image-cleaner-repository-output.d.ts +8 -0
- package/lib/ecr/ecr-unused-image-cleaner-repository-output.js +2 -0
- package/lib/ecr/ecr-unused-image-cleaner-repository-output.js.map +1 -0
- package/lib/ecr/ecr-unused-image-cleaner.d.ts +18 -0
- package/lib/ecr/ecr-unused-image-cleaner.js +136 -0
- package/lib/ecr/ecr-unused-image-cleaner.js.map +1 -0
- package/lib/ecr/index.d.ts +9 -0
- package/lib/ecr/index.js +10 -0
- package/lib/ecr/index.js.map +1 -0
- package/lib/ecr/retained-image-descriptor.d.ts +6 -0
- package/lib/ecr/retained-image-descriptor.js +2 -0
- package/lib/ecr/retained-image-descriptor.js.map +1 -0
- package/lib/ecr/retained-image-reason.d.ts +4 -0
- package/lib/ecr/retained-image-reason.js +6 -0
- package/lib/ecr/retained-image-reason.js.map +1 -0
- package/lib/ecr/used-image-finder.d.ts +3 -0
- package/lib/ecr/used-image-finder.js +2 -0
- package/lib/ecr/used-image-finder.js.map +1 -0
- package/lib/ecr/used-image-finders/aws-batch-used-image-finder.d.ts +8 -0
- package/lib/ecr/used-image-finders/aws-batch-used-image-finder.js +32 -0
- package/lib/ecr/used-image-finders/aws-batch-used-image-finder.js.map +1 -0
- package/lib/ecr/used-image-finders/lambda-used-image-finder.d.ts +8 -0
- package/lib/ecr/used-image-finders/lambda-used-image-finder.js +40 -0
- package/lib/ecr/used-image-finders/lambda-used-image-finder.js.map +1 -0
- package/lib/environment/cascade-environment-service-provider.d.ts +6 -0
- package/lib/environment/cascade-environment-service-provider.js +25 -0
- package/lib/environment/cascade-environment-service-provider.js.map +1 -0
- package/lib/environment/env-var-environment-service-provider.d.ts +6 -0
- package/lib/environment/env-var-environment-service-provider.js +31 -0
- package/lib/environment/env-var-environment-service-provider.js.map +1 -0
- package/lib/environment/environment-service-config.d.ts +4 -0
- package/lib/environment/environment-service-config.js +2 -0
- package/lib/environment/environment-service-config.js.map +1 -0
- package/lib/environment/environment-service-provider.d.ts +3 -0
- package/lib/environment/environment-service-provider.js +2 -0
- package/lib/environment/environment-service-provider.js.map +1 -0
- package/lib/environment/environment-service.d.ts +11 -0
- package/lib/environment/environment-service.js +51 -0
- package/lib/environment/environment-service.js.map +1 -0
- package/lib/environment/fixed-environment-service-provider.d.ts +7 -0
- package/lib/environment/fixed-environment-service-provider.js +22 -0
- package/lib/environment/fixed-environment-service-provider.js.map +1 -0
- package/lib/environment/index.d.ts +7 -0
- package/lib/environment/index.js +8 -0
- package/lib/environment/index.js.map +1 -0
- package/lib/environment/ssm-environment-service-provider.d.ts +8 -0
- package/lib/environment/ssm-environment-service-provider.js +59 -0
- package/lib/environment/ssm-environment-service-provider.js.map +1 -0
- package/lib/expiring-code/expiring-code-params.d.ts +7 -0
- package/lib/expiring-code/expiring-code-params.js +2 -0
- package/lib/expiring-code/expiring-code-params.js.map +1 -0
- package/lib/expiring-code/expiring-code-provider.d.ts +5 -0
- package/lib/expiring-code/expiring-code-provider.js +2 -0
- package/lib/expiring-code/expiring-code-provider.js.map +1 -0
- package/lib/expiring-code/expiring-code-ratchet.d.ts +10 -0
- package/lib/expiring-code/expiring-code-ratchet.js +35 -0
- package/lib/expiring-code/expiring-code-ratchet.js.map +1 -0
- package/lib/expiring-code/expiring-code.d.ts +6 -0
- package/lib/expiring-code/expiring-code.js +2 -0
- package/lib/expiring-code/expiring-code.js.map +1 -0
- package/lib/expiring-code/index.d.ts +4 -0
- package/lib/expiring-code/index.js +5 -0
- package/lib/expiring-code/index.js.map +1 -0
- package/lib/iam/aws-credentials-ratchet.d.ts +4 -0
- package/lib/iam/aws-credentials-ratchet.js +19 -0
- package/lib/iam/aws-credentials-ratchet.js.map +1 -0
- package/lib/iam/index.d.ts +1 -0
- package/lib/iam/index.js +2 -0
- package/lib/iam/index.js.map +1 -0
- package/lib/lambda/index.d.ts +2 -0
- package/lib/lambda/index.js +3 -0
- package/lib/lambda/index.js.map +1 -0
- package/lib/lambda/lambda-event-detector.d.ts +15 -0
- package/lib/lambda/lambda-event-detector.js +42 -0
- package/lib/lambda/lambda-event-detector.js.map +1 -0
- package/lib/lambda/lambda-event-type-guards.d.ts +11 -0
- package/lib/lambda/lambda-event-type-guards.js +28 -0
- package/lib/lambda/lambda-event-type-guards.js.map +1 -0
- package/lib/model/cloud-watch-metrics-minute-level-dynamo-count-request.d.ts +12 -0
- package/lib/model/cloud-watch-metrics-minute-level-dynamo-count-request.js +2 -0
- package/lib/model/cloud-watch-metrics-minute-level-dynamo-count-request.js.map +1 -0
- package/lib/model/dynamo-count-result.d.ts +5 -0
- package/lib/model/dynamo-count-result.js +2 -0
- package/lib/model/dynamo-count-result.js.map +1 -0
- package/lib/model/index.d.ts +2 -0
- package/lib/model/index.js +3 -0
- package/lib/model/index.js.map +1 -0
- package/lib/route53/index.d.ts +1 -0
- package/lib/route53/index.js +2 -0
- package/lib/route53/index.js.map +1 -0
- package/lib/route53/route-53-ratchet.d.ts +8 -0
- package/lib/route53/route-53-ratchet.js +59 -0
- package/lib/route53/route-53-ratchet.js.map +1 -0
- package/lib/runtime-parameter/cached-stored-runtime-parameter.d.ts +4 -0
- package/lib/runtime-parameter/cached-stored-runtime-parameter.js +2 -0
- package/lib/runtime-parameter/cached-stored-runtime-parameter.js.map +1 -0
- package/lib/runtime-parameter/global-variable-override-runtime-parameter-provider.d.ts +17 -0
- package/lib/runtime-parameter/global-variable-override-runtime-parameter-provider.js +52 -0
- package/lib/runtime-parameter/global-variable-override-runtime-parameter-provider.js.map +1 -0
- package/lib/runtime-parameter/index.d.ts +6 -0
- package/lib/runtime-parameter/index.js +7 -0
- package/lib/runtime-parameter/index.js.map +1 -0
- package/lib/runtime-parameter/memory-runtime-parameter-provider.d.ts +10 -0
- package/lib/runtime-parameter/memory-runtime-parameter-provider.js +35 -0
- package/lib/runtime-parameter/memory-runtime-parameter-provider.js.map +1 -0
- package/lib/runtime-parameter/runtime-parameter-provider.d.ts +6 -0
- package/lib/runtime-parameter/runtime-parameter-provider.js +2 -0
- package/lib/runtime-parameter/runtime-parameter-provider.js.map +1 -0
- package/lib/runtime-parameter/runtime-parameter-ratchet.d.ts +15 -0
- package/lib/runtime-parameter/runtime-parameter-ratchet.js +72 -0
- package/lib/runtime-parameter/runtime-parameter-ratchet.js.map +1 -0
- package/lib/runtime-parameter/stored-runtime-parameter.d.ts +6 -0
- package/lib/runtime-parameter/stored-runtime-parameter.js +2 -0
- package/lib/runtime-parameter/stored-runtime-parameter.js.map +1 -0
- package/lib/s3/expanded-file-children.d.ts +5 -0
- package/lib/s3/expanded-file-children.js +2 -0
- package/lib/s3/expanded-file-children.js.map +1 -0
- package/lib/s3/impl/s3-environment-service-provider.d.ts +15 -0
- package/lib/s3/impl/s3-environment-service-provider.js +28 -0
- package/lib/s3/impl/s3-environment-service-provider.js.map +1 -0
- package/lib/s3/impl/s3-expiring-code-provider.d.ts +17 -0
- package/lib/s3/impl/s3-expiring-code-provider.js +49 -0
- package/lib/s3/impl/s3-expiring-code-provider.js.map +1 -0
- package/lib/s3/impl/s3-prototype-dao-provider.d.ts +10 -0
- package/lib/s3/impl/s3-prototype-dao-provider.js +27 -0
- package/lib/s3/impl/s3-prototype-dao-provider.js.map +1 -0
- package/lib/s3/impl/s3-storage-provider.d.ts +14 -0
- package/lib/s3/impl/s3-storage-provider.js +44 -0
- package/lib/s3/impl/s3-storage-provider.js.map +1 -0
- package/lib/s3/index.d.ts +9 -0
- package/lib/s3/index.js +10 -0
- package/lib/s3/index.js.map +1 -0
- package/lib/s3/s3-cache-ratchet-like.d.ts +25 -0
- package/lib/s3/s3-cache-ratchet-like.js +2 -0
- package/lib/s3/s3-cache-ratchet-like.js.map +1 -0
- package/lib/s3/s3-cache-ratchet.d.ts +35 -0
- package/lib/s3/s3-cache-ratchet.js +360 -0
- package/lib/s3/s3-cache-ratchet.js.map +1 -0
- package/lib/s3/s3-location-sync-ratchet.d.ts +21 -0
- package/lib/s3/s3-location-sync-ratchet.js +140 -0
- package/lib/s3/s3-location-sync-ratchet.js.map +1 -0
- package/lib/s3/s3-ratchet.d.ts +5 -0
- package/lib/s3/s3-ratchet.js +23 -0
- package/lib/s3/s3-ratchet.js.map +1 -0
- package/lib/ses/index.d.ts +1 -0
- package/lib/ses/index.js +2 -0
- package/lib/ses/index.js.map +1 -0
- package/lib/ses/ses-mail-sending-provider.d.ts +15 -0
- package/lib/ses/ses-mail-sending-provider.js +68 -0
- package/lib/ses/ses-mail-sending-provider.js.map +1 -0
- package/lib/sns/index.d.ts +1 -0
- package/lib/sns/index.js +2 -0
- package/lib/sns/index.js.map +1 -0
- package/lib/sns/sns-ratchet.d.ts +9 -0
- package/lib/sns/sns-ratchet.js +49 -0
- package/lib/sns/sns-ratchet.js.map +1 -0
- package/lib/sync-lock/index.d.ts +2 -0
- package/lib/sync-lock/index.js +3 -0
- package/lib/sync-lock/index.js.map +1 -0
- package/lib/sync-lock/memory-sync-lock.d.ts +8 -0
- package/lib/sync-lock/memory-sync-lock.js +36 -0
- package/lib/sync-lock/memory-sync-lock.js.map +1 -0
- package/lib/sync-lock/sync-lock-provider.d.ts +5 -0
- package/lib/sync-lock/sync-lock-provider.js +2 -0
- package/lib/sync-lock/sync-lock-provider.js.map +1 -0
- package/package.json +55 -56
- package/lib/index.mjs +0 -2
- package/lib/types.d.ts +0 -818
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { RequireRatchet } from '@bitblit/ratchet-common/lang/require-ratchet';
|
|
2
|
+
import { Logger } from '@bitblit/ratchet-common/logger/logger';
|
|
3
|
+
export class CascadeEnvironmentServiceProvider {
|
|
4
|
+
providers;
|
|
5
|
+
constructor(providers) {
|
|
6
|
+
this.providers = providers;
|
|
7
|
+
RequireRatchet.notNullOrUndefined(providers);
|
|
8
|
+
RequireRatchet.true(providers.length > 0);
|
|
9
|
+
}
|
|
10
|
+
async fetchConfig(name) {
|
|
11
|
+
Logger.silly('CascadeEnvironmentServiceProvider fetch for %s', name);
|
|
12
|
+
let rval = null;
|
|
13
|
+
for (let i = 0; i < this.providers.length && !rval; i++) {
|
|
14
|
+
try {
|
|
15
|
+
rval = await this.providers[i].fetchConfig(name);
|
|
16
|
+
}
|
|
17
|
+
catch (err) {
|
|
18
|
+
Logger.error('Provider %d failed - trying next : %s', i, err, err);
|
|
19
|
+
rval = null;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
return rval;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=cascade-environment-service-provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cascade-environment-service-provider.js","sourceRoot":"","sources":["../../src/environment/cascade-environment-service-provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,8CAA8C,CAAC;AAC9E,OAAO,EAAE,MAAM,EAAE,MAAM,uCAAuC,CAAC;AAM/D,MAAM,OAAO,iCAAiC;IACjB;IAA3B,YAA2B,SAA0C;QAA1C,cAAS,GAAT,SAAS,CAAiC;QACnE,cAAc,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;QAC7C,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAC5C,CAAC;IAEM,KAAK,CAAC,WAAW,CAAC,IAAY;QACnC,MAAM,CAAC,KAAK,CAAC,gDAAgD,EAAE,IAAI,CAAC,CAAC;QACrE,IAAI,IAAI,GAAM,IAAI,CAAC;QACnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC;YACxD,IAAI,CAAC;gBACH,IAAI,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YACnD,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,MAAM,CAAC,KAAK,CAAC,uCAAuC,EAAE,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;gBACnE,IAAI,GAAG,IAAI,CAAC;YACd,CAAC;QACH,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { EnvironmentServiceProvider } from './environment-service-provider.js';
|
|
2
|
+
export declare class EnvVarEnvironmentServiceProvider<T> implements EnvironmentServiceProvider<T> {
|
|
3
|
+
private envVarName;
|
|
4
|
+
constructor(envVarName: string);
|
|
5
|
+
fetchConfig(): Promise<T>;
|
|
6
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { RequireRatchet } from '@bitblit/ratchet-common/lang/require-ratchet';
|
|
2
|
+
import { Logger } from '@bitblit/ratchet-common/logger/logger';
|
|
3
|
+
import { ErrorRatchet } from '@bitblit/ratchet-common/lang/error-ratchet';
|
|
4
|
+
import { StringRatchet } from '@bitblit/ratchet-common/lang/string-ratchet';
|
|
5
|
+
export class EnvVarEnvironmentServiceProvider {
|
|
6
|
+
envVarName;
|
|
7
|
+
constructor(envVarName) {
|
|
8
|
+
this.envVarName = envVarName;
|
|
9
|
+
RequireRatchet.notNullOrUndefined(envVarName);
|
|
10
|
+
}
|
|
11
|
+
async fetchConfig() {
|
|
12
|
+
Logger.silly('EnvVarEnvironmentServiceProvider fetch for %s', this.envVarName);
|
|
13
|
+
let rval = null;
|
|
14
|
+
const src = process ? process.env : global ? global : {};
|
|
15
|
+
const toParse = StringRatchet.trimToNull(src[this.envVarName]);
|
|
16
|
+
if (toParse) {
|
|
17
|
+
try {
|
|
18
|
+
rval = JSON.parse(toParse);
|
|
19
|
+
}
|
|
20
|
+
catch (err) {
|
|
21
|
+
Logger.error('Failed to read env - null or invalid JSON : %s : %s', err, toParse, err);
|
|
22
|
+
throw err;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
ErrorRatchet.throwFormattedErr('Could not find env var with name : %s', this.envVarName);
|
|
27
|
+
}
|
|
28
|
+
return rval;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=env-var-environment-service-provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"env-var-environment-service-provider.js","sourceRoot":"","sources":["../../src/environment/env-var-environment-service-provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,8CAA8C,CAAC;AAC9E,OAAO,EAAE,MAAM,EAAE,MAAM,uCAAuC,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,4CAA4C,CAAC;AAC1E,OAAO,EAAE,aAAa,EAAE,MAAM,6CAA6C,CAAC;AAO5E,MAAM,OAAO,gCAAgC;IAChB;IAA3B,YAA2B,UAAkB;QAAlB,eAAU,GAAV,UAAU,CAAQ;QAC3C,cAAc,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC;IAChD,CAAC;IAEM,KAAK,CAAC,WAAW;QACtB,MAAM,CAAC,KAAK,CAAC,+CAA+C,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QAE/E,IAAI,IAAI,GAAM,IAAI,CAAC;QACnB,MAAM,GAAG,GAAwB,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;QAC9E,MAAM,OAAO,GAAW,aAAa,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;QAGvE,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,CAAC;gBACH,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAC7B,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,MAAM,CAAC,KAAK,CAAC,qDAAqD,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,CAAC,CAAC;gBACvF,MAAM,GAAG,CAAC;YACZ,CAAC;QACH,CAAC;aAAM,CAAC;YACN,YAAY,CAAC,iBAAiB,CAAC,uCAAuC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QAC3F,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"environment-service-config.js","sourceRoot":"","sources":["../../src/environment/environment-service-config.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"environment-service-provider.js","sourceRoot":"","sources":["../../src/environment/environment-service-provider.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { EnvironmentServiceProvider } from './environment-service-provider.js';
|
|
2
|
+
import { EnvironmentServiceConfig } from './environment-service-config.js';
|
|
3
|
+
export declare class EnvironmentService<T> {
|
|
4
|
+
private provider;
|
|
5
|
+
private cfg;
|
|
6
|
+
private readPromiseCache;
|
|
7
|
+
static defaultEnvironmentServiceConfig(): EnvironmentServiceConfig;
|
|
8
|
+
constructor(provider: EnvironmentServiceProvider<T>, cfg?: EnvironmentServiceConfig);
|
|
9
|
+
getConfig(name: string): Promise<T>;
|
|
10
|
+
private getConfigUncached;
|
|
11
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { RequireRatchet } from '@bitblit/ratchet-common/lang/require-ratchet';
|
|
2
|
+
import { Logger } from '@bitblit/ratchet-common/logger/logger';
|
|
3
|
+
import { ErrorRatchet } from '@bitblit/ratchet-common/lang/error-ratchet';
|
|
4
|
+
import { PromiseRatchet } from '@bitblit/ratchet-common/lang/promise-ratchet';
|
|
5
|
+
export class EnvironmentService {
|
|
6
|
+
provider;
|
|
7
|
+
cfg;
|
|
8
|
+
readPromiseCache = new Map();
|
|
9
|
+
static defaultEnvironmentServiceConfig() {
|
|
10
|
+
const rval = {
|
|
11
|
+
maxRetries: 3,
|
|
12
|
+
backoffMultiplierMS: 500,
|
|
13
|
+
};
|
|
14
|
+
return rval;
|
|
15
|
+
}
|
|
16
|
+
constructor(provider, cfg = EnvironmentService.defaultEnvironmentServiceConfig()) {
|
|
17
|
+
this.provider = provider;
|
|
18
|
+
this.cfg = cfg;
|
|
19
|
+
RequireRatchet.notNullOrUndefined(provider);
|
|
20
|
+
RequireRatchet.notNullOrUndefined(cfg);
|
|
21
|
+
}
|
|
22
|
+
async getConfig(name) {
|
|
23
|
+
Logger.silly('EnvService:Request to read config %s', name);
|
|
24
|
+
if (!this.readPromiseCache.has(name)) {
|
|
25
|
+
Logger.silly('EnvService: Nothing in cache - adding');
|
|
26
|
+
this.readPromiseCache.set(name, this.getConfigUncached(name));
|
|
27
|
+
}
|
|
28
|
+
return this.readPromiseCache.get(name);
|
|
29
|
+
}
|
|
30
|
+
async getConfigUncached(name) {
|
|
31
|
+
let tryCount = 1;
|
|
32
|
+
let rval = null;
|
|
33
|
+
while (!rval && tryCount < this.cfg.maxRetries) {
|
|
34
|
+
tryCount++;
|
|
35
|
+
Logger.silly('Attempting fetch of %s', name);
|
|
36
|
+
try {
|
|
37
|
+
rval = await this.provider.fetchConfig(name);
|
|
38
|
+
}
|
|
39
|
+
catch (err) {
|
|
40
|
+
const waitMS = tryCount * this.cfg.backoffMultiplierMS;
|
|
41
|
+
Logger.info('Error attempting to fetch config %s (try %d of %d, waiting %s MS): %s', name, tryCount, this.cfg.maxRetries, waitMS, err, err);
|
|
42
|
+
await PromiseRatchet.wait(waitMS);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
if (!rval) {
|
|
46
|
+
ErrorRatchet.throwFormattedErr('Was unable to fetch config %s even after %d retries', name, this.cfg.maxRetries);
|
|
47
|
+
}
|
|
48
|
+
return rval;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=environment-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"environment-service.js","sourceRoot":"","sources":["../../src/environment/environment-service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,8CAA8C,CAAC;AAC9E,OAAO,EAAE,MAAM,EAAE,MAAM,uCAAuC,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,4CAA4C,CAAC;AAC1E,OAAO,EAAE,cAAc,EAAE,MAAM,8CAA8C,CAAC;AAO9E,MAAM,OAAO,kBAAkB;IAYnB;IACA;IAZF,gBAAgB,GAAG,IAAI,GAAG,EAAwB,CAAC;IAEpD,MAAM,CAAC,+BAA+B;QAC3C,MAAM,IAAI,GAA6B;YACrC,UAAU,EAAE,CAAC;YACb,mBAAmB,EAAE,GAAG;SACzB,CAAC;QACF,OAAO,IAAI,CAAC;IACd,CAAC;IAED,YACU,QAAuC,EACvC,MAAgC,kBAAkB,CAAC,+BAA+B,EAAE;QADpF,aAAQ,GAAR,QAAQ,CAA+B;QACvC,QAAG,GAAH,GAAG,CAAiF;QAE5F,cAAc,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;QAC5C,cAAc,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;IACzC,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,IAAY;QACjC,MAAM,CAAC,KAAK,CAAC,sCAAsC,EAAE,IAAI,CAAC,CAAC;QAC3D,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;YACrC,MAAM,CAAC,KAAK,CAAC,uCAAuC,CAAC,CAAC;YACtD,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC;QAChE,CAAC;QAED,OAAO,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACzC,CAAC;IAEO,KAAK,CAAC,iBAAiB,CAAC,IAAY;QAC1C,IAAI,QAAQ,GAAW,CAAC,CAAC;QACzB,IAAI,IAAI,GAAM,IAAI,CAAC;QAEnB,OAAO,CAAC,IAAI,IAAI,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC;YAC/C,QAAQ,EAAE,CAAC;YACX,MAAM,CAAC,KAAK,CAAC,wBAAwB,EAAE,IAAI,CAAC,CAAC;YAC7C,IAAI,CAAC;gBACH,IAAI,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YAC/C,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,MAAM,MAAM,GAAW,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,mBAAmB,CAAC;gBAC/D,MAAM,CAAC,IAAI,CACT,uEAAuE,EACvE,IAAI,EACJ,QAAQ,EACR,IAAI,CAAC,GAAG,CAAC,UAAU,EACnB,MAAM,EACN,GAAG,EACH,GAAG,CACJ,CAAC;gBACF,MAAM,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACpC,CAAC;QACH,CAAC;QAED,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,YAAY,CAAC,iBAAiB,CAAC,qDAAqD,EAAE,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACnH,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { EnvironmentServiceProvider } from './environment-service-provider.js';
|
|
2
|
+
export declare class FixedEnvironmentServiceProvider<T> implements EnvironmentServiceProvider<T> {
|
|
3
|
+
private value;
|
|
4
|
+
constructor(value: Map<string, T>);
|
|
5
|
+
static fromRecord<T>(record: Record<string, T>): FixedEnvironmentServiceProvider<T>;
|
|
6
|
+
fetchConfig(name: string): Promise<T>;
|
|
7
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { RequireRatchet } from '@bitblit/ratchet-common/lang/require-ratchet';
|
|
2
|
+
import { Logger } from '@bitblit/ratchet-common/logger/logger';
|
|
3
|
+
export class FixedEnvironmentServiceProvider {
|
|
4
|
+
value;
|
|
5
|
+
constructor(value) {
|
|
6
|
+
this.value = value;
|
|
7
|
+
RequireRatchet.notNullOrUndefined(value);
|
|
8
|
+
}
|
|
9
|
+
static fromRecord(record) {
|
|
10
|
+
const m = new Map();
|
|
11
|
+
Object.keys(record).forEach((k) => {
|
|
12
|
+
m.set(k, record[k]);
|
|
13
|
+
});
|
|
14
|
+
return new FixedEnvironmentServiceProvider(m);
|
|
15
|
+
}
|
|
16
|
+
async fetchConfig(name) {
|
|
17
|
+
Logger.silly('FixedEnvironmentServiceProvider fetch for %s', name);
|
|
18
|
+
const rval = this.value.get(name);
|
|
19
|
+
return rval;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=fixed-environment-service-provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fixed-environment-service-provider.js","sourceRoot":"","sources":["../../src/environment/fixed-environment-service-provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,8CAA8C,CAAC;AAC9E,OAAO,EAAE,MAAM,EAAE,MAAM,uCAAuC,CAAC;AAM/D,MAAM,OAAO,+BAA+B;IACf;IAA3B,YAA2B,KAAqB;QAArB,UAAK,GAAL,KAAK,CAAgB;QAC9C,cAAc,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;IAC3C,CAAC;IAEM,MAAM,CAAC,UAAU,CAAI,MAAyB;QACnD,MAAM,CAAC,GAAmB,IAAI,GAAG,EAAa,CAAC;QAC/C,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;YAChC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;QACtB,CAAC,CAAC,CAAC;QACH,OAAO,IAAI,+BAA+B,CAAI,CAAC,CAAC,CAAC;IACnD,CAAC;IAEM,KAAK,CAAC,WAAW,CAAC,IAAY;QACnC,MAAM,CAAC,KAAK,CAAC,8CAA8C,EAAE,IAAI,CAAC,CAAC;QACnE,MAAM,IAAI,GAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACrC,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from './cascade-environment-service-provider.js';
|
|
2
|
+
export * from './env-var-environment-service-provider.js';
|
|
3
|
+
export * from './environment-service-config.js';
|
|
4
|
+
export * from './environment-service-provider.js';
|
|
5
|
+
export * from './environment-service.js';
|
|
6
|
+
export * from './fixed-environment-service-provider.js';
|
|
7
|
+
export * from './ssm-environment-service-provider.js';
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export * from './cascade-environment-service-provider.js';
|
|
2
|
+
export * from './env-var-environment-service-provider.js';
|
|
3
|
+
export * from './environment-service-config.js';
|
|
4
|
+
export * from './environment-service-provider.js';
|
|
5
|
+
export * from './environment-service.js';
|
|
6
|
+
export * from './fixed-environment-service-provider.js';
|
|
7
|
+
export * from './ssm-environment-service-provider.js';
|
|
8
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/environment/index.ts"],"names":[],"mappings":"AAIA,cAAc,2CAA2C,CAAC;AAC1D,cAAc,2CAA2C,CAAC;AAC1D,cAAc,iCAAiC,CAAC;AAChD,cAAc,mCAAmC,CAAC;AAClD,cAAc,0BAA0B,CAAC;AACzC,cAAc,yCAAyC,CAAC;AACxD,cAAc,uCAAuC,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { EnvironmentServiceProvider } from './environment-service-provider.js';
|
|
2
|
+
export declare class SsmEnvironmentServiceProvider<T> implements EnvironmentServiceProvider<T> {
|
|
3
|
+
private region;
|
|
4
|
+
private ssmEncrypted;
|
|
5
|
+
private ssm;
|
|
6
|
+
constructor(region?: string, ssmEncrypted?: boolean);
|
|
7
|
+
fetchConfig(name: string): Promise<T>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { RequireRatchet } from '@bitblit/ratchet-common/lang/require-ratchet';
|
|
2
|
+
import { Logger } from '@bitblit/ratchet-common/logger/logger';
|
|
3
|
+
import { ErrorRatchet } from '@bitblit/ratchet-common/lang/error-ratchet';
|
|
4
|
+
import { PromiseRatchet } from '@bitblit/ratchet-common/lang/promise-ratchet';
|
|
5
|
+
import { StringRatchet } from '@bitblit/ratchet-common/lang/string-ratchet';
|
|
6
|
+
import { GetParameterCommand, ParameterNotFound, SSMClient } from '@aws-sdk/client-ssm';
|
|
7
|
+
export class SsmEnvironmentServiceProvider {
|
|
8
|
+
region;
|
|
9
|
+
ssmEncrypted;
|
|
10
|
+
ssm;
|
|
11
|
+
constructor(region = 'us-east-1', ssmEncrypted = true) {
|
|
12
|
+
this.region = region;
|
|
13
|
+
this.ssmEncrypted = ssmEncrypted;
|
|
14
|
+
RequireRatchet.notNullOrUndefined(region);
|
|
15
|
+
RequireRatchet.notNullOrUndefined(ssmEncrypted);
|
|
16
|
+
this.ssm = new SSMClient({ region: this.region });
|
|
17
|
+
}
|
|
18
|
+
async fetchConfig(name) {
|
|
19
|
+
Logger.silly('SsmEnvironmentServiceProvider fetch for %s', name);
|
|
20
|
+
const params = {
|
|
21
|
+
Name: name,
|
|
22
|
+
WithDecryption: this.ssmEncrypted,
|
|
23
|
+
};
|
|
24
|
+
let rval = null;
|
|
25
|
+
let toParse = null;
|
|
26
|
+
try {
|
|
27
|
+
const value = await this.ssm.send(new GetParameterCommand(params));
|
|
28
|
+
toParse = StringRatchet.trimToNull(value?.Parameter?.Value);
|
|
29
|
+
}
|
|
30
|
+
catch (err) {
|
|
31
|
+
if (err instanceof ParameterNotFound) {
|
|
32
|
+
const errMsg = Logger.warn('AWS could not find parameter %s - are you using the right AWS key?', name);
|
|
33
|
+
throw new Error(errMsg);
|
|
34
|
+
}
|
|
35
|
+
else if ((ErrorRatchet.safeStringifyErr(err) || '').toLowerCase().indexOf('throttl') > -1) {
|
|
36
|
+
Logger.warn('Throttled while trying to read parameters - waiting 1 second before allowing retry');
|
|
37
|
+
await PromiseRatchet.wait(1_000);
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
Logger.error('Final environment fetch error (cannot retry) : %s', err, err);
|
|
41
|
+
throw err;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
if (toParse) {
|
|
45
|
+
try {
|
|
46
|
+
rval = JSON.parse(toParse);
|
|
47
|
+
}
|
|
48
|
+
catch (err) {
|
|
49
|
+
Logger.error('Failed to read env - null or invalid JSON : %s : %s', err, toParse, err);
|
|
50
|
+
throw err;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
ErrorRatchet.throwFormattedErr('Could not find system parameter with name : %s in this account', name);
|
|
55
|
+
}
|
|
56
|
+
return rval;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=ssm-environment-service-provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ssm-environment-service-provider.js","sourceRoot":"","sources":["../../src/environment/ssm-environment-service-provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,8CAA8C,CAAC;AAC9E,OAAO,EAAE,MAAM,EAAE,MAAM,uCAAuC,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,4CAA4C,CAAC;AAC1E,OAAO,EAAE,cAAc,EAAE,MAAM,8CAA8C,CAAC;AAC9E,OAAO,EAAE,aAAa,EAAE,MAAM,6CAA6C,CAAC;AAC5E,OAAO,EAAE,mBAAmB,EAA6B,iBAAiB,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAOnH,MAAM,OAAO,6BAA6B;IAG9B;IACA;IAHF,GAAG,CAAY;IACvB,YACU,SAAS,WAAW,EACpB,eAAe,IAAI;QADnB,WAAM,GAAN,MAAM,CAAc;QACpB,iBAAY,GAAZ,YAAY,CAAO;QAE3B,cAAc,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;QAC1C,cAAc,CAAC,kBAAkB,CAAC,YAAY,CAAC,CAAC;QAChD,IAAI,CAAC,GAAG,GAAG,IAAI,SAAS,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IACpD,CAAC;IAEM,KAAK,CAAC,WAAW,CAAC,IAAY;QACnC,MAAM,CAAC,KAAK,CAAC,4CAA4C,EAAE,IAAI,CAAC,CAAC;QACjE,MAAM,MAAM,GAAG;YACb,IAAI,EAAE,IAAI;YACV,cAAc,EAAE,IAAI,CAAC,YAAY;SAClC,CAAC;QAEF,IAAI,IAAI,GAAM,IAAI,CAAC;QACnB,IAAI,OAAO,GAAW,IAAI,CAAC;QAC3B,IAAI,CAAC;YACH,MAAM,KAAK,GAA8B,MAAM,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC;YAC9F,OAAO,GAAG,aAAa,CAAC,UAAU,CAAC,KAAK,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;QAC9D,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,GAAG,YAAY,iBAAiB,EAAE,CAAC;gBACrC,MAAM,MAAM,GAAW,MAAM,CAAC,IAAI,CAAC,oEAAoE,EAAE,IAAI,CAAC,CAAC;gBAC/G,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC;YAC1B,CAAC;iBAAM,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBAK5F,MAAM,CAAC,IAAI,CAAC,oFAAoF,CAAC,CAAC;gBAClG,MAAM,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACnC,CAAC;iBAAM,CAAC;gBACN,MAAM,CAAC,KAAK,CAAC,mDAAmD,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;gBAC5E,MAAM,GAAG,CAAC;YACZ,CAAC;QACH,CAAC;QAGD,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,CAAC;gBACH,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAC7B,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,MAAM,CAAC,KAAK,CAAC,qDAAqD,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,CAAC,CAAC;gBACvF,MAAM,GAAG,CAAC;YACZ,CAAC;QACH,CAAC;aAAM,CAAC;YACN,YAAY,CAAC,iBAAiB,CAAC,gEAAgE,EAAE,IAAI,CAAC,CAAC;QACzG,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"expiring-code-params.js","sourceRoot":"","sources":["../../src/expiring-code/expiring-code-params.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"expiring-code-provider.js","sourceRoot":"","sources":["../../src/expiring-code/expiring-code-provider.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ExpiringCodeProvider } from './expiring-code-provider.js';
|
|
2
|
+
import { ExpiringCodeParams } from './expiring-code-params.js';
|
|
3
|
+
import { ExpiringCode } from './expiring-code.js';
|
|
4
|
+
export declare class ExpiringCodeRatchet {
|
|
5
|
+
private provider;
|
|
6
|
+
constructor(provider: ExpiringCodeProvider);
|
|
7
|
+
static generateCode(params: ExpiringCodeParams): ExpiringCode;
|
|
8
|
+
createNewCode(params: ExpiringCodeParams): Promise<ExpiringCode>;
|
|
9
|
+
checkCode(code: string, context: string, deleteOnMatch?: boolean): Promise<boolean>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { RequireRatchet } from '@bitblit/ratchet-common/lang/require-ratchet';
|
|
2
|
+
import { StringRatchet } from '@bitblit/ratchet-common/lang/string-ratchet';
|
|
3
|
+
export class ExpiringCodeRatchet {
|
|
4
|
+
provider;
|
|
5
|
+
constructor(provider) {
|
|
6
|
+
this.provider = provider;
|
|
7
|
+
}
|
|
8
|
+
static generateCode(params) {
|
|
9
|
+
RequireRatchet.notNullOrUndefined(params, 'params');
|
|
10
|
+
RequireRatchet.notNullOrUndefined(params.context, 'params.context');
|
|
11
|
+
RequireRatchet.notNullOrUndefined(params.length, 'params.length');
|
|
12
|
+
RequireRatchet.notNullOrUndefined(params.alphabet, 'params.alphabet');
|
|
13
|
+
let code = '';
|
|
14
|
+
for (let i = 0; i < params.length; i++) {
|
|
15
|
+
code += params.alphabet.charAt(Math.floor(params.alphabet.length * Math.random()));
|
|
16
|
+
}
|
|
17
|
+
const rval = {
|
|
18
|
+
code: code,
|
|
19
|
+
context: params.context,
|
|
20
|
+
tags: params.tags,
|
|
21
|
+
expiresEpochMS: Date.now() + params.timeToLiveSeconds * 1000,
|
|
22
|
+
};
|
|
23
|
+
return rval;
|
|
24
|
+
}
|
|
25
|
+
async createNewCode(params) {
|
|
26
|
+
const value = ExpiringCodeRatchet.generateCode(params);
|
|
27
|
+
const rval = await this.provider.storeCode(value);
|
|
28
|
+
return rval ? value : null;
|
|
29
|
+
}
|
|
30
|
+
async checkCode(code, context, deleteOnMatch) {
|
|
31
|
+
const rval = await this.provider.checkCode(StringRatchet.trimToEmpty(code), StringRatchet.trimToEmpty(context), deleteOnMatch);
|
|
32
|
+
return rval;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=expiring-code-ratchet.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"expiring-code-ratchet.js","sourceRoot":"","sources":["../../src/expiring-code/expiring-code-ratchet.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,8CAA8C,CAAC;AAC9E,OAAO,EAAE,aAAa,EAAE,MAAM,6CAA6C,CAAC;AAQ5E,MAAM,OAAO,mBAAmB;IACV;IAApB,YAAoB,QAA8B;QAA9B,aAAQ,GAAR,QAAQ,CAAsB;IAAG,CAAC;IAE/C,MAAM,CAAC,YAAY,CAAC,MAA0B;QACnD,cAAc,CAAC,kBAAkB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QACpD,cAAc,CAAC,kBAAkB,CAAC,MAAM,CAAC,OAAO,EAAE,gBAAgB,CAAC,CAAC;QACpE,cAAc,CAAC,kBAAkB,CAAC,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;QAClE,cAAc,CAAC,kBAAkB,CAAC,MAAM,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAC;QAEtE,IAAI,IAAI,GAAW,EAAE,CAAC;QACtB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACvC,IAAI,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QACrF,CAAC;QAED,MAAM,IAAI,GAAiB;YACzB,IAAI,EAAE,IAAI;YACV,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,IAAI,EAAE,MAAM,CAAC,IAAI;YACjB,cAAc,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,iBAAiB,GAAG,IAAI;SAC7D,CAAC;QACF,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,KAAK,CAAC,aAAa,CAAC,MAA0B;QACnD,MAAM,KAAK,GAAiB,mBAAmB,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QACrE,MAAM,IAAI,GAAY,MAAM,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAC3D,OAAO,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;IAC7B,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,IAAY,EAAE,OAAe,EAAE,aAAuB;QAC3E,MAAM,IAAI,GAAY,MAAM,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,aAAa,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,aAAa,CAAC,CAAC;QACxI,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"expiring-code.js","sourceRoot":"","sources":["../../src/expiring-code/expiring-code.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/expiring-code/index.ts"],"names":[],"mappings":"AAIA,cAAc,2BAA2B,CAAC;AAC1C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,oBAAoB,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { ErrorRatchet } from '@bitblit/ratchet-common/lang/error-ratchet';
|
|
2
|
+
import { StringRatchet } from '@bitblit/ratchet-common/lang/string-ratchet';
|
|
3
|
+
export class AwsCredentialsRatchet {
|
|
4
|
+
constructor() { }
|
|
5
|
+
static applySetProfileEnvironmentalVariable(newProfile) {
|
|
6
|
+
if (process.env) {
|
|
7
|
+
if (StringRatchet.trimToNull(newProfile)) {
|
|
8
|
+
process.env['AWS_PROFILE'] = newProfile;
|
|
9
|
+
}
|
|
10
|
+
else {
|
|
11
|
+
ErrorRatchet.throwFormattedErr('Cannot set profile to null/empty string');
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
ErrorRatchet.throwFormattedErr('Cannot set profile - not in a node environment - process missing');
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=aws-credentials-ratchet.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aws-credentials-ratchet.js","sourceRoot":"","sources":["../../src/iam/aws-credentials-ratchet.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,4CAA4C,CAAC;AAC1E,OAAO,EAAE,aAAa,EAAE,MAAM,6CAA6C,CAAC;AAO5E,MAAM,OAAO,qBAAqB;IAGhC,gBAAuB,CAAC;IAEjB,MAAM,CAAC,oCAAoC,CAAC,UAAkB;QACnE,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;YAChB,IAAI,aAAa,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;gBACzC,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,GAAG,UAAU,CAAC;YAC1C,CAAC;iBAAM,CAAC;gBACN,YAAY,CAAC,iBAAiB,CAAC,yCAAyC,CAAC,CAAC;YAC5E,CAAC;QACH,CAAC;aAAM,CAAC;YACN,YAAY,CAAC,iBAAiB,CAAC,kEAAkE,CAAC,CAAC;QACrG,CAAC;IACH,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './aws-credentials-ratchet.js';
|
package/lib/iam/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/iam/index.ts"],"names":[],"mappings":"AAIA,cAAc,8BAA8B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/lambda/index.ts"],"names":[],"mappings":"AAIA,cAAc,4BAA4B,CAAC;AAC3C,cAAc,+BAA+B,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export declare class LambdaEventDetector {
|
|
2
|
+
static isValidCronEvent(event: any): boolean;
|
|
3
|
+
static isValidSnsEvent(event: any): boolean;
|
|
4
|
+
static isValidSqsEvent(event: any): boolean;
|
|
5
|
+
static isValidDynamoDBEvent(event: any): boolean;
|
|
6
|
+
static isValidS3Event(event: any): boolean;
|
|
7
|
+
static isValidApiGatewayV2WithRequestContextEvent(event: any): boolean;
|
|
8
|
+
static isValidApiGatewayEvent(event: any): boolean;
|
|
9
|
+
static isValidApiGatewayAuthorizerEvent(event: any): boolean;
|
|
10
|
+
static isSingleCronEvent(event: any): boolean;
|
|
11
|
+
static isSingleSnsEvent(event: any): boolean;
|
|
12
|
+
static isSingleDynamoDBEvent(event: any): boolean;
|
|
13
|
+
static isSingleS3Event(event: any): boolean;
|
|
14
|
+
static isSingleEntryEvent(event: any, entryName?: string): boolean;
|
|
15
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
export class LambdaEventDetector {
|
|
2
|
+
static isValidCronEvent(event) {
|
|
3
|
+
return event && event.source == 'aws.events' && event.resources && event.resources.length > 0;
|
|
4
|
+
}
|
|
5
|
+
static isValidSnsEvent(event) {
|
|
6
|
+
return event && event.Records && event.Records.length > 0 && event.Records[0].EventSource == 'aws:sns';
|
|
7
|
+
}
|
|
8
|
+
static isValidSqsEvent(event) {
|
|
9
|
+
return event && event.Records && event.Records.length > 0 && event.Records[0].eventSource == 'aws:sqs';
|
|
10
|
+
}
|
|
11
|
+
static isValidDynamoDBEvent(event) {
|
|
12
|
+
return event && event.Records && event.Records.length > 0 && event.Records[0].eventSource == 'aws:dynamodb';
|
|
13
|
+
}
|
|
14
|
+
static isValidS3Event(event) {
|
|
15
|
+
return event && event.Records && event.Records.length > 0 && event.Records[0].eventSource == 'aws:s3';
|
|
16
|
+
}
|
|
17
|
+
static isValidApiGatewayV2WithRequestContextEvent(event) {
|
|
18
|
+
return event && event.rawPath && event.requestContext && event.routeKey;
|
|
19
|
+
}
|
|
20
|
+
static isValidApiGatewayEvent(event) {
|
|
21
|
+
return event && event.httpMethod && event.path && event.requestContext;
|
|
22
|
+
}
|
|
23
|
+
static isValidApiGatewayAuthorizerEvent(event) {
|
|
24
|
+
return event && event.authorizationToken && event.methodArn;
|
|
25
|
+
}
|
|
26
|
+
static isSingleCronEvent(event) {
|
|
27
|
+
return this.isValidCronEvent(event) && LambdaEventDetector.isSingleEntryEvent(event, 'resources');
|
|
28
|
+
}
|
|
29
|
+
static isSingleSnsEvent(event) {
|
|
30
|
+
return this.isValidSnsEvent(event) && LambdaEventDetector.isSingleEntryEvent(event);
|
|
31
|
+
}
|
|
32
|
+
static isSingleDynamoDBEvent(event) {
|
|
33
|
+
return this.isValidDynamoDBEvent(event) && LambdaEventDetector.isSingleEntryEvent(event);
|
|
34
|
+
}
|
|
35
|
+
static isSingleS3Event(event) {
|
|
36
|
+
return this.isValidS3Event(event) && LambdaEventDetector.isSingleEntryEvent(event);
|
|
37
|
+
}
|
|
38
|
+
static isSingleEntryEvent(event, entryName = 'Records') {
|
|
39
|
+
return event && event[entryName] && event[entryName] instanceof Array && event[entryName].length === 1;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=lambda-event-detector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lambda-event-detector.js","sourceRoot":"","sources":["../../src/lambda/lambda-event-detector.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,mBAAmB;IACvB,MAAM,CAAC,gBAAgB,CAAC,KAAU;QACvC,OAAO,KAAK,IAAI,KAAK,CAAC,MAAM,IAAI,YAAY,IAAI,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC;IAChG,CAAC;IAEM,MAAM,CAAC,eAAe,CAAC,KAAU;QACtC,OAAO,KAAK,IAAI,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,WAAW,IAAI,SAAS,CAAC;IACzG,CAAC;IAEM,MAAM,CAAC,eAAe,CAAC,KAAU;QACtC,OAAO,KAAK,IAAI,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,WAAW,IAAI,SAAS,CAAC;IACzG,CAAC;IAEM,MAAM,CAAC,oBAAoB,CAAC,KAAU;QAC3C,OAAO,KAAK,IAAI,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,WAAW,IAAI,cAAc,CAAC;IAC9G,CAAC;IAEM,MAAM,CAAC,cAAc,CAAC,KAAU;QACrC,OAAO,KAAK,IAAI,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,WAAW,IAAI,QAAQ,CAAC;IACxG,CAAC;IAEM,MAAM,CAAC,0CAA0C,CAAC,KAAU;QACjE,OAAO,KAAK,IAAI,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,cAAc,IAAI,KAAK,CAAC,QAAQ,CAAC;IAC1E,CAAC;IAEM,MAAM,CAAC,sBAAsB,CAAC,KAAU;QAC7C,OAAO,KAAK,IAAI,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,cAAc,CAAC;IACzE,CAAC;IAEM,MAAM,CAAC,gCAAgC,CAAC,KAAU;QACvD,OAAO,KAAK,IAAI,KAAK,CAAC,kBAAkB,IAAI,KAAK,CAAC,SAAS,CAAC;IAC9D,CAAC;IAEM,MAAM,CAAC,iBAAiB,CAAC,KAAU;QACxC,OAAO,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,mBAAmB,CAAC,kBAAkB,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;IACpG,CAAC;IAEM,MAAM,CAAC,gBAAgB,CAAC,KAAU;QACvC,OAAO,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI,mBAAmB,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;IACtF,CAAC;IAEM,MAAM,CAAC,qBAAqB,CAAC,KAAU;QAC5C,OAAO,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,IAAI,mBAAmB,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;IAC3F,CAAC;IAEM,MAAM,CAAC,eAAe,CAAC,KAAU;QACtC,OAAO,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,mBAAmB,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;IACrF,CAAC;IAEM,MAAM,CAAC,kBAAkB,CAAC,KAAU,EAAE,YAAoB,SAAS;QACxE,OAAO,KAAK,IAAI,KAAK,CAAC,SAAS,CAAC,IAAI,KAAK,CAAC,SAAS,CAAC,YAAY,KAAK,IAAI,KAAK,CAAC,SAAS,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC;IACzG,CAAC;CACF"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { APIGatewayEvent, APIGatewayProxyEventV2, DynamoDBStreamEvent, S3Event, ScheduledEvent, SNSEvent, SQSEvent } from 'aws-lambda';
|
|
2
|
+
export declare class LambdaEventTypeGuards {
|
|
3
|
+
static isValidCronEvent(event: any): event is ScheduledEvent;
|
|
4
|
+
static isValidSqsEvent(event: any): event is SQSEvent;
|
|
5
|
+
static isValidSnsEvent(event: any): event is SNSEvent;
|
|
6
|
+
static isValidDynamoDBEvent(event: any): event is DynamoDBStreamEvent;
|
|
7
|
+
static isValidS3Event(event: any): event is S3Event;
|
|
8
|
+
static isValidApiGatewayV2WithRequestContextEvent(event: any): event is APIGatewayProxyEventV2;
|
|
9
|
+
static isValidApiGatewayEvent(event: any): event is APIGatewayEvent;
|
|
10
|
+
static isValidApiGatewayAuthorizerEvent(event: any): boolean;
|
|
11
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { LambdaEventDetector } from './lambda-event-detector.js';
|
|
2
|
+
export class LambdaEventTypeGuards {
|
|
3
|
+
static isValidCronEvent(event) {
|
|
4
|
+
return LambdaEventDetector.isValidCronEvent(event);
|
|
5
|
+
}
|
|
6
|
+
static isValidSqsEvent(event) {
|
|
7
|
+
return LambdaEventDetector.isValidSqsEvent(event);
|
|
8
|
+
}
|
|
9
|
+
static isValidSnsEvent(event) {
|
|
10
|
+
return LambdaEventDetector.isValidSnsEvent(event);
|
|
11
|
+
}
|
|
12
|
+
static isValidDynamoDBEvent(event) {
|
|
13
|
+
return LambdaEventDetector.isValidDynamoDBEvent(event);
|
|
14
|
+
}
|
|
15
|
+
static isValidS3Event(event) {
|
|
16
|
+
return LambdaEventDetector.isValidS3Event(event);
|
|
17
|
+
}
|
|
18
|
+
static isValidApiGatewayV2WithRequestContextEvent(event) {
|
|
19
|
+
return LambdaEventDetector.isValidApiGatewayV2WithRequestContextEvent(event);
|
|
20
|
+
}
|
|
21
|
+
static isValidApiGatewayEvent(event) {
|
|
22
|
+
return LambdaEventDetector.isValidApiGatewayEvent(event);
|
|
23
|
+
}
|
|
24
|
+
static isValidApiGatewayAuthorizerEvent(event) {
|
|
25
|
+
return LambdaEventDetector.isValidApiGatewayAuthorizerEvent(event);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=lambda-event-type-guards.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lambda-event-type-guards.js","sourceRoot":"","sources":["../../src/lambda/lambda-event-type-guards.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AAEjE,MAAM,OAAO,qBAAqB;IACzB,MAAM,CAAC,gBAAgB,CAAC,KAAU;QACvC,OAAO,mBAAmB,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;IACrD,CAAC;IAEM,MAAM,CAAC,eAAe,CAAC,KAAU;QACtC,OAAO,mBAAmB,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;IACpD,CAAC;IAEM,MAAM,CAAC,eAAe,CAAC,KAAU;QACtC,OAAO,mBAAmB,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;IACpD,CAAC;IAEM,MAAM,CAAC,oBAAoB,CAAC,KAAU;QAC3C,OAAO,mBAAmB,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;IACzD,CAAC;IAEM,MAAM,CAAC,cAAc,CAAC,KAAU;QACrC,OAAO,mBAAmB,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;IACnD,CAAC;IAEM,MAAM,CAAC,0CAA0C,CAAC,KAAU;QACjE,OAAO,mBAAmB,CAAC,0CAA0C,CAAC,KAAK,CAAC,CAAC;IAC/E,CAAC;IAEM,MAAM,CAAC,sBAAsB,CAAC,KAAU;QAC7C,OAAO,mBAAmB,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;IAC3D,CAAC;IAEM,MAAM,CAAC,gCAAgC,CAAC,KAAU;QACvD,OAAO,mBAAmB,CAAC,gCAAgC,CAAC,KAAK,CAAC,CAAC;IACrE,CAAC;CACF"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { KeyValue } from '@bitblit/ratchet-common/lang/key-value';
|
|
2
|
+
import { DynamoRatchet } from '../dynamodb/dynamo-ratchet.js';
|
|
3
|
+
import { QueryCommandInput, ScanCommandInput } from '@aws-sdk/lib-dynamodb';
|
|
4
|
+
export interface CloudWatchMetricsMinuteLevelDynamoCountRequest {
|
|
5
|
+
dynamoRatchet: DynamoRatchet;
|
|
6
|
+
query: QueryCommandInput;
|
|
7
|
+
scan: ScanCommandInput;
|
|
8
|
+
minuteUTC: string;
|
|
9
|
+
namespace: string;
|
|
10
|
+
metric: string;
|
|
11
|
+
dims: KeyValue<any>[];
|
|
12
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cloud-watch-metrics-minute-level-dynamo-count-request.js","sourceRoot":"","sources":["../../src/model/cloud-watch-metrics-minute-level-dynamo-count-request.ts"],"names":[],"mappings":""}
|