@lighthouse/common 6.9.6 → 6.9.7
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.
|
@@ -48,6 +48,7 @@ const fetchImageForPdfGeneratorService = async function (url) {
|
|
|
48
48
|
}
|
|
49
49
|
const transformerResponse = await requestImageTransformation(`/${path}`, searchParamsObject);
|
|
50
50
|
const statusCode = transformerResponse.statusCode;
|
|
51
|
+
const redirectLocation = transformerResponse.headers?.Location;
|
|
51
52
|
switch (statusCode) {
|
|
52
53
|
case 200:
|
|
53
54
|
{
|
|
@@ -60,21 +61,24 @@ const fetchImageForPdfGeneratorService = async function (url) {
|
|
|
60
61
|
}
|
|
61
62
|
case 302:
|
|
62
63
|
{
|
|
63
|
-
console.debug('Image transformation successful but image is too big for lambda delivery, fetching directly
|
|
64
|
-
const redirectLocation = transformerResponse.headers.Location;
|
|
64
|
+
console.debug('Image transformation successful but image is too big for lambda delivery, fetching directly via redirect URL');
|
|
65
65
|
if (!redirectLocation) {
|
|
66
66
|
throw new Error('Redirect response received but no location provided');
|
|
67
67
|
}
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
})
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
68
|
+
let response;
|
|
69
|
+
try {
|
|
70
|
+
response = await fetch(redirectLocation);
|
|
71
|
+
} catch (error) {
|
|
72
|
+
throw new Error(`Failed to fetch image from redirect URL: ${error.message}`);
|
|
73
|
+
}
|
|
74
|
+
if (!response.ok) {
|
|
75
|
+
throw new Error(`Failed to fetch image from redirect: ${response.status}`);
|
|
76
|
+
}
|
|
77
|
+
const buffer = Buffer.from(await response.arrayBuffer());
|
|
78
|
+
return formatBase64Image({
|
|
79
|
+
base64String: buffer.toString('base64'),
|
|
75
80
|
key: transformedBucketImagePath
|
|
76
81
|
});
|
|
77
|
-
return fullDataUrl;
|
|
78
82
|
}
|
|
79
83
|
case 400:
|
|
80
84
|
throw new Error(`Bad request to image transformer: ${transformerResponse.body}`);
|
|
@@ -14,7 +14,8 @@ var s3 = new AWS.S3({
|
|
|
14
14
|
});
|
|
15
15
|
export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
|
|
16
16
|
var _ref = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee(url) {
|
|
17
|
-
var
|
|
17
|
+
var _transformerResponse$;
|
|
18
|
+
var urlMatch, applicationId, _parseUrlString, path, queryString, searchParamsObject, transformedBucketImagePath, alreadyTransformedImage, fullDataUrl, transformerResponse, statusCode, redirectLocation, _fullDataUrl, response, buffer, _t, _t2, _t3;
|
|
18
19
|
return _regeneratorRuntime.wrap(function (_context) {
|
|
19
20
|
while (1) switch (_context.prev = _context.next) {
|
|
20
21
|
case 0:
|
|
@@ -57,8 +58,9 @@ export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
|
|
|
57
58
|
case 5:
|
|
58
59
|
transformerResponse = _context.sent;
|
|
59
60
|
statusCode = transformerResponse.statusCode;
|
|
61
|
+
redirectLocation = (_transformerResponse$ = transformerResponse.headers) === null || _transformerResponse$ === void 0 ? void 0 : _transformerResponse$.Location;
|
|
60
62
|
_t = statusCode;
|
|
61
|
-
_context.next = _t === 200 ? 6 : _t === 302 ? 7 : _t === 400 ?
|
|
63
|
+
_context.next = _t === 200 ? 6 : _t === 302 ? 7 : _t === 400 ? 14 : _t === 403 ? 15 : _t === 404 ? 16 : _t === 500 ? 17 : 18;
|
|
62
64
|
break;
|
|
63
65
|
case 6:
|
|
64
66
|
console.debug('Image transformation successful');
|
|
@@ -68,42 +70,55 @@ export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
|
|
|
68
70
|
});
|
|
69
71
|
return _context.abrupt("return", _fullDataUrl);
|
|
70
72
|
case 7:
|
|
71
|
-
console.debug('Image transformation successful but image is too big for lambda delivery, fetching directly
|
|
72
|
-
redirectLocation = transformerResponse.headers.Location;
|
|
73
|
+
console.debug('Image transformation successful but image is too big for lambda delivery, fetching directly via redirect URL');
|
|
73
74
|
if (redirectLocation) {
|
|
74
75
|
_context.next = 8;
|
|
75
76
|
break;
|
|
76
77
|
}
|
|
77
78
|
throw new Error('Redirect response received but no location provided');
|
|
78
79
|
case 8:
|
|
80
|
+
_context.prev = 8;
|
|
79
81
|
_context.next = 9;
|
|
80
|
-
return
|
|
81
|
-
bucketName: process.env.S3_BUCKET_IMAGE_TRANSFORMER_CACHE,
|
|
82
|
-
key: transformedBucketImagePath
|
|
83
|
-
});
|
|
82
|
+
return fetch(redirectLocation);
|
|
84
83
|
case 9:
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
base64String: newlyTransformedImage.body.toString('base64'),
|
|
89
|
-
key: transformedBucketImagePath
|
|
90
|
-
});
|
|
91
|
-
return _context.abrupt("return", _fullDataUrl2);
|
|
84
|
+
response = _context.sent;
|
|
85
|
+
_context.next = 11;
|
|
86
|
+
break;
|
|
92
87
|
case 10:
|
|
93
|
-
|
|
88
|
+
_context.prev = 10;
|
|
89
|
+
_t2 = _context["catch"](8);
|
|
90
|
+
throw new Error("Failed to fetch image from redirect URL: ".concat(_t2.message));
|
|
94
91
|
case 11:
|
|
95
|
-
|
|
92
|
+
if (response.ok) {
|
|
93
|
+
_context.next = 12;
|
|
94
|
+
break;
|
|
95
|
+
}
|
|
96
|
+
throw new Error("Failed to fetch image from redirect: ".concat(response.status));
|
|
96
97
|
case 12:
|
|
97
|
-
|
|
98
|
+
_t3 = Buffer;
|
|
99
|
+
_context.next = 13;
|
|
100
|
+
return response.arrayBuffer();
|
|
98
101
|
case 13:
|
|
99
|
-
|
|
102
|
+
buffer = _t3.from.call(_t3, _context.sent);
|
|
103
|
+
return _context.abrupt("return", formatBase64Image({
|
|
104
|
+
base64String: buffer.toString('base64'),
|
|
105
|
+
key: transformedBucketImagePath
|
|
106
|
+
}));
|
|
100
107
|
case 14:
|
|
101
|
-
throw new Error("
|
|
108
|
+
throw new Error("Bad request to image transformer: ".concat(transformerResponse.body));
|
|
102
109
|
case 15:
|
|
110
|
+
throw new Error('Requested transformed image is too big');
|
|
111
|
+
case 16:
|
|
112
|
+
throw new Error('The requested image does not exist');
|
|
113
|
+
case 17:
|
|
114
|
+
throw new Error("Image transformation failed: ".concat(transformerResponse.body));
|
|
115
|
+
case 18:
|
|
116
|
+
throw new Error("Unexpected response from image transformer: ".concat(statusCode, " - ").concat(transformerResponse.body));
|
|
117
|
+
case 19:
|
|
103
118
|
case "end":
|
|
104
119
|
return _context.stop();
|
|
105
120
|
}
|
|
106
|
-
}, _callee);
|
|
121
|
+
}, _callee, null, [[8, 10]]);
|
|
107
122
|
}));
|
|
108
123
|
return function fetchImageForPdfGeneratorService(_x) {
|
|
109
124
|
return _ref.apply(this, arguments);
|
|
@@ -114,7 +129,7 @@ export function requestImageTransformation(_x2, _x3) {
|
|
|
114
129
|
}
|
|
115
130
|
function _requestImageTransformation() {
|
|
116
131
|
_requestImageTransformation = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee2(path, searchParamsObject) {
|
|
117
|
-
var lambdaEvent, params, result, response, errorMessage,
|
|
132
|
+
var lambdaEvent, params, result, response, errorMessage, _t4;
|
|
118
133
|
return _regeneratorRuntime.wrap(function (_context2) {
|
|
119
134
|
while (1) switch (_context2.prev = _context2.next) {
|
|
120
135
|
case 0:
|
|
@@ -151,9 +166,9 @@ function _requestImageTransformation() {
|
|
|
151
166
|
return _context2.abrupt("return", response);
|
|
152
167
|
case 4:
|
|
153
168
|
_context2.prev = 4;
|
|
154
|
-
|
|
155
|
-
errorMessage = "Failed to invoke image transformer lambda: ".concat(
|
|
156
|
-
console.error(errorMessage,
|
|
169
|
+
_t4 = _context2["catch"](2);
|
|
170
|
+
errorMessage = "Failed to invoke image transformer lambda: ".concat(_t4.message);
|
|
171
|
+
console.error(errorMessage, _t4);
|
|
157
172
|
throw new Error(errorMessage);
|
|
158
173
|
case 5:
|
|
159
174
|
case "end":
|
|
@@ -168,7 +183,7 @@ export function fetchResourceFromS3(_x4) {
|
|
|
168
183
|
}
|
|
169
184
|
function _fetchResourceFromS() {
|
|
170
185
|
_fetchResourceFromS = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee3(_ref2) {
|
|
171
|
-
var bucketName, key, params, result,
|
|
186
|
+
var bucketName, key, params, result, _t5;
|
|
172
187
|
return _regeneratorRuntime.wrap(function (_context3) {
|
|
173
188
|
while (1) switch (_context3.prev = _context3.next) {
|
|
174
189
|
case 0:
|
|
@@ -201,12 +216,12 @@ function _fetchResourceFromS() {
|
|
|
201
216
|
});
|
|
202
217
|
case 4:
|
|
203
218
|
_context3.prev = 4;
|
|
204
|
-
|
|
205
|
-
if (!(
|
|
219
|
+
_t5 = _context3["catch"](2);
|
|
220
|
+
if (!(_t5.code !== 'NoSuchKey')) {
|
|
206
221
|
_context3.next = 5;
|
|
207
222
|
break;
|
|
208
223
|
}
|
|
209
|
-
console.error('Failed to fetch image:',
|
|
224
|
+
console.error('Failed to fetch image:', _t5);
|
|
210
225
|
throw new Error("Failed to fetch image: ".concat(bucketName, "/").concat(key));
|
|
211
226
|
case 5:
|
|
212
227
|
console.debug('Image not found in transformed bucket, invoking transformer');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["validateBase64Image","AWS","IMAGE_CACHE_REGION","lambda","Lambda","region","s3","S3","fetchImageForPdfGeneratorService","_ref","_asyncToGenerator","_regeneratorRuntime","mark","_callee","url","urlMatch","applicationId","_parseUrlString","path","queryString","searchParamsObject","transformedBucketImagePath","alreadyTransformedImage","fullDataUrl","transformerResponse","statusCode","_fullDataUrl","redirectLocation","newlyTransformedImage","_fullDataUrl2","_t","wrap","_context","prev","next","console","debug","Error","match","parseUrlString","concat","fetchResourceFromS3","bucketName","process","env","S3_BUCKET_IMAGE_TRANSFORMER_CACHE","key","sent","body","formatBase64Image","base64String","toString","abrupt","requestImageTransformation","headers","Location","stop","_x","apply","arguments","_x2","_x3","_requestImageTransformation","_callee2","lambdaEvent","params","result","response","errorMessage","_t2","_context2","queryStringParameters","requestContext","http","method","FunctionName","IMAGE_TRANSFORMER_ARN","InvocationType","Payload","JSON","stringify","invoke","promise","parse","message","error","_x4","_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","URL","searchParams","forEach","value","replace","pathname","substring"],"sources":["../../../src/helpers/fetch-image-for-pdf-generator-service/index.js"],"sourcesContent":["import { validateBase64Image } from '../image-validators'\nimport AWS from 'aws-sdk'\n\n// Image transformer and cache are always in us-east-1 (shared across all regions)\n// The image-optimisation-image-processing Lambda only exists in us-east-1\nconst IMAGE_CACHE_REGION = 'us-east-1'\n\nconst lambda = new AWS.Lambda({\n region: IMAGE_CACHE_REGION,\n})\n\nconst s3 = new AWS.S3({\n region: IMAGE_CACHE_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, queryString, searchParamsObject } = parseUrlString(url)\n\n const transformedBucketImagePath =\n path + (queryString ? `/${queryString}` : '')\n\n const alreadyTransformedImage = await fetchResourceFromS3({\n bucketName: process.env.S3_BUCKET_IMAGE_TRANSFORMER_CACHE,\n key: transformedBucketImagePath,\n })\n\n if (alreadyTransformedImage?.body) {\n const fullDataUrl = formatBase64Image({\n base64String: alreadyTransformedImage.body.toString('base64'),\n key: transformedBucketImagePath,\n })\n return fullDataUrl\n }\n\n const transformerResponse = await requestImageTransformation(\n `/${path}`,\n searchParamsObject\n )\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\n if (!redirectLocation) {\n throw new Error('Redirect response received but no location provided')\n }\n const newlyTransformedImage = await fetchResourceFromS3({\n bucketName: process.env.S3_BUCKET_IMAGE_TRANSFORMER_CACHE,\n key: transformedBucketImagePath,\n })\n console.debug('Image successfully fetched from S3 at:', redirectLocation)\n\n const fullDataUrl = formatBase64Image({\n base64String: newlyTransformedImage.body.toString('base64'),\n key: transformedBucketImagePath,\n })\n\n return fullDataUrl\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(path, searchParamsObject) {\n if (!path) {\n throw new Error('Image Path is required for image transformation')\n }\n\n console.debug(\n 'ImageTransformation: Invoking image transformer lambda for path:',\n { path, searchParamsObject }\n )\n\n const lambdaEvent = {\n queryStringParameters: searchParamsObject,\n requestContext: {\n http: {\n method: 'GET',\n 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 \"https://example.cloudfront.net/<applicationId>/<path>/filename.jpeg?width=100&height=100\"\n * @returns {Object} - Object with { path: string, queryString: string, searchParamsObject: Object }\n * @example\n * parseUrlString(\"https://example.cloudfront.net/abc123/folder/image.jpeg?width=100&height=100\")\n * // Returns: { path: \"abc123/folder/image.jpeg\", queryString: \"width=100,t=456\", searchParamsObject: { 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 // Extract the path after the domain\n const url = new URL(urlString)\n\n let searchParamsObject = {}\n url.searchParams.forEach((value, key) => {\n searchParamsObject[key] = value\n })\n\n let queryString = url.searchParams.toString()\n queryString = queryString ? queryString.replace(/&/g, ',') : ''\n\n return {\n path: url.pathname.substring(1), // Remove leading '/'\n queryString,\n searchParamsObject,\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"index.js","names":["validateBase64Image","AWS","IMAGE_CACHE_REGION","lambda","Lambda","region","s3","S3","fetchImageForPdfGeneratorService","_ref","_asyncToGenerator","_regeneratorRuntime","mark","_callee","url","_transformerResponse$","urlMatch","applicationId","_parseUrlString","path","queryString","searchParamsObject","transformedBucketImagePath","alreadyTransformedImage","fullDataUrl","transformerResponse","statusCode","redirectLocation","_fullDataUrl","response","buffer","_t","_t2","_t3","wrap","_context","prev","next","console","debug","Error","match","parseUrlString","concat","fetchResourceFromS3","bucketName","process","env","S3_BUCKET_IMAGE_TRANSFORMER_CACHE","key","sent","body","formatBase64Image","base64String","toString","abrupt","requestImageTransformation","headers","Location","fetch","message","ok","status","Buffer","arrayBuffer","from","call","stop","_x","apply","arguments","_x2","_x3","_requestImageTransformation","_callee2","lambdaEvent","params","result","errorMessage","_t4","_context2","queryStringParameters","requestContext","http","method","FunctionName","IMAGE_TRANSFORMER_ARN","InvocationType","Payload","JSON","stringify","invoke","promise","parse","error","_x4","_fetchResourceFromS","_callee3","_ref2","_t5","_context3","Bucket","Key","getObject","Body","contentType","ContentType","contentLength","ContentLength","lastModified","LastModified","etag","ETag","code","_ref3","imageType","toLowerCase","includes","base64Flag","isValid","urlString","URL","searchParams","forEach","value","replace","pathname","substring"],"sources":["../../../src/helpers/fetch-image-for-pdf-generator-service/index.js"],"sourcesContent":["import { validateBase64Image } from '../image-validators'\nimport AWS from 'aws-sdk'\n\n// Image transformer and cache are always in us-east-1 (shared across all regions)\n// The image-optimisation-image-processing Lambda only exists in us-east-1\nconst IMAGE_CACHE_REGION = 'us-east-1'\n\nconst lambda = new AWS.Lambda({\n region: IMAGE_CACHE_REGION,\n})\n\nconst s3 = new AWS.S3({\n region: IMAGE_CACHE_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, queryString, searchParamsObject } = parseUrlString(url)\n\n const transformedBucketImagePath =\n path + (queryString ? `/${queryString}` : '')\n\n const alreadyTransformedImage = await fetchResourceFromS3({\n bucketName: process.env.S3_BUCKET_IMAGE_TRANSFORMER_CACHE,\n key: transformedBucketImagePath,\n })\n\n if (alreadyTransformedImage?.body) {\n const fullDataUrl = formatBase64Image({\n base64String: alreadyTransformedImage.body.toString('base64'),\n key: transformedBucketImagePath,\n })\n return fullDataUrl\n }\n\n const transformerResponse = await requestImageTransformation(\n `/${path}`,\n searchParamsObject\n )\n\n const statusCode = transformerResponse.statusCode\n const redirectLocation = transformerResponse.headers?.Location\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 via redirect URL'\n )\n\n if (!redirectLocation) {\n throw new Error('Redirect response received but no location provided')\n }\n\n let response\n try {\n response = await fetch(redirectLocation)\n } catch (error) {\n throw new Error(\n `Failed to fetch image from redirect URL: ${error.message}`\n )\n }\n\n if (!response.ok) {\n throw new Error(\n `Failed to fetch image from redirect: ${response.status}`\n )\n }\n\n const buffer = Buffer.from(await response.arrayBuffer())\n\n return formatBase64Image({\n base64String: buffer.toString('base64'),\n key: transformedBucketImagePath,\n })\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(path, searchParamsObject) {\n if (!path) {\n throw new Error('Image Path is required for image transformation')\n }\n\n console.debug(\n 'ImageTransformation: Invoking image transformer lambda for path:',\n { path, searchParamsObject }\n )\n\n const lambdaEvent = {\n queryStringParameters: searchParamsObject,\n requestContext: {\n http: {\n method: 'GET',\n 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 \"https://example.cloudfront.net/<applicationId>/<path>/filename.jpeg?width=100&height=100\"\n * @returns {Object} - Object with { path: string, queryString: string, searchParamsObject: Object }\n * @example\n * parseUrlString(\"https://example.cloudfront.net/abc123/folder/image.jpeg?width=100&height=100\")\n * // Returns: { path: \"abc123/folder/image.jpeg\", queryString: \"width=100,t=456\", searchParamsObject: { 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 // Extract the path after the domain\n const url = new URL(urlString)\n\n let searchParamsObject = {}\n url.searchParams.forEach((value, key) => {\n searchParamsObject[key] = value\n })\n\n let queryString = url.searchParams.toString()\n queryString = queryString ? queryString.replace(/&/g, ',') : ''\n\n return {\n path: url.pathname.substring(1), // Remove leading '/'\n queryString,\n searchParamsObject,\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
package/package.json
CHANGED
package/debug-storybook.log
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
[17:05:07.504] [ERROR] Error: Unknown codemod storiesof-to-csf. Run --list for options.
|