@lighthouse/common 5.0.0-canary-2 → 5.0.0-canary-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.
@@ -33,7 +33,7 @@ const fetchImageForPdfGeneratorService = async function (url) {
33
33
  throw new Error('Requestor has insufficient permissions');
34
34
  }
35
35
 
36
- const key = url.split(applicationId)[1];
36
+ const key = url.substring(url.indexOf(applicationId));
37
37
  const alreadyTransformedImage = await fetchResourceFromS3({
38
38
  bucketName: `${process.env.S3_BUCKET_UPLOADS}-transformed`,
39
39
  key
@@ -146,7 +146,12 @@ async function fetchResourceFromS3({
146
146
  etag: result.ETag
147
147
  };
148
148
  } catch (error) {
149
+ // TODO: Remove this testing log
150
+ console.info('ERROR: s3 Image fetch failure', error);
151
+
149
152
  if (error.code !== 'NoSuchKey') {
153
+ console.info('ERROR: s3 Image fetch', error.code); // TODO: Remove this testing log
154
+
150
155
  throw new Error(`Failed to fetch image: ${bucketName}/${key}`);
151
156
  }
152
157
 
@@ -37,7 +37,7 @@ export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
37
37
  throw new Error('Requestor has insufficient permissions');
38
38
 
39
39
  case 7:
40
- key = url.split(applicationId)[1];
40
+ key = url.substring(url.indexOf(applicationId));
41
41
  _context.next = 10;
42
42
  return fetchResourceFromS3({
43
43
  bucketName: "".concat(process.env.S3_BUCKET_UPLOADS, "-transformed"),
@@ -224,18 +224,22 @@ function _fetchResourceFromS() {
224
224
  case 12:
225
225
  _context3.prev = 12;
226
226
  _context3.t0 = _context3["catch"](5);
227
+ // TODO: Remove this testing log
228
+ console.info('ERROR: s3 Image fetch failure', _context3.t0);
227
229
 
228
230
  if (!(_context3.t0.code !== 'NoSuchKey')) {
229
- _context3.next = 16;
231
+ _context3.next = 18;
230
232
  break;
231
233
  }
232
234
 
235
+ console.info('ERROR: s3 Image fetch', _context3.t0.code); // TODO: Remove this testing log
236
+
233
237
  throw new Error("Failed to fetch image: ".concat(bucketName, "/").concat(key));
234
238
 
235
- case 16:
239
+ case 18:
236
240
  console.info('Image not found in transformed bucket, invoking transformer');
237
241
 
238
- case 17:
242
+ case 19:
239
243
  case "end":
240
244
  return _context3.stop();
241
245
  }
@@ -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","split","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'\n\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.split(applicationId)[1]\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 if (error.code !== 'NoSuchKey') {\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","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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lighthouse/common",
3
- "version": "5.0.0-canary-2",
3
+ "version": "5.0.0-canary-4",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "module": "lib/index.js",