@lighthouse/common 5.0.0-canary-4 → 5.0.0-canary-5

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.
@@ -33,17 +33,18 @@ const fetchImageForPdfGeneratorService = async function (url) {
33
33
  throw new Error('Requestor has insufficient permissions');
34
34
  }
35
35
 
36
- const key = url.substring(url.indexOf(applicationId));
36
+ const keyWithTransformations = url.substring(url.indexOf(applicationId));
37
37
  const alreadyTransformedImage = await fetchResourceFromS3({
38
38
  bucketName: `${process.env.S3_BUCKET_UPLOADS}-transformed`,
39
- key
39
+ key: keyWithTransformations
40
40
  });
41
41
 
42
42
  if (alreadyTransformedImage && alreadyTransformedImage.body) {
43
43
  return alreadyTransformedImage.body.toString('base64');
44
44
  }
45
45
 
46
- const transformerResponse = await requestImageTransformation(key);
46
+ const keyWithoutTransformations = keyWithTransformations.split('?')[0];
47
+ const transformerResponse = await requestImageTransformation(keyWithoutTransformations);
47
48
  const statusCode = transformerResponse.statusCode;
48
49
 
49
50
  switch (statusCode) {
@@ -59,7 +60,7 @@ const fetchImageForPdfGeneratorService = async function (url) {
59
60
  if (redirectLocation) {
60
61
  const newlyTransformedImage = await fetchResourceFromS3({
61
62
  bucketName: `${process.env.S3_BUCKET_UPLOADS}-transformed`,
62
- key
63
+ key: keyWithTransformations
63
64
  });
64
65
  console.log('Image successfully fetched from S3 at:', redirectLocation);
65
66
  return newlyTransformedImage.body.toString('base64');
@@ -146,9 +147,6 @@ async function fetchResourceFromS3({
146
147
  etag: result.ETag
147
148
  };
148
149
  } catch (error) {
149
- // TODO: Remove this testing log
150
- console.info('ERROR: s3 Image fetch failure', error);
151
-
152
150
  if (error.code !== 'NoSuchKey') {
153
151
  console.info('ERROR: s3 Image fetch', error.code); // TODO: Remove this testing log
154
152
 
@@ -10,7 +10,7 @@ var s3 = new AWS.S3({
10
10
  });
11
11
  export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
12
12
  var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(url) {
13
- var urlMatch, applicationId, key, alreadyTransformedImage, transformerResponse, statusCode, _transformerResponse$, redirectLocation, newlyTransformedImage;
13
+ var urlMatch, applicationId, keyWithTransformations, alreadyTransformedImage, keyWithoutTransformations, transformerResponse, statusCode, _transformerResponse$, redirectLocation, newlyTransformedImage;
14
14
 
15
15
  return _regeneratorRuntime.wrap(function _callee$(_context) {
16
16
  while (1) {
@@ -37,11 +37,11 @@ export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
37
37
  throw new Error('Requestor has insufficient permissions');
38
38
 
39
39
  case 7:
40
- key = url.substring(url.indexOf(applicationId));
40
+ keyWithTransformations = url.substring(url.indexOf(applicationId));
41
41
  _context.next = 10;
42
42
  return fetchResourceFromS3({
43
43
  bucketName: "".concat(process.env.S3_BUCKET_UPLOADS, "-transformed"),
44
- key: key
44
+ key: keyWithTransformations
45
45
  });
46
46
 
47
47
  case 10:
@@ -55,59 +55,60 @@ export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
55
55
  return _context.abrupt("return", alreadyTransformedImage.body.toString('base64'));
56
56
 
57
57
  case 13:
58
- _context.next = 15;
59
- return requestImageTransformation(key);
58
+ keyWithoutTransformations = keyWithTransformations.split('?')[0];
59
+ _context.next = 16;
60
+ return requestImageTransformation(keyWithoutTransformations);
60
61
 
61
- case 15:
62
+ case 16:
62
63
  transformerResponse = _context.sent;
63
64
  statusCode = transformerResponse.statusCode;
64
65
  _context.t0 = statusCode;
65
- _context.next = _context.t0 === 200 ? 20 : _context.t0 === 302 ? 22 : _context.t0 === 400 ? 31 : _context.t0 === 403 ? 32 : _context.t0 === 404 ? 33 : _context.t0 === 500 ? 34 : 35;
66
+ _context.next = _context.t0 === 200 ? 21 : _context.t0 === 302 ? 23 : _context.t0 === 400 ? 32 : _context.t0 === 403 ? 33 : _context.t0 === 404 ? 34 : _context.t0 === 500 ? 35 : 36;
66
67
  break;
67
68
 
68
- case 20:
69
+ case 21:
69
70
  console.log('Image transformation successful');
70
71
  return _context.abrupt("return", transformerResponse.body);
71
72
 
72
- case 22:
73
+ case 23:
73
74
  console.log('Image transformation successful but image is too big for lambda delivery, fetching directly from S3');
74
75
  redirectLocation = (_transformerResponse$ = transformerResponse.headers) === null || _transformerResponse$ === void 0 ? void 0 : _transformerResponse$.Location;
75
76
 
76
77
  if (!redirectLocation) {
77
- _context.next = 30;
78
+ _context.next = 31;
78
79
  break;
79
80
  }
80
81
 
81
- _context.next = 27;
82
+ _context.next = 28;
82
83
  return fetchResourceFromS3({
83
84
  bucketName: "".concat(process.env.S3_BUCKET_UPLOADS, "-transformed"),
84
- key: key
85
+ key: keyWithTransformations
85
86
  });
86
87
 
87
- case 27:
88
+ case 28:
88
89
  newlyTransformedImage = _context.sent;
89
90
  console.log('Image successfully fetched from S3 at:', redirectLocation);
90
91
  return _context.abrupt("return", newlyTransformedImage.body.toString('base64'));
91
92
 
92
- case 30:
93
+ case 31:
93
94
  throw new Error('Redirect response received but no location provided');
94
95
 
95
- case 31:
96
+ case 32:
96
97
  throw new Error("Bad request to image transformer: ".concat(transformerResponse.body));
97
98
 
98
- case 32:
99
+ case 33:
99
100
  throw new Error('Requested transformed image is too big');
100
101
 
101
- case 33:
102
+ case 34:
102
103
  throw new Error('The requested image does not exist');
103
104
 
104
- case 34:
105
+ case 35:
105
106
  throw new Error("Image transformation failed: ".concat(transformerResponse.body));
106
107
 
107
- case 35:
108
+ case 36:
108
109
  throw new Error("Unexpected response from image transformer: ".concat(statusCode, " - ").concat(transformerResponse.body));
109
110
 
110
- case 36:
111
+ case 37:
111
112
  case "end":
112
113
  return _context.stop();
113
114
  }
@@ -224,11 +225,9 @@ function _fetchResourceFromS() {
224
225
  case 12:
225
226
  _context3.prev = 12;
226
227
  _context3.t0 = _context3["catch"](5);
227
- // TODO: Remove this testing log
228
- console.info('ERROR: s3 Image fetch failure', _context3.t0);
229
228
 
230
229
  if (!(_context3.t0.code !== 'NoSuchKey')) {
231
- _context3.next = 18;
230
+ _context3.next = 17;
232
231
  break;
233
232
  }
234
233
 
@@ -236,10 +235,10 @@ function _fetchResourceFromS() {
236
235
 
237
236
  throw new Error("Failed to fetch image: ".concat(bucketName, "/").concat(key));
238
237
 
239
- case 18:
238
+ case 17:
240
239
  console.info('Image not found in transformed bucket, invoking transformer');
241
240
 
242
- case 19:
241
+ case 18:
243
242
  case "end":
244
243
  return _context3.stop();
245
244
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/helpers/fetch-image-for-pdf-generator-service/index.js"],"names":["AWS","REGION","process","env","AWS_REGION","lambda","Lambda","region","s3","S3","fetchImageForPdfGeneratorService","url","console","info","Error","urlMatch","match","applicationId","key","substring","indexOf","fetchResourceFromS3","bucketName","S3_BUCKET_UPLOADS","alreadyTransformedImage","body","toString","requestImageTransformation","transformerResponse","statusCode","log","redirectLocation","headers","Location","newlyTransformedImage","lambdaEvent","requestContext","http","method","path","params","FunctionName","IMAGE_TRANSFORMER_ARN","InvocationType","Payload","JSON","stringify","invoke","promise","result","response","parse","errorMessage","message","error","Bucket","Key","getObject","Body","contentType","ContentType","contentLength","ContentLength","lastModified","LastModified","etag","ETag","code"],"mappings":"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","sourcesContent":["import AWS from 'aws-sdk'\nconst REGION = process.env.AWS_REGION\n\nconst lambda = new AWS.Lambda({\n region: REGION,\n})\nconst s3 = new AWS.S3({\n region: REGION,\n})\n\nexport const fetchImageForPdfGeneratorService = async function(url) {\n console.info(\n 'Fetching image via CloudFront For Serverless Pdf Generator Service'\n )\n\n if (!url) {\n throw new Error('URL is required to fetch image for PDF generator service')\n }\n\n const urlMatch = url && url.match(/([a-f0-9]{24})\\//)\n const applicationId = urlMatch && urlMatch[1]\n\n if (!applicationId) {\n throw new Error('Requestor has insufficient permissions')\n }\n\n const key = url.substring(url.indexOf(applicationId))\n\n const alreadyTransformedImage = await fetchResourceFromS3({\n bucketName: `${process.env.S3_BUCKET_UPLOADS}-transformed`,\n key,\n })\n\n if (alreadyTransformedImage && alreadyTransformedImage.body) {\n return alreadyTransformedImage.body.toString('base64')\n }\n\n const transformerResponse = await requestImageTransformation(key)\n\n const statusCode = transformerResponse.statusCode\n\n switch (statusCode) {\n case 200:\n console.log('Image transformation successful')\n return transformerResponse.body\n case 302: {\n console.log(\n 'Image transformation successful but image is too big for lambda delivery, fetching directly from S3'\n )\n const redirectLocation = transformerResponse.headers?.Location\n if (redirectLocation) {\n const newlyTransformedImage = await fetchResourceFromS3({\n bucketName: `${process.env.S3_BUCKET_UPLOADS}-transformed`,\n key,\n })\n console.log('Image successfully fetched from S3 at:', redirectLocation)\n\n return newlyTransformedImage.body.toString('base64')\n }\n throw new Error('Redirect response received but no location provided')\n }\n case 400:\n throw new Error(\n `Bad request to image transformer: ${transformerResponse.body}`\n )\n case 403:\n throw new Error('Requested transformed image is too big')\n case 404:\n throw new Error('The requested image does not exist')\n case 500:\n throw new Error(\n `Image transformation failed: ${transformerResponse.body}`\n )\n default:\n throw new Error(\n `Unexpected response from image transformer: ${statusCode} - ${transformerResponse.body}`\n )\n }\n}\n\nexport async function requestImageTransformation(key) {\n if (!key) {\n throw new Error('Image Path is required for image transformation')\n }\n\n console.log(\n 'ImageTransformation: Invoking image transformer lambda for path:',\n key\n )\n\n const lambdaEvent = {\n requestContext: {\n http: {\n method: 'GET',\n path: key,\n },\n },\n }\n\n const params = {\n FunctionName: process.env.IMAGE_TRANSFORMER_ARN,\n InvocationType: 'RequestResponse',\n Payload: JSON.stringify(lambdaEvent),\n }\n\n try {\n const result = await lambda.invoke(params).promise()\n\n const response = JSON.parse(result.Payload)\n\n return response\n } catch (error) {\n const errorMessage = `Failed to invoke image transformer lambda: ${error.message}`\n console.error(errorMessage, error)\n throw new Error(errorMessage)\n }\n}\n\nexport async function fetchResourceFromS3({ bucketName, key }) {\n console.info(\n `Fetching resource from S3 Bucket: '${bucketName}' at path: '${key}'`\n )\n if (!bucketName || !key) {\n throw new Error(\n 'bucketName and key are required for S3 resource fetch ' +\n JSON.stringify({ bucketName, key })\n )\n }\n\n const params = {\n Bucket: bucketName,\n Key: key,\n }\n\n try {\n const result = await s3.getObject(params).promise()\n\n return {\n body: result.Body,\n contentType: result.ContentType,\n contentLength: result.ContentLength,\n lastModified: result.LastModified,\n etag: result.ETag,\n }\n } catch (error) {\n // TODO: Remove this testing log\n console.info('ERROR: s3 Image fetch failure', error)\n if (error.code !== 'NoSuchKey') {\n console.info('ERROR: s3 Image fetch', error.code) // TODO: Remove this testing log\n throw new Error(`Failed to fetch image: ${bucketName}/${key}`)\n }\n\n console.info('Image not found in transformed bucket, invoking transformer')\n }\n}\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../../../src/helpers/fetch-image-for-pdf-generator-service/index.js"],"names":["AWS","REGION","process","env","AWS_REGION","lambda","Lambda","region","s3","S3","fetchImageForPdfGeneratorService","url","console","info","Error","urlMatch","match","applicationId","keyWithTransformations","substring","indexOf","fetchResourceFromS3","bucketName","S3_BUCKET_UPLOADS","key","alreadyTransformedImage","body","toString","keyWithoutTransformations","split","requestImageTransformation","transformerResponse","statusCode","log","redirectLocation","headers","Location","newlyTransformedImage","lambdaEvent","requestContext","http","method","path","params","FunctionName","IMAGE_TRANSFORMER_ARN","InvocationType","Payload","JSON","stringify","invoke","promise","result","response","parse","errorMessage","message","error","Bucket","Key","getObject","Body","contentType","ContentType","contentLength","ContentLength","lastModified","LastModified","etag","ETag","code"],"mappings":"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","sourcesContent":["import AWS from 'aws-sdk'\nconst REGION = process.env.AWS_REGION\n\nconst lambda = new AWS.Lambda({\n region: REGION,\n})\nconst s3 = new AWS.S3({\n region: REGION,\n})\n\nexport const fetchImageForPdfGeneratorService = async function(url) {\n console.info(\n 'Fetching image via CloudFront For Serverless Pdf Generator Service'\n )\n\n if (!url) {\n throw new Error('URL is required to fetch image for PDF generator service')\n }\n\n const urlMatch = url && url.match(/([a-f0-9]{24})\\//)\n const applicationId = urlMatch && urlMatch[1]\n\n if (!applicationId) {\n throw new Error('Requestor has insufficient permissions')\n }\n\n const keyWithTransformations = url.substring(url.indexOf(applicationId))\n\n const alreadyTransformedImage = await fetchResourceFromS3({\n bucketName: `${process.env.S3_BUCKET_UPLOADS}-transformed`,\n key: keyWithTransformations,\n })\n\n if (alreadyTransformedImage && alreadyTransformedImage.body) {\n return alreadyTransformedImage.body.toString('base64')\n }\n\n const keyWithoutTransformations = keyWithTransformations.split('?')[0]\n\n const transformerResponse = await requestImageTransformation(keyWithoutTransformations)\n\n const statusCode = transformerResponse.statusCode\n\n switch (statusCode) {\n case 200:\n console.log('Image transformation successful')\n return transformerResponse.body\n case 302: {\n console.log(\n 'Image transformation successful but image is too big for lambda delivery, fetching directly from S3'\n )\n const redirectLocation = transformerResponse.headers?.Location\n if (redirectLocation) {\n const newlyTransformedImage = await fetchResourceFromS3({\n bucketName: `${process.env.S3_BUCKET_UPLOADS}-transformed`,\n key: keyWithTransformations,\n })\n console.log('Image successfully fetched from S3 at:', redirectLocation)\n\n return newlyTransformedImage.body.toString('base64')\n }\n throw new Error('Redirect response received but no location provided')\n }\n case 400:\n throw new Error(\n `Bad request to image transformer: ${transformerResponse.body}`\n )\n case 403:\n throw new Error('Requested transformed image is too big')\n case 404:\n throw new Error('The requested image does not exist')\n case 500:\n throw new Error(\n `Image transformation failed: ${transformerResponse.body}`\n )\n default:\n throw new Error(\n `Unexpected response from image transformer: ${statusCode} - ${transformerResponse.body}`\n )\n }\n}\n\nexport async function requestImageTransformation(key) {\n if (!key) {\n throw new Error('Image Path is required for image transformation')\n }\n\n console.log(\n 'ImageTransformation: Invoking image transformer lambda for path:',\n key\n )\n\n const lambdaEvent = {\n requestContext: {\n http: {\n method: 'GET',\n path: key,\n },\n },\n }\n\n const params = {\n FunctionName: process.env.IMAGE_TRANSFORMER_ARN,\n InvocationType: 'RequestResponse',\n Payload: JSON.stringify(lambdaEvent),\n }\n\n try {\n const result = await lambda.invoke(params).promise()\n\n const response = JSON.parse(result.Payload)\n\n return response\n } catch (error) {\n const errorMessage = `Failed to invoke image transformer lambda: ${error.message}`\n console.error(errorMessage, error)\n throw new Error(errorMessage)\n }\n}\n\nexport async function fetchResourceFromS3({ bucketName, key }) {\n console.info(\n `Fetching resource from S3 Bucket: '${bucketName}' at path: '${key}'`\n )\n if (!bucketName || !key) {\n throw new Error(\n 'bucketName and key are required for S3 resource fetch ' +\n JSON.stringify({ bucketName, key })\n )\n }\n\n const params = {\n Bucket: bucketName,\n Key: key,\n }\n\n try {\n const result = await s3.getObject(params).promise()\n\n return {\n body: result.Body,\n contentType: result.ContentType,\n contentLength: result.ContentLength,\n lastModified: result.LastModified,\n etag: result.ETag,\n }\n } catch (error) {\n if (error.code !== 'NoSuchKey') {\n console.info('ERROR: s3 Image fetch', error.code) // TODO: Remove this testing log\n throw new Error(`Failed to fetch image: ${bucketName}/${key}`)\n }\n\n console.info('Image not found in transformed bucket, invoking transformer')\n }\n}\n"],"file":"index.js"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lighthouse/common",
3
- "version": "5.0.0-canary-4",
3
+ "version": "5.0.0-canary-5",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "module": "lib/index.js",