truemark-cdk-lib 1.5.3 → 1.5.4
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.
|
@@ -41,34 +41,47 @@ export interface CloudFrontBucketProps extends ExtendedConstructProps {
|
|
|
41
41
|
* Simple Construct for creating buckets that will be accessed directly by CloudFront as an Origin.
|
|
42
42
|
*/
|
|
43
43
|
export declare class CloudFrontBucket extends ExtendedConstruct {
|
|
44
|
+
private deployCount;
|
|
44
45
|
readonly bucket: Bucket;
|
|
45
46
|
readonly bucketName: string;
|
|
46
47
|
readonly bucketArn: string;
|
|
47
48
|
readonly originAccessIdentity: OriginAccessIdentity;
|
|
48
49
|
readonly originAccessIdentityId: string;
|
|
50
|
+
private nextDeployCount;
|
|
49
51
|
constructor(scope: Construct, id: string, props: CloudFrontBucketProps);
|
|
50
52
|
/**
|
|
51
53
|
* Helper method to deploy local assets to the created bucket. Ths function assumes
|
|
52
54
|
* CloudFront invalidation requests will be sent for mutable files to serve new content.
|
|
53
55
|
* For more complicated deployments, use BucketDeployment directly.
|
|
54
56
|
*
|
|
55
|
-
* @param
|
|
57
|
+
* @param paths the paths to the local assets
|
|
56
58
|
* @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)
|
|
57
59
|
* @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)
|
|
58
60
|
* @param prune true to prune old files; default is false
|
|
59
61
|
*/
|
|
60
|
-
|
|
62
|
+
deployPaths(paths: string[], maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment;
|
|
61
63
|
/**
|
|
62
64
|
* Helper method to deploy local assets to the created bucket. Ths function assumes
|
|
63
65
|
* CloudFront invalidation requests will be sent for mutable files to serve new content.
|
|
64
66
|
* For more complicated deployments, use BucketDeployment directly.
|
|
65
67
|
*
|
|
66
|
-
* @param
|
|
68
|
+
* @param path the path to the local assets
|
|
67
69
|
* @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)
|
|
68
70
|
* @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)
|
|
69
71
|
* @param prune true to prune old files; default is false
|
|
70
72
|
*/
|
|
71
|
-
|
|
73
|
+
deployPath(path: string, maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment;
|
|
74
|
+
/**
|
|
75
|
+
* Helper method to assets to the created bucket. This function assumes CloudFront invalidation
|
|
76
|
+
* requests will be sent for mutable files to serve new content.
|
|
77
|
+
* For more complicated deployments, use BucketDeployment directly.
|
|
78
|
+
*
|
|
79
|
+
* @param sources the sources to deploy
|
|
80
|
+
* @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)
|
|
81
|
+
* @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)
|
|
82
|
+
* @param prune true to prune old files; default is false
|
|
83
|
+
*/
|
|
84
|
+
deploySources(sources: ISource[], maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment;
|
|
72
85
|
/**
|
|
73
86
|
* Helper method to assets to the created bucket. This function assumes CloudFront invalidation
|
|
74
87
|
* requests will be sent for mutable files to serve new content.
|
|
@@ -14,6 +14,7 @@ class CloudFrontBucket extends aws_cdk_1.ExtendedConstruct {
|
|
|
14
14
|
constructor(scope, id, props) {
|
|
15
15
|
var _a, _b, _c, _d;
|
|
16
16
|
super(scope, id, { standardTags: aws_cdk_1.StandardTags.merge(props.standardTags, truemark_1.LibStandardTags) });
|
|
17
|
+
this.deployCount = 0;
|
|
17
18
|
const removalPolicy = (_a = props.removalPolicy) !== null && _a !== void 0 ? _a : aws_cdk_lib_1.RemovalPolicy.RETAIN;
|
|
18
19
|
const autoDeleteObjects = ((_b = props.autoDeleteObjects) !== null && _b !== void 0 ? _b : false) && removalPolicy === aws_cdk_lib_1.RemovalPolicy.DESTROY;
|
|
19
20
|
this.bucket = new aws_s3_1.Bucket(this, "Default", {
|
|
@@ -33,6 +34,32 @@ class CloudFrontBucket extends aws_cdk_1.ExtendedConstruct {
|
|
|
33
34
|
this.originAccessIdentityId = this.originAccessIdentity.originAccessIdentityId;
|
|
34
35
|
this.bucket.grantRead(this.originAccessIdentity);
|
|
35
36
|
}
|
|
37
|
+
nextDeployCount() {
|
|
38
|
+
let current = this.deployCount++;
|
|
39
|
+
return current === 0 ? '' : `${current}`;
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Helper method to deploy local assets to the created bucket. Ths function assumes
|
|
43
|
+
* CloudFront invalidation requests will be sent for mutable files to serve new content.
|
|
44
|
+
* For more complicated deployments, use BucketDeployment directly.
|
|
45
|
+
*
|
|
46
|
+
* @param paths the paths to the local assets
|
|
47
|
+
* @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)
|
|
48
|
+
* @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)
|
|
49
|
+
* @param prune true to prune old files; default is false
|
|
50
|
+
*/
|
|
51
|
+
deployPaths(paths, maxAge, sMaxAge, prune) {
|
|
52
|
+
return new aws_s3_deployment_1.BucketDeployment(this, `Deploy${this.nextDeployCount()}`, {
|
|
53
|
+
sources: paths.map(path => aws_s3_deployment_1.Source.asset(path)),
|
|
54
|
+
destinationBucket: this.bucket,
|
|
55
|
+
prune: prune !== null && prune !== void 0 ? prune : false,
|
|
56
|
+
cacheControl: [
|
|
57
|
+
aws_s3_deployment_1.CacheControl.setPublic(),
|
|
58
|
+
aws_s3_deployment_1.CacheControl.maxAge(maxAge !== null && maxAge !== void 0 ? maxAge : aws_cdk_lib_1.Duration.minutes(15)),
|
|
59
|
+
aws_s3_deployment_1.CacheControl.sMaxAge(sMaxAge !== null && sMaxAge !== void 0 ? sMaxAge : aws_cdk_lib_1.Duration.days(7))
|
|
60
|
+
]
|
|
61
|
+
});
|
|
62
|
+
}
|
|
36
63
|
/**
|
|
37
64
|
* Helper method to deploy local assets to the created bucket. Ths function assumes
|
|
38
65
|
* CloudFront invalidation requests will be sent for mutable files to serve new content.
|
|
@@ -47,18 +74,18 @@ class CloudFrontBucket extends aws_cdk_1.ExtendedConstruct {
|
|
|
47
74
|
return this.deployPaths([path], maxAge, sMaxAge, prune);
|
|
48
75
|
}
|
|
49
76
|
/**
|
|
50
|
-
* Helper method to
|
|
51
|
-
*
|
|
77
|
+
* Helper method to assets to the created bucket. This function assumes CloudFront invalidation
|
|
78
|
+
* requests will be sent for mutable files to serve new content.
|
|
52
79
|
* For more complicated deployments, use BucketDeployment directly.
|
|
53
80
|
*
|
|
54
|
-
* @param
|
|
81
|
+
* @param sources the sources to deploy
|
|
55
82
|
* @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)
|
|
56
83
|
* @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)
|
|
57
84
|
* @param prune true to prune old files; default is false
|
|
58
85
|
*/
|
|
59
|
-
|
|
60
|
-
return new aws_s3_deployment_1.BucketDeployment(this,
|
|
61
|
-
sources:
|
|
86
|
+
deploySources(sources, maxAge, sMaxAge, prune) {
|
|
87
|
+
return new aws_s3_deployment_1.BucketDeployment(this, `Deploy${this.nextDeployCount()}`, {
|
|
88
|
+
sources: sources,
|
|
62
89
|
destinationBucket: this.bucket,
|
|
63
90
|
prune: prune !== null && prune !== void 0 ? prune : false,
|
|
64
91
|
cacheControl: [
|
|
@@ -79,17 +106,8 @@ class CloudFrontBucket extends aws_cdk_1.ExtendedConstruct {
|
|
|
79
106
|
* @param prune true to prune old files; default is false
|
|
80
107
|
*/
|
|
81
108
|
deploySource(source, maxAge, sMaxAge, prune) {
|
|
82
|
-
return
|
|
83
|
-
sources: [source],
|
|
84
|
-
destinationBucket: this.bucket,
|
|
85
|
-
prune: prune !== null && prune !== void 0 ? prune : false,
|
|
86
|
-
cacheControl: [
|
|
87
|
-
aws_s3_deployment_1.CacheControl.setPublic(),
|
|
88
|
-
aws_s3_deployment_1.CacheControl.maxAge(maxAge !== null && maxAge !== void 0 ? maxAge : aws_cdk_lib_1.Duration.minutes(15)),
|
|
89
|
-
aws_s3_deployment_1.CacheControl.sMaxAge(sMaxAge !== null && sMaxAge !== void 0 ? sMaxAge : aws_cdk_lib_1.Duration.days(7))
|
|
90
|
-
]
|
|
91
|
-
});
|
|
109
|
+
return this.deploySources([source], maxAge, sMaxAge, prune);
|
|
92
110
|
}
|
|
93
111
|
}
|
|
94
112
|
exports.CloudFrontBucket = CloudFrontBucket;
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloud-front-bucket.js","sourceRoot":"","sources":["cloud-front-bucket.ts"],"names":[],"mappings":"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","sourcesContent":["import {Construct} from \"constructs\";\nimport {BlockPublicAccess, Bucket, BucketEncryption, IBucket} from \"aws-cdk-lib/aws-s3\";\nimport {OriginAccessIdentity} from \"aws-cdk-lib/aws-cloudfront\";\nimport {BucketDeployment, CacheControl, ISource, Source} from \"aws-cdk-lib/aws-s3-deployment\";\nimport {Duration, RemovalPolicy} from \"aws-cdk-lib\";\nimport {ExtendedConstruct, ExtendedConstructProps, StandardTags} from \"../../aws-cdk\";\nimport {LibStandardTags} from \"../../truemark\";\n\n/**\n * Properties for CloudFrontBucket.\n */\nexport interface CloudFrontBucketProps extends ExtendedConstructProps {\n\n  /**\n   * Policy to apply when the bucket is removed from this stack.\n   * @default RemovalPolicy.RETAIN\n   */\n  readonly removalPolicy?: RemovalPolicy;\n\n  /**\n   * Whether all objects should be automatically deleted when the bucket is removed from the stack or when the stack is deleted.\n   * Requires the removalPolicy to be set to RemovalPolicy.DESTROY. Default is false.\n   *\n   * @default false\n   */\n  readonly autoDeleteObjects?: boolean;\n\n  /**\n   * Whether this bucket should have versioning turned on or not. Default is false.\n   *\n   * @default false\n   */\n  readonly versioned?: boolean;\n\n  /**\n   * Whether this bucket should have transfer acceleration turned on or not. Default is false.\n   *\n   * @default false\n   */\n  readonly transferAcceleration?: boolean;\n\n  /**\n   * Optional bucket name. If not provided, a name will be generated.\n   */\n  readonly bucketName?: string;\n}\n\n/**\n * Simple Construct for creating buckets that will be accessed directly by CloudFront as an Origin.\n */\nexport class CloudFrontBucket extends ExtendedConstruct {\n\n  readonly bucket: Bucket;\n  readonly bucketName: string;\n  readonly bucketArn: string;\n  readonly originAccessIdentity: OriginAccessIdentity;\n  readonly originAccessIdentityId: string;\n\n  constructor(scope: Construct, id: string, props: CloudFrontBucketProps) {\n    super(scope, id, {standardTags: StandardTags.merge(props.standardTags, LibStandardTags)});\n\n    const removalPolicy = props.removalPolicy ?? RemovalPolicy.RETAIN;\n    const autoDeleteObjects = (props.autoDeleteObjects ?? false) && removalPolicy === RemovalPolicy.DESTROY;\n\n    this.bucket = new Bucket(this, \"Default\", {\n      encryption: BucketEncryption.S3_MANAGED, // CloudFront cannot use KMS with S3\n      blockPublicAccess: BlockPublicAccess.BLOCK_ALL,\n      removalPolicy,\n      autoDeleteObjects,\n      versioned: props.versioned ?? false,\n      transferAcceleration: props.transferAcceleration ?? false,\n      bucketName: props.bucketName\n    });\n    this.bucketName = this.bucket.bucketName;\n    this.bucketArn = this.bucket.bucketArn;\n    this.originAccessIdentity = new OriginAccessIdentity(this, \"Access\", {\n      comment: `S3 bucket ${this.bucket.bucketName}`\n    });\n    this.originAccessIdentityId = this.originAccessIdentity.originAccessIdentityId;\n    this.bucket.grantRead(this.originAccessIdentity);\n  }\n\n  /**\n   * Helper method to deploy local assets to the created bucket. Ths function assumes\n   * CloudFront invalidation requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param path the path to the local assets\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deployPath(path: string, maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return this.deployPaths([path], maxAge, sMaxAge, prune);\n  }\n\n  /**\n   * Helper method to deploy local assets to the created bucket. Ths function assumes\n   * CloudFront invalidation requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param paths the paths to the local assets\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deployPaths(paths: string[], maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return new BucketDeployment(this, \"Deploy\", {\n      sources: paths.map(path => Source.asset(path)),\n      destinationBucket: this.bucket,\n      prune: prune ?? false,\n      cacheControl: [\n        CacheControl.setPublic(),\n        CacheControl.maxAge(maxAge ?? Duration.minutes(15)),\n        CacheControl.sMaxAge(sMaxAge ?? Duration.days(7))\n      ]\n    });\n  }\n\n  /**\n   * Helper method to assets to the created bucket. This function assumes CloudFront invalidation\n   * requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param source the source to deploy\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deploySource(source: ISource, maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return new BucketDeployment(this, \"Deploy\", {\n      sources: [source],\n      destinationBucket: this.bucket,\n      prune: prune ?? false,\n      cacheControl: [\n        CacheControl.setPublic(),\n        CacheControl.maxAge(maxAge ?? Duration.minutes(15)),\n        CacheControl.sMaxAge(sMaxAge ?? Duration.days(7))\n      ]\n    })\n  }\n}\n"]}
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloud-front-bucket.js","sourceRoot":"","sources":["cloud-front-bucket.ts"],"names":[],"mappings":"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","sourcesContent":["import {Construct} from \"constructs\";\nimport {BlockPublicAccess, Bucket, BucketEncryption, IBucket} from \"aws-cdk-lib/aws-s3\";\nimport {OriginAccessIdentity} from \"aws-cdk-lib/aws-cloudfront\";\nimport {BucketDeployment, CacheControl, ISource, Source} from \"aws-cdk-lib/aws-s3-deployment\";\nimport {Duration, RemovalPolicy} from \"aws-cdk-lib\";\nimport {ExtendedConstruct, ExtendedConstructProps, StandardTags} from \"../../aws-cdk\";\nimport {LibStandardTags} from \"../../truemark\";\n\n/**\n * Properties for CloudFrontBucket.\n */\nexport interface CloudFrontBucketProps extends ExtendedConstructProps {\n\n  /**\n   * Policy to apply when the bucket is removed from this stack.\n   * @default RemovalPolicy.RETAIN\n   */\n  readonly removalPolicy?: RemovalPolicy;\n\n  /**\n   * Whether all objects should be automatically deleted when the bucket is removed from the stack or when the stack is deleted.\n   * Requires the removalPolicy to be set to RemovalPolicy.DESTROY. Default is false.\n   *\n   * @default false\n   */\n  readonly autoDeleteObjects?: boolean;\n\n  /**\n   * Whether this bucket should have versioning turned on or not. Default is false.\n   *\n   * @default false\n   */\n  readonly versioned?: boolean;\n\n  /**\n   * Whether this bucket should have transfer acceleration turned on or not. Default is false.\n   *\n   * @default false\n   */\n  readonly transferAcceleration?: boolean;\n\n  /**\n   * Optional bucket name. If not provided, a name will be generated.\n   */\n  readonly bucketName?: string;\n}\n\n/**\n * Simple Construct for creating buckets that will be accessed directly by CloudFront as an Origin.\n */\nexport class CloudFrontBucket extends ExtendedConstruct {\n\n  private deployCount: number = 0;\n\n  readonly bucket: Bucket;\n  readonly bucketName: string;\n  readonly bucketArn: string;\n  readonly originAccessIdentity: OriginAccessIdentity;\n  readonly originAccessIdentityId: string;\n\n  private nextDeployCount(): string {\n    let current = this.deployCount++;\n    return current === 0 ? '' : `${current}`;\n  }\n\n  constructor(scope: Construct, id: string, props: CloudFrontBucketProps) {\n    super(scope, id, {standardTags: StandardTags.merge(props.standardTags, LibStandardTags)});\n\n    const removalPolicy = props.removalPolicy ?? RemovalPolicy.RETAIN;\n    const autoDeleteObjects = (props.autoDeleteObjects ?? false) && removalPolicy === RemovalPolicy.DESTROY;\n\n    this.bucket = new Bucket(this, \"Default\", {\n      encryption: BucketEncryption.S3_MANAGED, // CloudFront cannot use KMS with S3\n      blockPublicAccess: BlockPublicAccess.BLOCK_ALL,\n      removalPolicy,\n      autoDeleteObjects,\n      versioned: props.versioned ?? false,\n      transferAcceleration: props.transferAcceleration ?? false,\n      bucketName: props.bucketName\n    });\n    this.bucketName = this.bucket.bucketName;\n    this.bucketArn = this.bucket.bucketArn;\n    this.originAccessIdentity = new OriginAccessIdentity(this, \"Access\", {\n      comment: `S3 bucket ${this.bucket.bucketName}`\n    });\n    this.originAccessIdentityId = this.originAccessIdentity.originAccessIdentityId;\n    this.bucket.grantRead(this.originAccessIdentity);\n  }\n\n  /**\n   * Helper method to deploy local assets to the created bucket. Ths function assumes\n   * CloudFront invalidation requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param paths the paths to the local assets\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deployPaths(paths: string[], maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return new BucketDeployment(this, `Deploy${this.nextDeployCount()}`, {\n      sources: paths.map(path => Source.asset(path)),\n      destinationBucket: this.bucket,\n      prune: prune ?? false,\n      cacheControl: [\n        CacheControl.setPublic(),\n        CacheControl.maxAge(maxAge ?? Duration.minutes(15)),\n        CacheControl.sMaxAge(sMaxAge ?? Duration.days(7))\n      ]\n    });\n  }\n\n  /**\n   * Helper method to deploy local assets to the created bucket. Ths function assumes\n   * CloudFront invalidation requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param path the path to the local assets\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deployPath(path: string, maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return this.deployPaths([path], maxAge, sMaxAge, prune);\n  }\n\n  /**\n   * Helper method to assets to the created bucket. This function assumes CloudFront invalidation\n   * requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param sources the sources to deploy\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deploySources(sources: ISource[], maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return new BucketDeployment(this, `Deploy${this.nextDeployCount()}`, {\n      sources: sources,\n      destinationBucket: this.bucket,\n      prune: prune ?? false,\n      cacheControl: [\n        CacheControl.setPublic(),\n        CacheControl.maxAge(maxAge ?? Duration.minutes(15)),\n        CacheControl.sMaxAge(sMaxAge ?? Duration.days(7))\n      ]\n    });\n  }\n\n  /**\n   * Helper method to assets to the created bucket. This function assumes CloudFront invalidation\n   * requests will be sent for mutable files to serve new content.\n   * For more complicated deployments, use BucketDeployment directly.\n   *\n   * @param source the source to deploy\n   * @param maxAge the length of time to browsers will cache files; default is Duration.minutes(15)\n   * @param sMaxAge the length of time CloudFront will cache files; default is Duration.days(7)\n   * @param prune true to prune old files; default is false\n   */\n  deploySource(source: ISource, maxAge?: Duration, sMaxAge?: Duration, prune?: boolean): BucketDeployment {\n    return this.deploySources([source], maxAge, sMaxAge, prune);\n  }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "truemark-cdk-lib",
|
|
3
|
-
"version": "1.5.
|
|
3
|
+
"version": "1.5.4",
|
|
4
4
|
"main": "index.js",
|
|
5
5
|
"types": "index.d.ts",
|
|
6
6
|
"scripts": {
|
|
@@ -73,5 +73,5 @@
|
|
|
73
73
|
"publishConfig": {
|
|
74
74
|
"access": "public"
|
|
75
75
|
},
|
|
76
|
-
"gitHead": "
|
|
76
|
+
"gitHead": "e13ac758d43022f153bd7d3dff1bea80845c8e1f"
|
|
77
77
|
}
|