@dotcom-tool-kit/upload-assets-to-s3 1.0.0-beta.9 → 1.2.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/.toolkitrc.yml
CHANGED
package/lib/index.js
CHANGED
|
@@ -2,5 +2,5 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.tasks = void 0;
|
|
4
4
|
const tslib_1 = require("tslib");
|
|
5
|
-
const upload_assets_to_s3_1 = tslib_1.__importDefault(require("./tasks/upload-assets-to-s3"));
|
|
5
|
+
const upload_assets_to_s3_1 = (0, tslib_1.__importDefault)(require("./tasks/upload-assets-to-s3"));
|
|
6
6
|
exports.tasks = [upload_assets_to_s3_1.default];
|
|
@@ -1,14 +1,6 @@
|
|
|
1
1
|
import { Task } from '@dotcom-tool-kit/task';
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
secretAccessKey: string;
|
|
5
|
-
directory: string;
|
|
6
|
-
bucket: string;
|
|
7
|
-
destination: string;
|
|
8
|
-
extensions: string;
|
|
9
|
-
cacheControl: string;
|
|
10
|
-
};
|
|
11
|
-
export default class UploadAssetsToS3 extends Task<UploadAssetsToS3Options> {
|
|
2
|
+
import { UploadAssetsToS3Options, UploadAssetsToS3Schema } from '@dotcom-tool-kit/types/lib/schema/upload-assets-to-s3';
|
|
3
|
+
export default class UploadAssetsToS3 extends Task<typeof UploadAssetsToS3Schema> {
|
|
12
4
|
static description: string;
|
|
13
5
|
static defaultOptions: UploadAssetsToS3Options;
|
|
14
6
|
run(): Promise<void>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"upload-assets-to-s3.d.ts","sourceRoot":"","sources":["../../src/tasks/upload-assets-to-s3.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,uBAAuB,CAAA;
|
|
1
|
+
{"version":3,"file":"upload-assets-to-s3.d.ts","sourceRoot":"","sources":["../../src/tasks/upload-assets-to-s3.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,uBAAuB,CAAA;AAM5C,OAAO,EACL,uBAAuB,EACvB,sBAAsB,EACvB,MAAM,uDAAuD,CAAA;AAE9D,MAAM,CAAC,OAAO,OAAO,gBAAiB,SAAQ,IAAI,CAAC,OAAO,sBAAsB,CAAC;IAC/E,MAAM,CAAC,WAAW,SAAK;IAEvB,MAAM,CAAC,cAAc,EAAE,uBAAuB,CAS7C;IAEK,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAG3B"}
|
|
@@ -2,10 +2,10 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const tslib_1 = require("tslib");
|
|
4
4
|
const task_1 = require("@dotcom-tool-kit/task");
|
|
5
|
-
const fs = tslib_1.__importStar(require("fs"));
|
|
6
|
-
const aws_sdk_1 = tslib_1.__importDefault(require("aws-sdk"));
|
|
7
|
-
const path_1 = tslib_1.__importDefault(require("path"));
|
|
8
|
-
const mime_1 = tslib_1.__importDefault(require("mime"));
|
|
5
|
+
const fs = (0, tslib_1.__importStar)(require("fs"));
|
|
6
|
+
const aws_sdk_1 = (0, tslib_1.__importDefault)(require("aws-sdk"));
|
|
7
|
+
const path_1 = (0, tslib_1.__importDefault)(require("path"));
|
|
8
|
+
const mime_1 = (0, tslib_1.__importDefault)(require("mime"));
|
|
9
9
|
const glob_1 = require("glob");
|
|
10
10
|
class UploadAssetsToS3 extends task_1.Task {
|
|
11
11
|
async run() {
|
|
@@ -15,11 +15,12 @@ class UploadAssetsToS3 extends task_1.Task {
|
|
|
15
15
|
exports.default = UploadAssetsToS3;
|
|
16
16
|
UploadAssetsToS3.description = '';
|
|
17
17
|
UploadAssetsToS3.defaultOptions = {
|
|
18
|
-
accessKeyId: process.env.
|
|
19
|
-
secretAccessKey: process.env.
|
|
18
|
+
accessKeyId: process.env.aws_access_hashed_assets || '',
|
|
19
|
+
secretAccessKey: process.env.aws_secret_hashed_assets || '',
|
|
20
20
|
directory: 'public',
|
|
21
|
-
|
|
22
|
-
|
|
21
|
+
reviewBucket: ['ft-next-hashed-assets-preview'],
|
|
22
|
+
prodBucket: ['ft-next-hashed-assets-prod', 'ft-next-hashed-assets-prod-us'],
|
|
23
|
+
destination: 'hashed-assets/page-kit',
|
|
23
24
|
extensions: 'js,css,map,gz,br,png,jpg,jpeg,gif,webp,svg,ico,json',
|
|
24
25
|
cacheControl: 'public, max-age=31536000, stale-while-revalidate=60, stale-if-error=3600'
|
|
25
26
|
};
|
|
@@ -44,7 +45,7 @@ const uploadFile = async (file, options, s3) => {
|
|
|
44
45
|
const encoding = getFileEncoding(basename);
|
|
45
46
|
const key = path_1.default.posix.join(options.destination, basename);
|
|
46
47
|
const params = {
|
|
47
|
-
Bucket:
|
|
48
|
+
Bucket: '',
|
|
48
49
|
Key: key,
|
|
49
50
|
Body: fs.createReadStream(file),
|
|
50
51
|
ACL: 'public-read',
|
|
@@ -52,12 +53,42 @@ const uploadFile = async (file, options, s3) => {
|
|
|
52
53
|
ContentEncoding: encoding,
|
|
53
54
|
CacheControl: options.cacheControl
|
|
54
55
|
};
|
|
56
|
+
const bucketByEnv = process.env.NODE_ENV === 'branch' ? options.reviewBucket : options.prodBucket;
|
|
57
|
+
let currentBucket = '';
|
|
55
58
|
try {
|
|
56
|
-
|
|
57
|
-
|
|
59
|
+
if (typeof bucketByEnv === 'string') {
|
|
60
|
+
const params = {
|
|
61
|
+
Bucket: bucketByEnv,
|
|
62
|
+
Key: key,
|
|
63
|
+
Body: fs.createReadStream(file),
|
|
64
|
+
ACL: 'public-read',
|
|
65
|
+
ContentType: `${type}; charset=utf-8`,
|
|
66
|
+
ContentEncoding: encoding,
|
|
67
|
+
CacheControl: options.cacheControl
|
|
68
|
+
};
|
|
69
|
+
currentBucket = params.Bucket;
|
|
70
|
+
const data = await s3.upload(params).promise();
|
|
71
|
+
console.log(`Uploaded ${basename} to ${data.Location}`);
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
for (const bucket of bucketByEnv) {
|
|
75
|
+
const params = {
|
|
76
|
+
Bucket: bucket,
|
|
77
|
+
Key: key,
|
|
78
|
+
Body: fs.createReadStream(file),
|
|
79
|
+
ACL: 'public-read',
|
|
80
|
+
ContentType: `${type}; charset=utf-8`,
|
|
81
|
+
ContentEncoding: encoding,
|
|
82
|
+
CacheControl: options.cacheControl
|
|
83
|
+
};
|
|
84
|
+
currentBucket = params.Bucket;
|
|
85
|
+
const data = await s3.upload(params).promise();
|
|
86
|
+
console.log(`Uploaded ${basename} to ${data.Location}`);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
58
89
|
}
|
|
59
90
|
catch (error) {
|
|
60
|
-
console.error(`Upload of ${basename} to ${
|
|
91
|
+
console.error(`Upload of ${basename} to ${currentBucket} failed`);
|
|
61
92
|
throw error;
|
|
62
93
|
}
|
|
63
94
|
};
|
package/package.json
CHANGED
|
@@ -1,16 +1,17 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dotcom-tool-kit/upload-assets-to-s3",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.2.0",
|
|
4
4
|
"description": "",
|
|
5
5
|
"main": "lib",
|
|
6
6
|
"scripts": {
|
|
7
|
-
"test": "jest --silent"
|
|
7
|
+
"test": "cd ../../ ; npx jest --silent --projects packages/upload-assets-to-s3"
|
|
8
8
|
},
|
|
9
9
|
"keywords": [],
|
|
10
10
|
"author": "FT.com Platforms Team <platforms-team.customer-products@ft.com>",
|
|
11
11
|
"license": "ISC",
|
|
12
12
|
"dependencies": {
|
|
13
|
-
"@dotcom-tool-kit/task": "^1.
|
|
13
|
+
"@dotcom-tool-kit/task": "^1.2.0",
|
|
14
|
+
"@dotcom-tool-kit/types": "^1.2.0",
|
|
14
15
|
"aws-sdk": "^2.901.0",
|
|
15
16
|
"glob": "^7.1.6",
|
|
16
17
|
"mime": "^2.5.2"
|
|
@@ -27,12 +28,13 @@
|
|
|
27
28
|
"@jest/globals": "^26.6.2",
|
|
28
29
|
"@types/glob": "^7.1.3",
|
|
29
30
|
"@types/jest": "^26.0.23",
|
|
30
|
-
"@types/mime": "^2.0.3"
|
|
31
|
-
"jest": "^26.6.3",
|
|
32
|
-
"ts-jest": "^26.5.6"
|
|
31
|
+
"@types/mime": "^2.0.3"
|
|
33
32
|
},
|
|
34
33
|
"files": [
|
|
35
34
|
"/lib",
|
|
36
35
|
".toolkitrc.yml"
|
|
37
|
-
]
|
|
36
|
+
],
|
|
37
|
+
"volta": {
|
|
38
|
+
"extends": "../../package.json"
|
|
39
|
+
}
|
|
38
40
|
}
|