@lighthouse/common 6.2.0-canary.24 → 6.2.0-canary.26
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/dist/helpers/fetch-image/index.js +4 -0
- package/dist/helpers/fetch-image-for-pdf-generator-service/index.js +3 -0
- package/lib/helpers/fetch-image/index.js +4 -0
- package/lib/helpers/fetch-image/index.js.map +1 -1
- package/lib/helpers/fetch-image-for-pdf-generator-service/index.js +3 -0
- package/lib/helpers/fetch-image-for-pdf-generator-service/index.js.map +1 -1
- package/package.json +1 -1
|
@@ -57,6 +57,10 @@ function fetchImage(url, options = {}) {
|
|
|
57
57
|
const {
|
|
58
58
|
isHeader = false
|
|
59
59
|
} = options;
|
|
60
|
+
console.log('FETCHING SOME IMAGE,:', {
|
|
61
|
+
url,
|
|
62
|
+
options
|
|
63
|
+
});
|
|
60
64
|
return fetch(encodedUrl, fetchOptions).then(response => {
|
|
61
65
|
const contentHeader = response.headers.get('content-length');
|
|
62
66
|
const contentType = response.headers.get('content-type');
|
|
@@ -32,15 +32,18 @@ const fetchImageForPdfGeneratorService = async function (url) {
|
|
|
32
32
|
queryParams
|
|
33
33
|
} = parseUrlString(url);
|
|
34
34
|
const transformedBucketPath = `${path}/${queryParams}`;
|
|
35
|
+
console.log('FETCHING IMAGE FROM S3');
|
|
35
36
|
const alreadyTransformedImage = await fetchResourceFromS3({
|
|
36
37
|
bucketName: `${process.env.S3_BUCKET_IMAGE_TRANSFORMER_CACHE}`,
|
|
37
38
|
key: transformedBucketPath
|
|
38
39
|
});
|
|
39
40
|
if (alreadyTransformedImage?.body) {
|
|
41
|
+
console.log('IMAGE FOUND TO BE ALREADY TRANSFORMED');
|
|
40
42
|
const fullDataUrl = formatBase64Image({
|
|
41
43
|
base64String: alreadyTransformedImage.body.toString('base64'),
|
|
42
44
|
key: url
|
|
43
45
|
});
|
|
46
|
+
console.log('FULL DATA URL? ', JSON.stringify(fullDataUrl).substring(0, 50));
|
|
44
47
|
return fullDataUrl;
|
|
45
48
|
}
|
|
46
49
|
const transformerResponse = await requestImageTransformation(path);
|
|
@@ -46,6 +46,10 @@ export function fetchImage(url) {
|
|
|
46
46
|
var fetchOptions = _objectSpread(_objectSpread({}, defaultOptions), options);
|
|
47
47
|
var _options$isHeader = options.isHeader,
|
|
48
48
|
isHeader = _options$isHeader === void 0 ? false : _options$isHeader;
|
|
49
|
+
console.log('FETCHING SOME IMAGE,:', {
|
|
50
|
+
url: url,
|
|
51
|
+
options: options
|
|
52
|
+
});
|
|
49
53
|
return fetch(encodedUrl, fetchOptions).then(function (response) {
|
|
50
54
|
var contentHeader = response.headers.get('content-length');
|
|
51
55
|
var contentType = response.headers.get('content-type');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["atob","btoa","fetchPonyfill","Promise","LIGHTHOUSE_LOGO_URL","imageNotFound","fetchImageForPdfGeneratorService","fetchImageForWeb","fetch","self","_typeof","contentTypes","defaultOptions","cache","fetchImage","url","options","arguments","length","undefined","shouldUseCloudfront","console","log","isWebContext","window","encodedUrl","encodeURI","fetchOptions","_objectSpread","_options$isHeader","isHeader","then","response","contentHeader","headers","get","contentType","reject","Error","concat","ok","imageType","arrayBuffer","buffer","_ref","base64Flag","imageStr","arrayBufferToBase64","base64","isValid","validateBase64Image","catch","error","binary","bytes","slice","call","Uint8Array","forEach","b","String","fromCharCode","base64String","isJpeg","startsWith","validateJpegImage","isPng","validatePngImage","base64string","src","imageData","from","replace","c","charCodeAt","imageCorrupted","sequence","i"],"sources":["../../../src/helpers/fetch-image/index.js"],"sourcesContent":["import { atob, btoa } from '@lighthouse/abab'\nimport fetchPonyfill from 'fetch-ponyfill'\nimport Promise from 'bluebird'\nimport { LIGHTHOUSE_LOGO_URL } from '../../constants'\nimport { imageNotFound } from '../../images'\nimport { fetchImageForPdfGeneratorService } from '../fetch-image-for-pdf-generator-service'\nimport { fetchImageForWeb } from '../fetch-image-for-web'\n\n// NOTE use the native fetch if it's available in the browser, because the\n// ponyfill (which actually uses the github polyfill) does not support all the\n// same options as native fetch\nconst fetch =\n (typeof self === 'object' && self.fetch) || fetchPonyfill({ Promise }).fetch\n\nconst contentTypes = {\n 'image/png': 'png',\n 'image/jpeg': 'jpeg',\n}\n\nconst defaultOptions = {\n // NOTE The cache: no-cache option is important to avoid an issue with CORS\n // and caching on Chrome. Here's a good explanation of the issue:\n // https://stackoverflow.com/a/37455118\n // In our case, when loading the web version of a form, the signature image is\n // cached without the correct CORS headers. If the pdf is then generated,\n // there's a mismatch between the cached image headers and the CORS headers\n // sent from the fetch request, causing an error\n cache: 'no-cache',\n}\n\nexport function fetchImage(url, options = {}) {\n const { shouldUseCloudfront } = options\n console.log({ options })\n if (shouldUseCloudfront) {\n const isWebContext = typeof window === 'object'\n\n return isWebContext\n ? // Values used from options: isHeader, Signature, Policy, KeyPairId\n fetchImageForWeb(url, options)\n : fetchImageForPdfGeneratorService(url)\n }\n\n const encodedUrl = encodeURI(url)\n\n const fetchOptions = {\n ...defaultOptions,\n ...options,\n }\n const { isHeader = false } = options\n\n return fetch(encodedUrl, fetchOptions)\n .then((response) => {\n const contentHeader = response.headers.get('content-length')\n const contentType = response.headers.get('content-type')\n\n // NOTE: the response will be ok but we won't be able to render any\n // image meaning pdfmake will error. Raise error here and return early.\n if (contentHeader === '0') {\n return Promise.reject(\n new Error(`Failed to fetch image as no content length: ${encodedUrl}`)\n )\n }\n\n if (!response.ok) {\n return Promise.reject(new Error(`Failed to fetch image: ${encodedUrl}`))\n }\n\n const imageType = contentTypes[contentType]\n\n return response.arrayBuffer().then((buffer) => ({\n buffer,\n imageType,\n }))\n })\n .then(({ buffer, imageType }) => {\n const base64Flag = `data:image/${imageType};base64,`\n const imageStr = arrayBufferToBase64(buffer)\n\n const base64 = `${base64Flag}${imageStr}`\n const isValid = validateBase64Image(base64)\n\n if (!isValid) {\n return Promise.reject(new Error('InvalidImageError'))\n }\n\n return base64\n })\n .catch((error) => {\n if (isHeader) {\n // NOTE: Replace failed headers with LH logo\n console.error('FetchImageHeaderError', error)\n return fetchImage(LIGHTHOUSE_LOGO_URL, defaultOptions)\n }\n\n console.error(error)\n return imageNotFound\n })\n}\n\nexport function arrayBufferToBase64(buffer) {\n let binary = ''\n const bytes = [].slice.call(new Uint8Array(buffer))\n\n bytes.forEach((b) => (binary += String.fromCharCode(b)))\n\n return btoa(binary)\n}\n\nexport function validateBase64Image(base64String) {\n const isJpeg = base64String.startsWith('data:image/jpeg;base64,')\n\n if (isJpeg) return validateJpegImage(base64String)\n\n const isPng = base64String.startsWith('data:image/png;base64,')\n\n if (isPng) return validatePngImage(base64String)\n\n return false\n}\n\n// See SO for more info: https://stackoverflow.com/a/41635312\n// Fiddle: https://jsfiddle.net/Lnyxuchw/\nexport function validateJpegImage(base64string) {\n const src = base64string\n const imageData = Uint8Array.from(\n atob(src.replace('data:image/jpeg;base64,', '')),\n (c) => c.charCodeAt(0)\n )\n const imageCorrupted =\n imageData[imageData.length - 1] === 217 &&\n imageData[imageData.length - 2] === 255\n\n return imageCorrupted\n}\n\n// See SO for more info: https://stackoverflow.com/a/41635312\n// Fiddle: https://jsfiddle.net/Lnyxuchw/\nexport function validatePngImage(base64string) {\n const src = base64string\n const imageData = Uint8Array.from(\n atob(src.replace('data:image/png;base64,', '')),\n (c) => c.charCodeAt(0)\n )\n const sequence = [0, 0, 0, 0, 73, 69, 78, 68, 174, 66, 96, 130]\n\n //check last 12 elements of array so they contains needed values\n for (let i = 12; i > 0; i--) {\n if (imageData[imageData.length - i] !== sequence[12 - i]) {\n return false\n }\n }\n\n return true\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"index.js","names":["atob","btoa","fetchPonyfill","Promise","LIGHTHOUSE_LOGO_URL","imageNotFound","fetchImageForPdfGeneratorService","fetchImageForWeb","fetch","self","_typeof","contentTypes","defaultOptions","cache","fetchImage","url","options","arguments","length","undefined","shouldUseCloudfront","console","log","isWebContext","window","encodedUrl","encodeURI","fetchOptions","_objectSpread","_options$isHeader","isHeader","then","response","contentHeader","headers","get","contentType","reject","Error","concat","ok","imageType","arrayBuffer","buffer","_ref","base64Flag","imageStr","arrayBufferToBase64","base64","isValid","validateBase64Image","catch","error","binary","bytes","slice","call","Uint8Array","forEach","b","String","fromCharCode","base64String","isJpeg","startsWith","validateJpegImage","isPng","validatePngImage","base64string","src","imageData","from","replace","c","charCodeAt","imageCorrupted","sequence","i"],"sources":["../../../src/helpers/fetch-image/index.js"],"sourcesContent":["import { atob, btoa } from '@lighthouse/abab'\nimport fetchPonyfill from 'fetch-ponyfill'\nimport Promise from 'bluebird'\nimport { LIGHTHOUSE_LOGO_URL } from '../../constants'\nimport { imageNotFound } from '../../images'\nimport { fetchImageForPdfGeneratorService } from '../fetch-image-for-pdf-generator-service'\nimport { fetchImageForWeb } from '../fetch-image-for-web'\n\n// NOTE use the native fetch if it's available in the browser, because the\n// ponyfill (which actually uses the github polyfill) does not support all the\n// same options as native fetch\nconst fetch =\n (typeof self === 'object' && self.fetch) || fetchPonyfill({ Promise }).fetch\n\nconst contentTypes = {\n 'image/png': 'png',\n 'image/jpeg': 'jpeg',\n}\n\nconst defaultOptions = {\n // NOTE The cache: no-cache option is important to avoid an issue with CORS\n // and caching on Chrome. Here's a good explanation of the issue:\n // https://stackoverflow.com/a/37455118\n // In our case, when loading the web version of a form, the signature image is\n // cached without the correct CORS headers. If the pdf is then generated,\n // there's a mismatch between the cached image headers and the CORS headers\n // sent from the fetch request, causing an error\n cache: 'no-cache',\n}\n\nexport function fetchImage(url, options = {}) {\n const { shouldUseCloudfront } = options\n console.log({ options })\n if (shouldUseCloudfront) {\n const isWebContext = typeof window === 'object'\n\n return isWebContext\n ? // Values used from options: isHeader, Signature, Policy, KeyPairId\n fetchImageForWeb(url, options)\n : fetchImageForPdfGeneratorService(url)\n }\n\n const encodedUrl = encodeURI(url)\n\n const fetchOptions = {\n ...defaultOptions,\n ...options,\n }\n const { isHeader = false } = options\n console.log('FETCHING SOME IMAGE,:', { url, options })\n return fetch(encodedUrl, fetchOptions)\n .then((response) => {\n const contentHeader = response.headers.get('content-length')\n const contentType = response.headers.get('content-type')\n\n // NOTE: the response will be ok but we won't be able to render any\n // image meaning pdfmake will error. Raise error here and return early.\n if (contentHeader === '0') {\n return Promise.reject(\n new Error(`Failed to fetch image as no content length: ${encodedUrl}`)\n )\n }\n\n if (!response.ok) {\n return Promise.reject(new Error(`Failed to fetch image: ${encodedUrl}`))\n }\n\n const imageType = contentTypes[contentType]\n\n return response.arrayBuffer().then((buffer) => ({\n buffer,\n imageType,\n }))\n })\n .then(({ buffer, imageType }) => {\n const base64Flag = `data:image/${imageType};base64,`\n const imageStr = arrayBufferToBase64(buffer)\n\n const base64 = `${base64Flag}${imageStr}`\n const isValid = validateBase64Image(base64)\n\n if (!isValid) {\n return Promise.reject(new Error('InvalidImageError'))\n }\n\n return base64\n })\n .catch((error) => {\n if (isHeader) {\n // NOTE: Replace failed headers with LH logo\n console.error('FetchImageHeaderError', error)\n return fetchImage(LIGHTHOUSE_LOGO_URL, defaultOptions)\n }\n\n console.error(error)\n return imageNotFound\n })\n}\n\nexport function arrayBufferToBase64(buffer) {\n let binary = ''\n const bytes = [].slice.call(new Uint8Array(buffer))\n\n bytes.forEach((b) => (binary += String.fromCharCode(b)))\n\n return btoa(binary)\n}\n\nexport function validateBase64Image(base64String) {\n const isJpeg = base64String.startsWith('data:image/jpeg;base64,')\n\n if (isJpeg) return validateJpegImage(base64String)\n\n const isPng = base64String.startsWith('data:image/png;base64,')\n\n if (isPng) return validatePngImage(base64String)\n\n return false\n}\n\n// See SO for more info: https://stackoverflow.com/a/41635312\n// Fiddle: https://jsfiddle.net/Lnyxuchw/\nexport function validateJpegImage(base64string) {\n const src = base64string\n const imageData = Uint8Array.from(\n atob(src.replace('data:image/jpeg;base64,', '')),\n (c) => c.charCodeAt(0)\n )\n const imageCorrupted =\n imageData[imageData.length - 1] === 217 &&\n imageData[imageData.length - 2] === 255\n\n return imageCorrupted\n}\n\n// See SO for more info: https://stackoverflow.com/a/41635312\n// Fiddle: https://jsfiddle.net/Lnyxuchw/\nexport function validatePngImage(base64string) {\n const src = base64string\n const imageData = Uint8Array.from(\n atob(src.replace('data:image/png;base64,', '')),\n (c) => c.charCodeAt(0)\n )\n const sequence = [0, 0, 0, 0, 73, 69, 78, 68, 174, 66, 96, 130]\n\n //check last 12 elements of array so they contains needed values\n for (let i = 12; i > 0; i--) {\n if (imageData[imageData.length - i] !== sequence[12 - i]) {\n return false\n }\n }\n\n return true\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -33,6 +33,7 @@ export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
|
|
|
33
33
|
case 2:
|
|
34
34
|
_parseUrlString = parseUrlString(url), path = _parseUrlString.path, queryParams = _parseUrlString.queryParams;
|
|
35
35
|
transformedBucketPath = "".concat(path, "/").concat(queryParams);
|
|
36
|
+
console.log('FETCHING IMAGE FROM S3');
|
|
36
37
|
_context.next = 3;
|
|
37
38
|
return fetchResourceFromS3({
|
|
38
39
|
bucketName: "".concat(process.env.S3_BUCKET_IMAGE_TRANSFORMER_CACHE),
|
|
@@ -44,10 +45,12 @@ export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
|
|
|
44
45
|
_context.next = 4;
|
|
45
46
|
break;
|
|
46
47
|
}
|
|
48
|
+
console.log('IMAGE FOUND TO BE ALREADY TRANSFORMED');
|
|
47
49
|
fullDataUrl = formatBase64Image({
|
|
48
50
|
base64String: alreadyTransformedImage.body.toString('base64'),
|
|
49
51
|
key: url
|
|
50
52
|
});
|
|
53
|
+
console.log('FULL DATA URL? ', JSON.stringify(fullDataUrl).substring(0, 50));
|
|
51
54
|
return _context.abrupt("return", fullDataUrl);
|
|
52
55
|
case 4:
|
|
53
56
|
_context.next = 5;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["validateBase64Image","AWS","REGION","process","env","AWS_REGION","lambda","Lambda","region","s3","S3","fetchImageForPdfGeneratorService","_ref","_asyncToGenerator","_regeneratorRuntime","mark","_callee","url","urlMatch","applicationId","_parseUrlString","path","queryParams","transformedBucketPath","alreadyTransformedImage","fullDataUrl","transformerResponse","statusCode","_fullDataUrl","_transformerResponse$","redirectLocation","newlyTransformedImage","_fullDataUrl2","_t","wrap","_context","prev","next","console","debug","Error","match","parseUrlString","concat","fetchResourceFromS3","bucketName","S3_BUCKET_IMAGE_TRANSFORMER_CACHE","key","sent","body","formatBase64Image","base64String","toString","abrupt","requestImageTransformation","headers","Location","stop","_x","apply","arguments","_x2","_requestImageTransformation","_callee2","_parseUrlString2","queryParamsObject","lambdaEvent","params","result","response","errorMessage","_t2","_context2","split","forEach","param","_param$split","_param$split2","_slicedToArray","value","queryStringParameters","Object","keys","length","requestContext","http","method","FunctionName","IMAGE_TRANSFORMER_ARN","InvocationType","Payload","JSON","stringify","invoke","promise","parse","message","error","_x3","_fetchResourceFromS","_callee3","_ref2","_t3","_context3","Bucket","Key","getObject","Body","contentType","ContentType","contentLength","ContentLength","lastModified","LastModified","etag","ETag","code","_ref3","imageType","toLowerCase","includes","base64Flag","isValid","urlString","_urlString$split","_urlString$split2","queryString","pathWithoutSlash","substring","map","join"],"sources":["../../../src/helpers/fetch-image-for-pdf-generator-service/index.js"],"sourcesContent":["import { validateBase64Image } from '../image-validators'\nimport 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.debug(\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 { path, queryParams } = parseUrlString(url)\n\n const transformedBucketPath = `${path}/${queryParams}`\n\n const alreadyTransformedImage = await fetchResourceFromS3({\n bucketName: `${process.env.S3_BUCKET_IMAGE_TRANSFORMER_CACHE}`,\n key: transformedBucketPath,\n })\n\n if (alreadyTransformedImage?.body) {\n const fullDataUrl = formatBase64Image({\n base64String: alreadyTransformedImage.body.toString('base64'),\n key: url,\n })\n return fullDataUrl\n }\n\n const transformerResponse = await requestImageTransformation(path)\n\n const statusCode = transformerResponse.statusCode\n\n switch (statusCode) {\n case 200: {\n console.debug('Image transformation successful')\n\n const fullDataUrl = formatBase64Image({\n base64String: transformerResponse.body.toString('base64'),\n key: url,\n })\n\n return fullDataUrl\n }\n case 302: {\n console.debug(\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_IMAGE_TRANSFORMER_CACHE}`,\n key: transformedBucketPath,\n })\n console.debug(\n 'Image successfully fetched from S3 at:',\n redirectLocation\n )\n\n const fullDataUrl = formatBase64Image({\n base64String: newlyTransformedImage.body.toString('base64'),\n key: transformedBucketPath,\n })\n\n return fullDataUrl\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(url) {\n if (!url) {\n throw new Error('Image URL is required for image transformation')\n }\n\n console.debug(\n 'ImageTransformation: Invoking image transformer lambda for URL:',\n url\n )\n\n const { path, queryParams } = parseUrlString(url)\n\n const queryParamsObject = {}\n if (queryParams) {\n queryParams.split(',').forEach((param) => {\n const [key, value] = param.split('=')\n if (key && value) {\n queryParamsObject[key] = value\n }\n })\n }\n\n const lambdaEvent = {\n queryStringParameters:\n Object.keys(queryParamsObject).length > 0 ? queryParamsObject : null,\n requestContext: {\n http: {\n method: 'GET',\n path: `/${path}`,\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.debug(\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.error('Failed to fetch image:', error)\n throw new Error(`Failed to fetch image: ${bucketName}/${key}`)\n }\n\n console.debug('Image not found in transformed bucket, invoking transformer')\n }\n}\n\nexport function formatBase64Image({ base64String, key }) {\n if (!key) {\n throw new Error('Key is required for image formatting')\n }\n\n const imageType = key.toLowerCase().includes('.png') ? 'png' : 'jpeg'\n const base64Flag = `data:image/${imageType};base64,`\n const fullDataUrl = `${base64Flag}${base64String}`\n\n // Validate the formatted data URL\n const isValid = validateBase64Image(fullDataUrl)\n if (!isValid) {\n throw new Error('InvalidImageError')\n }\n\n return fullDataUrl\n}\n\n/**\n * Parses a URL-like string into path and query parameters\n * @param {string} urlString - String like \"<applicationId>/<path>/filename.jpeg?width=100&height=100\"\n * @returns {Object} - Object with { path: string, queryParams: string }\n * @example\n * parseUrlString(\"abc123/folder/image.jpeg?width=100&height=100\")\n * // Returns: { path: \"abc123/folder/image.jpeg\", queryParams: \"width=100,height=100\" }\n */\nfunction parseUrlString(urlString) {\n if (!urlString || typeof urlString !== 'string') {\n throw new Error('URL string is required and must be a string')\n }\n\n // Split on the first occurrence of '?' to separate path from query parameters\n const [path, queryString] = urlString.split('?')\n\n const pathWithoutSlash = path.substring(1)\n\n if (!path) {\n throw new Error('Invalid URL string: missing path component')\n }\n\n // If there are no query parameters, return path with empty queryParams\n if (!queryString) {\n return {\n path: path,\n queryParams: '',\n }\n }\n\n // Parse query parameters and convert to comma-separated format\n const queryParams = queryString\n .split('&')\n .map((param) => {\n // Handle parameters that might not have '=' (though uncommon)\n if (!param.includes('=')) {\n return param\n }\n return param\n })\n .join(',')\n\n return {\n path: pathWithoutSlash,\n queryParams: queryParams,\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"index.js","names":["validateBase64Image","AWS","REGION","process","env","AWS_REGION","lambda","Lambda","region","s3","S3","fetchImageForPdfGeneratorService","_ref","_asyncToGenerator","_regeneratorRuntime","mark","_callee","url","urlMatch","applicationId","_parseUrlString","path","queryParams","transformedBucketPath","alreadyTransformedImage","fullDataUrl","transformerResponse","statusCode","_fullDataUrl","_transformerResponse$","redirectLocation","newlyTransformedImage","_fullDataUrl2","_t","wrap","_context","prev","next","console","debug","Error","match","parseUrlString","concat","log","fetchResourceFromS3","bucketName","S3_BUCKET_IMAGE_TRANSFORMER_CACHE","key","sent","body","formatBase64Image","base64String","toString","JSON","stringify","substring","abrupt","requestImageTransformation","headers","Location","stop","_x","apply","arguments","_x2","_requestImageTransformation","_callee2","_parseUrlString2","queryParamsObject","lambdaEvent","params","result","response","errorMessage","_t2","_context2","split","forEach","param","_param$split","_param$split2","_slicedToArray","value","queryStringParameters","Object","keys","length","requestContext","http","method","FunctionName","IMAGE_TRANSFORMER_ARN","InvocationType","Payload","invoke","promise","parse","message","error","_x3","_fetchResourceFromS","_callee3","_ref2","_t3","_context3","Bucket","Key","getObject","Body","contentType","ContentType","contentLength","ContentLength","lastModified","LastModified","etag","ETag","code","_ref3","imageType","toLowerCase","includes","base64Flag","isValid","urlString","_urlString$split","_urlString$split2","queryString","pathWithoutSlash","map","join"],"sources":["../../../src/helpers/fetch-image-for-pdf-generator-service/index.js"],"sourcesContent":["import { validateBase64Image } from '../image-validators'\nimport 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.debug(\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 { path, queryParams } = parseUrlString(url)\n\n const transformedBucketPath = `${path}/${queryParams}`\n\n console.log('FETCHING IMAGE FROM S3')\n const alreadyTransformedImage = await fetchResourceFromS3({\n bucketName: `${process.env.S3_BUCKET_IMAGE_TRANSFORMER_CACHE}`,\n key: transformedBucketPath,\n })\n\n if (alreadyTransformedImage?.body) {\n console.log('IMAGE FOUND TO BE ALREADY TRANSFORMED')\n const fullDataUrl = formatBase64Image({\n base64String: alreadyTransformedImage.body.toString('base64'),\n key: url,\n })\n console.log('FULL DATA URL? ', JSON.stringify(fullDataUrl).substring(0, 50))\n return fullDataUrl\n }\n\n const transformerResponse = await requestImageTransformation(path)\n\n const statusCode = transformerResponse.statusCode\n\n switch (statusCode) {\n case 200: {\n console.debug('Image transformation successful')\n\n const fullDataUrl = formatBase64Image({\n base64String: transformerResponse.body.toString('base64'),\n key: url,\n })\n\n return fullDataUrl\n }\n case 302: {\n console.debug(\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_IMAGE_TRANSFORMER_CACHE}`,\n key: transformedBucketPath,\n })\n console.debug(\n 'Image successfully fetched from S3 at:',\n redirectLocation\n )\n\n const fullDataUrl = formatBase64Image({\n base64String: newlyTransformedImage.body.toString('base64'),\n key: transformedBucketPath,\n })\n\n return fullDataUrl\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(url) {\n if (!url) {\n throw new Error('Image URL is required for image transformation')\n }\n\n console.debug(\n 'ImageTransformation: Invoking image transformer lambda for URL:',\n url\n )\n\n const { path, queryParams } = parseUrlString(url)\n\n const queryParamsObject = {}\n if (queryParams) {\n queryParams.split(',').forEach((param) => {\n const [key, value] = param.split('=')\n if (key && value) {\n queryParamsObject[key] = value\n }\n })\n }\n\n const lambdaEvent = {\n queryStringParameters:\n Object.keys(queryParamsObject).length > 0 ? queryParamsObject : null,\n requestContext: {\n http: {\n method: 'GET',\n path: `/${path}`,\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.debug(\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.error('Failed to fetch image:', error)\n throw new Error(`Failed to fetch image: ${bucketName}/${key}`)\n }\n\n console.debug('Image not found in transformed bucket, invoking transformer')\n }\n}\n\nexport function formatBase64Image({ base64String, key }) {\n if (!key) {\n throw new Error('Key is required for image formatting')\n }\n\n const imageType = key.toLowerCase().includes('.png') ? 'png' : 'jpeg'\n const base64Flag = `data:image/${imageType};base64,`\n const fullDataUrl = `${base64Flag}${base64String}`\n\n // Validate the formatted data URL\n const isValid = validateBase64Image(fullDataUrl)\n if (!isValid) {\n throw new Error('InvalidImageError')\n }\n\n return fullDataUrl\n}\n\n/**\n * Parses a URL-like string into path and query parameters\n * @param {string} urlString - String like \"<applicationId>/<path>/filename.jpeg?width=100&height=100\"\n * @returns {Object} - Object with { path: string, queryParams: string }\n * @example\n * parseUrlString(\"abc123/folder/image.jpeg?width=100&height=100\")\n * // Returns: { path: \"abc123/folder/image.jpeg\", queryParams: \"width=100,height=100\" }\n */\nfunction parseUrlString(urlString) {\n if (!urlString || typeof urlString !== 'string') {\n throw new Error('URL string is required and must be a string')\n }\n\n // Split on the first occurrence of '?' to separate path from query parameters\n const [path, queryString] = urlString.split('?')\n\n const pathWithoutSlash = path.substring(1)\n\n if (!path) {\n throw new Error('Invalid URL string: missing path component')\n }\n\n // If there are no query parameters, return path with empty queryParams\n if (!queryString) {\n return {\n path: path,\n queryParams: '',\n }\n }\n\n // Parse query parameters and convert to comma-separated format\n const queryParams = queryString\n .split('&')\n .map((param) => {\n // Handle parameters that might not have '=' (though uncommon)\n if (!param.includes('=')) {\n return param\n }\n return param\n })\n .join(',')\n\n return {\n path: pathWithoutSlash,\n queryParams: queryParams,\n }\n}\n"],"mappings":"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","ignoreList":[]}
|