@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
@@ -1,5 +1,5 @@
1
1
  hooks:
2
- 'release:deploy': UploadAssetsToS3
2
+ 'release:remote': UploadAssetsToS3
3
3
 
4
4
  options:
5
5
  '@dotcom-tool-kit/upload-static-assets':
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
- export declare type UploadAssetsToS3Options = {
3
- accessKeyId: string;
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;AAO5C,oBAAY,uBAAuB,GAAG;IACpC,WAAW,EAAE,MAAM,CAAA;IACnB,eAAe,EAAE,MAAM,CAAA;IACvB,SAAS,EAAE,MAAM,CAAA;IACjB,MAAM,EAAE,MAAM,CAAA;IACd,WAAW,EAAE,MAAM,CAAA;IACnB,UAAU,EAAE,MAAM,CAAA;IAClB,YAAY,EAAE,MAAM,CAAA;CACrB,CAAA;AAED,MAAM,CAAC,OAAO,OAAO,gBAAiB,SAAQ,IAAI,CAAC,uBAAuB,CAAC;IACzE,MAAM,CAAC,WAAW,SAAK;IAEvB,MAAM,CAAC,cAAc,EAAE,uBAAuB,CAQ7C;IAEK,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAG3B"}
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.AWS_ACCESS || '',
19
- secretAccessKey: process.env.AWS_SECRET || '',
18
+ accessKeyId: process.env.aws_access_hashed_assets || '',
19
+ secretAccessKey: process.env.aws_secret_hashed_assets || '',
20
20
  directory: 'public',
21
- bucket: 'ft-next-hashed-assets-prod',
22
- destination: 'hashed-assets/uploaded',
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: options.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
- const data = await s3.upload(params).promise();
57
- console.log(`Uploaded ${basename} to ${data.Location}`);
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 ${options.bucket} failed`);
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.0.0-beta.9",
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.0.0-beta.9",
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
  }