@lighthouse/common 5.0.0-canary-7 → 5.0.0-canary-8
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
|
key: keyWithTransformations
|
|
34
34
|
});
|
|
35
35
|
if (alreadyTransformedImage && alreadyTransformedImage.body) {
|
|
36
|
-
const fullDataUrl = formatBase64Image({
|
|
36
|
+
const fullDataUrl = await formatBase64Image({
|
|
37
37
|
base64String: alreadyTransformedImage.body.toString('base64'),
|
|
38
38
|
key: keyWithTransformations
|
|
39
39
|
});
|
|
@@ -44,8 +44,14 @@ const fetchImageForPdfGeneratorService = async function (url) {
|
|
|
44
44
|
const statusCode = transformerResponse.statusCode;
|
|
45
45
|
switch (statusCode) {
|
|
46
46
|
case 200:
|
|
47
|
-
|
|
48
|
-
|
|
47
|
+
{
|
|
48
|
+
console.log('Image transformation successful');
|
|
49
|
+
const fullDataUrl = await formatBase64Image({
|
|
50
|
+
base64String: transformerResponse.body.toString('base64'),
|
|
51
|
+
key: keyWithTransformations
|
|
52
|
+
});
|
|
53
|
+
return fullDataUrl;
|
|
54
|
+
}
|
|
49
55
|
case 302:
|
|
50
56
|
{
|
|
51
57
|
console.log('Image transformation successful but image is too big for lambda delivery, fetching directly from S3');
|
|
@@ -56,7 +62,11 @@ const fetchImageForPdfGeneratorService = async function (url) {
|
|
|
56
62
|
key: keyWithTransformations
|
|
57
63
|
});
|
|
58
64
|
console.log('Image successfully fetched from S3 at:', redirectLocation);
|
|
59
|
-
|
|
65
|
+
const fullDataUrl = await formatBase64Image({
|
|
66
|
+
base64String: newlyTransformedImage.body.toString('base64'),
|
|
67
|
+
key: keyWithTransformations
|
|
68
|
+
});
|
|
69
|
+
return fullDataUrl;
|
|
60
70
|
}
|
|
61
71
|
throw new Error('Redirect response received but no location provided');
|
|
62
72
|
}
|
|
@@ -133,7 +143,7 @@ async function fetchResourceFromS3({
|
|
|
133
143
|
console.info('Image not found in transformed bucket, invoking transformer');
|
|
134
144
|
}
|
|
135
145
|
}
|
|
136
|
-
function formatBase64Image({
|
|
146
|
+
async function formatBase64Image({
|
|
137
147
|
base64String,
|
|
138
148
|
key
|
|
139
149
|
}) {
|
|
@@ -11,7 +11,7 @@ var s3 = new AWS.S3({
|
|
|
11
11
|
});
|
|
12
12
|
export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
|
|
13
13
|
var _ref = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee(url) {
|
|
14
|
-
var urlMatch, applicationId, keyWithTransformations, alreadyTransformedImage, fullDataUrl, keyWithoutTransformations, transformerResponse, statusCode, _transformerResponse$, redirectLocation, newlyTransformedImage;
|
|
14
|
+
var urlMatch, applicationId, keyWithTransformations, alreadyTransformedImage, fullDataUrl, keyWithoutTransformations, transformerResponse, statusCode, _fullDataUrl, _transformerResponse$, redirectLocation, newlyTransformedImage, _fullDataUrl2;
|
|
15
15
|
return _regeneratorRuntime.wrap(function _callee$(_context) {
|
|
16
16
|
while (1) {
|
|
17
17
|
switch (_context.prev = _context.next) {
|
|
@@ -40,56 +40,73 @@ export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
|
|
|
40
40
|
case 10:
|
|
41
41
|
alreadyTransformedImage = _context.sent;
|
|
42
42
|
if (!(alreadyTransformedImage && alreadyTransformedImage.body)) {
|
|
43
|
-
_context.next =
|
|
43
|
+
_context.next = 16;
|
|
44
44
|
break;
|
|
45
45
|
}
|
|
46
|
-
|
|
46
|
+
_context.next = 14;
|
|
47
|
+
return formatBase64Image({
|
|
47
48
|
base64String: alreadyTransformedImage.body.toString('base64'),
|
|
48
49
|
key: keyWithTransformations
|
|
49
50
|
});
|
|
50
|
-
return _context.abrupt("return", fullDataUrl);
|
|
51
51
|
case 14:
|
|
52
|
+
fullDataUrl = _context.sent;
|
|
53
|
+
return _context.abrupt("return", fullDataUrl);
|
|
54
|
+
case 16:
|
|
52
55
|
keyWithoutTransformations = "/".concat(keyWithTransformations.split('?')[0]);
|
|
53
|
-
_context.next =
|
|
56
|
+
_context.next = 19;
|
|
54
57
|
return requestImageTransformation(keyWithoutTransformations);
|
|
55
|
-
case
|
|
58
|
+
case 19:
|
|
56
59
|
transformerResponse = _context.sent;
|
|
57
60
|
statusCode = transformerResponse.statusCode;
|
|
58
61
|
_context.t0 = statusCode;
|
|
59
|
-
_context.next = _context.t0 === 200 ?
|
|
62
|
+
_context.next = _context.t0 === 200 ? 24 : _context.t0 === 302 ? 29 : _context.t0 === 400 ? 41 : _context.t0 === 403 ? 42 : _context.t0 === 404 ? 43 : _context.t0 === 500 ? 44 : 45;
|
|
60
63
|
break;
|
|
61
|
-
case 22:
|
|
62
|
-
console.log('Image transformation successful');
|
|
63
|
-
return _context.abrupt("return", transformerResponse.body);
|
|
64
64
|
case 24:
|
|
65
|
+
console.log('Image transformation successful');
|
|
66
|
+
_context.next = 27;
|
|
67
|
+
return formatBase64Image({
|
|
68
|
+
base64String: transformerResponse.body.toString('base64'),
|
|
69
|
+
key: keyWithTransformations
|
|
70
|
+
});
|
|
71
|
+
case 27:
|
|
72
|
+
_fullDataUrl = _context.sent;
|
|
73
|
+
return _context.abrupt("return", _fullDataUrl);
|
|
74
|
+
case 29:
|
|
65
75
|
console.log('Image transformation successful but image is too big for lambda delivery, fetching directly from S3');
|
|
66
76
|
redirectLocation = (_transformerResponse$ = transformerResponse.headers) === null || _transformerResponse$ === void 0 ? void 0 : _transformerResponse$.Location;
|
|
67
77
|
if (!redirectLocation) {
|
|
68
|
-
_context.next =
|
|
78
|
+
_context.next = 40;
|
|
69
79
|
break;
|
|
70
80
|
}
|
|
71
|
-
_context.next =
|
|
81
|
+
_context.next = 34;
|
|
72
82
|
return fetchResourceFromS3({
|
|
73
83
|
bucketName: "".concat(process.env.S3_BUCKET_UPLOADS, "-transformed"),
|
|
74
84
|
key: keyWithTransformations
|
|
75
85
|
});
|
|
76
|
-
case
|
|
86
|
+
case 34:
|
|
77
87
|
newlyTransformedImage = _context.sent;
|
|
78
88
|
console.log('Image successfully fetched from S3 at:', redirectLocation);
|
|
79
|
-
|
|
80
|
-
|
|
89
|
+
_context.next = 38;
|
|
90
|
+
return formatBase64Image({
|
|
91
|
+
base64String: newlyTransformedImage.body.toString('base64'),
|
|
92
|
+
key: keyWithTransformations
|
|
93
|
+
});
|
|
94
|
+
case 38:
|
|
95
|
+
_fullDataUrl2 = _context.sent;
|
|
96
|
+
return _context.abrupt("return", _fullDataUrl2);
|
|
97
|
+
case 40:
|
|
81
98
|
throw new Error('Redirect response received but no location provided');
|
|
82
|
-
case
|
|
99
|
+
case 41:
|
|
83
100
|
throw new Error("Bad request to image transformer: ".concat(transformerResponse.body));
|
|
84
|
-
case
|
|
101
|
+
case 42:
|
|
85
102
|
throw new Error('Requested transformed image is too big');
|
|
86
|
-
case
|
|
103
|
+
case 43:
|
|
87
104
|
throw new Error('The requested image does not exist');
|
|
88
|
-
case
|
|
105
|
+
case 44:
|
|
89
106
|
throw new Error("Image transformation failed: ".concat(transformerResponse.body));
|
|
90
|
-
case
|
|
107
|
+
case 45:
|
|
91
108
|
throw new Error("Unexpected response from image transformer: ".concat(statusCode, " - ").concat(transformerResponse.body));
|
|
92
|
-
case
|
|
109
|
+
case 46:
|
|
93
110
|
case "end":
|
|
94
111
|
return _context.stop();
|
|
95
112
|
}
|
|
@@ -209,18 +226,35 @@ function _fetchResourceFromS() {
|
|
|
209
226
|
}));
|
|
210
227
|
return _fetchResourceFromS.apply(this, arguments);
|
|
211
228
|
}
|
|
212
|
-
export function formatBase64Image(
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
229
|
+
export function formatBase64Image(_x4) {
|
|
230
|
+
return _formatBase64Image.apply(this, arguments);
|
|
231
|
+
}
|
|
232
|
+
function _formatBase64Image() {
|
|
233
|
+
_formatBase64Image = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee4(_ref3) {
|
|
234
|
+
var base64String, key, imageType, base64Flag, fullDataUrl, isValid;
|
|
235
|
+
return _regeneratorRuntime.wrap(function _callee4$(_context4) {
|
|
236
|
+
while (1) {
|
|
237
|
+
switch (_context4.prev = _context4.next) {
|
|
238
|
+
case 0:
|
|
239
|
+
base64String = _ref3.base64String, key = _ref3.key;
|
|
240
|
+
imageType = key.toLowerCase().includes('.png') ? 'png' : 'jpeg';
|
|
241
|
+
base64Flag = "data:image/".concat(imageType, ";base64,");
|
|
242
|
+
fullDataUrl = "".concat(base64Flag).concat(base64String); // Validate the formatted data URL
|
|
243
|
+
isValid = validateBase64Image(fullDataUrl);
|
|
244
|
+
if (isValid) {
|
|
245
|
+
_context4.next = 7;
|
|
246
|
+
break;
|
|
247
|
+
}
|
|
248
|
+
return _context4.abrupt("return", Promise.reject(new Error('InvalidImageError')));
|
|
249
|
+
case 7:
|
|
250
|
+
return _context4.abrupt("return", fullDataUrl);
|
|
251
|
+
case 8:
|
|
252
|
+
case "end":
|
|
253
|
+
return _context4.stop();
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
}, _callee4);
|
|
257
|
+
}));
|
|
258
|
+
return _formatBase64Image.apply(this, arguments);
|
|
225
259
|
}
|
|
226
260
|
//# sourceMappingURL=index.js.map
|
|
@@ -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","keyWithTransformations","alreadyTransformedImage","fullDataUrl","keyWithoutTransformations","transformerResponse","statusCode","_transformerResponse$","redirectLocation","newlyTransformedImage","wrap","_callee$","_context","prev","next","console","info","Error","match","substring","indexOf","fetchResourceFromS3","bucketName","concat","S3_BUCKET_UPLOADS","key","sent","body","formatBase64Image","base64String","toString","abrupt","split","requestImageTransformation","t0","log","headers","Location","stop","_x","apply","arguments","_x2","_requestImageTransformation","_callee2","lambdaEvent","params","result","response","errorMessage","_callee2$","_context2","requestContext","http","method","path","FunctionName","IMAGE_TRANSFORMER_ARN","InvocationType","Payload","JSON","stringify","invoke","promise","parse","message","error","_x3","_fetchResourceFromS","_callee3","_ref2","_callee3$","_context3","Bucket","Key","getObject","Body","contentType","ContentType","contentLength","ContentLength","lastModified","LastModified","etag","ETag","code","_ref3","imageType","toLowerCase","includes","base64Flag","isValid","Promise","reject"],"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.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 const fullDataUrl = formatBase64Image({\n base64String: alreadyTransformedImage.body.toString('base64'),\n key: keyWithTransformations,\n })\n return fullDataUrl\n }\n\n const keyWithoutTransformations = `/${keyWithTransformations.split('?')[0]}`\n\n const transformerResponse = await requestImageTransformation(\n keyWithoutTransformations\n )\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('Failed to fetch image:', error)\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\nexport function formatBase64Image({ base64String, key }) {\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 return Promise.reject(new Error('InvalidImageError'))\n }\n\n return fullDataUrl\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","keyWithTransformations","alreadyTransformedImage","fullDataUrl","keyWithoutTransformations","transformerResponse","statusCode","_fullDataUrl","_transformerResponse$","redirectLocation","newlyTransformedImage","_fullDataUrl2","wrap","_callee$","_context","prev","next","console","info","Error","match","substring","indexOf","fetchResourceFromS3","bucketName","concat","S3_BUCKET_UPLOADS","key","sent","body","formatBase64Image","base64String","toString","abrupt","split","requestImageTransformation","t0","log","headers","Location","stop","_x","apply","arguments","_x2","_requestImageTransformation","_callee2","lambdaEvent","params","result","response","errorMessage","_callee2$","_context2","requestContext","http","method","path","FunctionName","IMAGE_TRANSFORMER_ARN","InvocationType","Payload","JSON","stringify","invoke","promise","parse","message","error","_x3","_fetchResourceFromS","_callee3","_ref2","_callee3$","_context3","Bucket","Key","getObject","Body","contentType","ContentType","contentLength","ContentLength","lastModified","LastModified","etag","ETag","code","_x4","_formatBase64Image","_callee4","_ref3","imageType","base64Flag","isValid","_callee4$","_context4","toLowerCase","includes","Promise","reject"],"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.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 const fullDataUrl = await formatBase64Image({\n base64String: alreadyTransformedImage.body.toString('base64'),\n key: keyWithTransformations,\n })\n return fullDataUrl\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\n const fullDataUrl = await formatBase64Image({\n base64String: transformerResponse.body.toString('base64'),\n key: keyWithTransformations,\n })\n\n return fullDataUrl\n }\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 const fullDataUrl = await formatBase64Image({\n base64String: newlyTransformedImage.body.toString('base64'),\n key: keyWithTransformations,\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(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('Failed to fetch image:', error)\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\nexport async function formatBase64Image({ base64String, key }) {\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 return Promise.reject(new Error('InvalidImageError'))\n }\n\n return fullDataUrl\n}\n"],"mappings":"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","ignoreList":[]}
|