@dotcom-tool-kit/upload-assets-to-s3 1.0.0-beta.28 → 1.0.0-beta.31

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.
@@ -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"}
@@ -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,6 +1,6 @@
1
1
  {
2
2
  "name": "@dotcom-tool-kit/upload-assets-to-s3",
3
- "version": "1.0.0-beta.28",
3
+ "version": "1.0.0-beta.31",
4
4
  "description": "",
5
5
  "main": "lib",
6
6
  "scripts": {
@@ -10,7 +10,8 @@
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.28",
13
+ "@dotcom-tool-kit/task": "^1.0.0-beta.31",
14
+ "@dotcom-tool-kit/types": "^1.0.0-beta.31",
14
15
  "aws-sdk": "^2.901.0",
15
16
  "glob": "^7.1.6",
16
17
  "mime": "^2.5.2"