@lighthouse/common 5.0.0-canary-8 → 5.0.0-canary-10

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 = await formatBase64Image({
36
+ const fullDataUrl = formatBase64Image({
37
37
  base64String: alreadyTransformedImage.body.toString('base64'),
38
38
  key: keyWithTransformations
39
39
  });
@@ -46,7 +46,7 @@ const fetchImageForPdfGeneratorService = async function (url) {
46
46
  case 200:
47
47
  {
48
48
  console.log('Image transformation successful');
49
- const fullDataUrl = await formatBase64Image({
49
+ const fullDataUrl = formatBase64Image({
50
50
  base64String: transformerResponse.body.toString('base64'),
51
51
  key: keyWithTransformations
52
52
  });
@@ -62,7 +62,7 @@ const fetchImageForPdfGeneratorService = async function (url) {
62
62
  key: keyWithTransformations
63
63
  });
64
64
  console.log('Image successfully fetched from S3 at:', redirectLocation);
65
- const fullDataUrl = await formatBase64Image({
65
+ const fullDataUrl = formatBase64Image({
66
66
  base64String: newlyTransformedImage.body.toString('base64'),
67
67
  key: keyWithTransformations
68
68
  });
@@ -143,10 +143,13 @@ async function fetchResourceFromS3({
143
143
  console.info('Image not found in transformed bucket, invoking transformer');
144
144
  }
145
145
  }
146
- async function formatBase64Image({
146
+ function formatBase64Image({
147
147
  base64String,
148
148
  key
149
149
  }) {
150
+ if (!key) {
151
+ throw new Error('Key is required for image formatting');
152
+ }
150
153
  const imageType = key.toLowerCase().includes('.png') ? 'png' : 'jpeg';
151
154
  const base64Flag = `data:image/${imageType};base64,`;
152
155
  const fullDataUrl = `${base64Flag}${base64String}`;
@@ -154,7 +157,7 @@ async function formatBase64Image({
154
157
  // Validate the formatted data URL
155
158
  const isValid = (0, _imageValidators.validateBase64Image)(fullDataUrl);
156
159
  if (!isValid) {
157
- return Promise.reject(new Error('InvalidImageError'));
160
+ throw new Error('InvalidImageError');
158
161
  }
159
162
  return fullDataUrl;
160
163
  }
@@ -16,7 +16,8 @@ function validateBase64Image(base64String) {
16
16
  // Fiddle: https://jsfiddle.net/Lnyxuchw/
17
17
  function validateJpegImage(base64string) {
18
18
  const src = base64string;
19
- const imageData = Uint8Array.from(atob(src.replace('data:image/jpeg;base64,', '')), c => c.charCodeAt(0));
19
+ const base64Data = src.replace('data:image/jpeg;base64,', '');
20
+ const imageData = new Uint8Array(Buffer.from(base64Data, 'base64'));
20
21
  const imageCorrupted = imageData[imageData.length - 1] === 217 && imageData[imageData.length - 2] === 255;
21
22
  return imageCorrupted;
22
23
  }
@@ -25,7 +26,8 @@ function validateJpegImage(base64string) {
25
26
  // Fiddle: https://jsfiddle.net/Lnyxuchw/
26
27
  function validatePngImage(base64string) {
27
28
  const src = base64string;
28
- const imageData = Uint8Array.from(atob(src.replace('data:image/png;base64,', '')), c => c.charCodeAt(0));
29
+ const base64Data = src.replace('data:image/png;base64,', '');
30
+ const imageData = new Uint8Array(Buffer.from(base64Data, 'base64'));
29
31
  const sequence = [0, 0, 0, 0, 73, 69, 78, 68, 174, 66, 96, 130]; // in hex:
30
32
 
31
33
  //check last 12 elements of array so they contains needed values
@@ -40,73 +40,64 @@ export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
40
40
  case 10:
41
41
  alreadyTransformedImage = _context.sent;
42
42
  if (!(alreadyTransformedImage && alreadyTransformedImage.body)) {
43
- _context.next = 16;
43
+ _context.next = 14;
44
44
  break;
45
45
  }
46
- _context.next = 14;
47
- return formatBase64Image({
46
+ fullDataUrl = formatBase64Image({
48
47
  base64String: alreadyTransformedImage.body.toString('base64'),
49
48
  key: keyWithTransformations
50
49
  });
51
- case 14:
52
- fullDataUrl = _context.sent;
53
50
  return _context.abrupt("return", fullDataUrl);
54
- case 16:
51
+ case 14:
55
52
  keyWithoutTransformations = "/".concat(keyWithTransformations.split('?')[0]);
56
- _context.next = 19;
53
+ _context.next = 17;
57
54
  return requestImageTransformation(keyWithoutTransformations);
58
- case 19:
55
+ case 17:
59
56
  transformerResponse = _context.sent;
60
57
  statusCode = transformerResponse.statusCode;
61
58
  _context.t0 = statusCode;
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;
59
+ _context.next = _context.t0 === 200 ? 22 : _context.t0 === 302 ? 25 : _context.t0 === 400 ? 35 : _context.t0 === 403 ? 36 : _context.t0 === 404 ? 37 : _context.t0 === 500 ? 38 : 39;
63
60
  break;
64
- case 24:
61
+ case 22:
65
62
  console.log('Image transformation successful');
66
- _context.next = 27;
67
- return formatBase64Image({
63
+ _fullDataUrl = formatBase64Image({
68
64
  base64String: transformerResponse.body.toString('base64'),
69
65
  key: keyWithTransformations
70
66
  });
71
- case 27:
72
- _fullDataUrl = _context.sent;
73
67
  return _context.abrupt("return", _fullDataUrl);
74
- case 29:
68
+ case 25:
75
69
  console.log('Image transformation successful but image is too big for lambda delivery, fetching directly from S3');
76
70
  redirectLocation = (_transformerResponse$ = transformerResponse.headers) === null || _transformerResponse$ === void 0 ? void 0 : _transformerResponse$.Location;
77
71
  if (!redirectLocation) {
78
- _context.next = 40;
72
+ _context.next = 34;
79
73
  break;
80
74
  }
81
- _context.next = 34;
75
+ _context.next = 30;
82
76
  return fetchResourceFromS3({
83
77
  bucketName: "".concat(process.env.S3_BUCKET_UPLOADS, "-transformed"),
84
78
  key: keyWithTransformations
85
79
  });
86
- case 34:
80
+ case 30:
87
81
  newlyTransformedImage = _context.sent;
88
82
  console.log('Image successfully fetched from S3 at:', redirectLocation);
89
- _context.next = 38;
90
- return formatBase64Image({
83
+ _fullDataUrl2 = formatBase64Image({
91
84
  base64String: newlyTransformedImage.body.toString('base64'),
92
85
  key: keyWithTransformations
93
86
  });
94
- case 38:
95
- _fullDataUrl2 = _context.sent;
96
87
  return _context.abrupt("return", _fullDataUrl2);
97
- case 40:
88
+ case 34:
98
89
  throw new Error('Redirect response received but no location provided');
99
- case 41:
90
+ case 35:
100
91
  throw new Error("Bad request to image transformer: ".concat(transformerResponse.body));
101
- case 42:
92
+ case 36:
102
93
  throw new Error('Requested transformed image is too big');
103
- case 43:
94
+ case 37:
104
95
  throw new Error('The requested image does not exist');
105
- case 44:
96
+ case 38:
106
97
  throw new Error("Image transformation failed: ".concat(transformerResponse.body));
107
- case 45:
98
+ case 39:
108
99
  throw new Error("Unexpected response from image transformer: ".concat(statusCode, " - ").concat(transformerResponse.body));
109
- case 46:
100
+ case 40:
110
101
  case "end":
111
102
  return _context.stop();
112
103
  }
@@ -226,35 +217,21 @@ function _fetchResourceFromS() {
226
217
  }));
227
218
  return _fetchResourceFromS.apply(this, arguments);
228
219
  }
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);
220
+ export function formatBase64Image(_ref3) {
221
+ var base64String = _ref3.base64String,
222
+ key = _ref3.key;
223
+ if (!key) {
224
+ throw new Error('Key is required for image formatting');
225
+ }
226
+ var imageType = key.toLowerCase().includes('.png') ? 'png' : 'jpeg';
227
+ var base64Flag = "data:image/".concat(imageType, ";base64,");
228
+ var fullDataUrl = "".concat(base64Flag).concat(base64String);
229
+
230
+ // Validate the formatted data URL
231
+ var isValid = validateBase64Image(fullDataUrl);
232
+ if (!isValid) {
233
+ throw new Error('InvalidImageError');
234
+ }
235
+ return fullDataUrl;
259
236
  }
260
237
  //# 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","_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":[]}
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","_ref3","imageType","toLowerCase","includes","base64Flag","isValid"],"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\n const fullDataUrl = 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 = 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 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"],"mappings":"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","ignoreList":[]}
@@ -10,9 +10,8 @@ export function validateBase64Image(base64String) {
10
10
  // Fiddle: https://jsfiddle.net/Lnyxuchw/
11
11
  function validateJpegImage(base64string) {
12
12
  var src = base64string;
13
- var imageData = Uint8Array.from(atob(src.replace('data:image/jpeg;base64,', '')), function (c) {
14
- return c.charCodeAt(0);
15
- });
13
+ var base64Data = src.replace('data:image/jpeg;base64,', '');
14
+ var imageData = new Uint8Array(Buffer.from(base64Data, 'base64'));
16
15
  var imageCorrupted = imageData[imageData.length - 1] === 217 && imageData[imageData.length - 2] === 255;
17
16
  return imageCorrupted;
18
17
  }
@@ -21,9 +20,8 @@ function validateJpegImage(base64string) {
21
20
  // Fiddle: https://jsfiddle.net/Lnyxuchw/
22
21
  function validatePngImage(base64string) {
23
22
  var src = base64string;
24
- var imageData = Uint8Array.from(atob(src.replace('data:image/png;base64,', '')), function (c) {
25
- return c.charCodeAt(0);
26
- });
23
+ var base64Data = src.replace('data:image/png;base64,', '');
24
+ var imageData = new Uint8Array(Buffer.from(base64Data, 'base64'));
27
25
  var sequence = [0, 0, 0, 0, 73, 69, 78, 68, 174, 66, 96, 130]; // in hex:
28
26
 
29
27
  //check last 12 elements of array so they contains needed values
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["validateBase64Image","base64String","isJpeg","startsWith","validateJpegImage","isPng","validatePngImage","base64string","src","imageData","Uint8Array","from","atob","replace","c","charCodeAt","imageCorrupted","length","sequence","i"],"sources":["../../../src/helpers/image-validators/index.js"],"sourcesContent":["export 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/\nfunction 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/\nfunction 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] // in hex:\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":"AAAA,OAAO,SAASA,mBAAmBA,CAACC,YAAY,EAAE;EAChD,IAAMC,MAAM,GAAGD,YAAY,CAACE,UAAU,CAAC,yBAAyB,CAAC;EAEjE,IAAID,MAAM,EAAE,OAAOE,iBAAiB,CAACH,YAAY,CAAC;EAElD,IAAMI,KAAK,GAAGJ,YAAY,CAACE,UAAU,CAAC,wBAAwB,CAAC;EAE/D,IAAIE,KAAK,EAAE,OAAOC,gBAAgB,CAACL,YAAY,CAAC;EAEhD,OAAO,KAAK;AACd;;AAEA;AACA;AACA,SAASG,iBAAiBA,CAACG,YAAY,EAAE;EACvC,IAAMC,GAAG,GAAGD,YAAY;EACxB,IAAME,SAAS,GAAGC,UAAU,CAACC,IAAI,CAC/BC,IAAI,CAACJ,GAAG,CAACK,OAAO,CAAC,yBAAyB,EAAE,EAAE,CAAC,CAAC,EAChD,UAAAC,CAAC;IAAA,OAAIA,CAAC,CAACC,UAAU,CAAC,CAAC,CAAC;EAAA,CACtB,CAAC;EACD,IAAMC,cAAc,GAClBP,SAAS,CAACA,SAAS,CAACQ,MAAM,GAAG,CAAC,CAAC,KAAK,GAAG,IACvCR,SAAS,CAACA,SAAS,CAACQ,MAAM,GAAG,CAAC,CAAC,KAAK,GAAG;EAEzC,OAAOD,cAAc;AACvB;;AAEA;AACA;AACA,SAASV,gBAAgBA,CAACC,YAAY,EAAE;EACtC,IAAMC,GAAG,GAAGD,YAAY;EACxB,IAAME,SAAS,GAAGC,UAAU,CAACC,IAAI,CAC/BC,IAAI,CAACJ,GAAG,CAACK,OAAO,CAAC,wBAAwB,EAAE,EAAE,CAAC,CAAC,EAC/C,UAAAC,CAAC;IAAA,OAAIA,CAAC,CAACC,UAAU,CAAC,CAAC,CAAC;EAAA,CACtB,CAAC;EACD,IAAMG,QAAQ,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,EAAC;;EAEhE;EACA,KAAK,IAAIC,CAAC,GAAG,EAAE,EAAEA,CAAC,GAAG,CAAC,EAAEA,CAAC,EAAE,EAAE;IAC3B,IAAIV,SAAS,CAACA,SAAS,CAACQ,MAAM,GAAGE,CAAC,CAAC,KAAKD,QAAQ,CAAC,EAAE,GAAGC,CAAC,CAAC,EAAE;MACxD,OAAO,KAAK;IACd;EACF;EAEA,OAAO,IAAI;AACb","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["validateBase64Image","base64String","isJpeg","startsWith","validateJpegImage","isPng","validatePngImage","base64string","src","base64Data","replace","imageData","Uint8Array","Buffer","from","imageCorrupted","length","sequence","i"],"sources":["../../../src/helpers/image-validators/index.js"],"sourcesContent":["export 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/\nfunction validateJpegImage(base64string) {\n const src = base64string\n const base64Data = src.replace('data:image/jpeg;base64,', '')\n const imageData = new Uint8Array(Buffer.from(base64Data, 'base64'))\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/\nfunction validatePngImage(base64string) {\n const src = base64string\n const base64Data = src.replace('data:image/png;base64,', '')\n const imageData = new Uint8Array(Buffer.from(base64Data, 'base64'))\n const sequence = [0, 0, 0, 0, 73, 69, 78, 68, 174, 66, 96, 130] // in hex:\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":"AAAA,OAAO,SAASA,mBAAmBA,CAACC,YAAY,EAAE;EAChD,IAAMC,MAAM,GAAGD,YAAY,CAACE,UAAU,CAAC,yBAAyB,CAAC;EAEjE,IAAID,MAAM,EAAE,OAAOE,iBAAiB,CAACH,YAAY,CAAC;EAElD,IAAMI,KAAK,GAAGJ,YAAY,CAACE,UAAU,CAAC,wBAAwB,CAAC;EAE/D,IAAIE,KAAK,EAAE,OAAOC,gBAAgB,CAACL,YAAY,CAAC;EAEhD,OAAO,KAAK;AACd;;AAEA;AACA;AACA,SAASG,iBAAiBA,CAACG,YAAY,EAAE;EACvC,IAAMC,GAAG,GAAGD,YAAY;EACxB,IAAME,UAAU,GAAGD,GAAG,CAACE,OAAO,CAAC,yBAAyB,EAAE,EAAE,CAAC;EAC7D,IAAMC,SAAS,GAAG,IAAIC,UAAU,CAACC,MAAM,CAACC,IAAI,CAACL,UAAU,EAAE,QAAQ,CAAC,CAAC;EACnE,IAAMM,cAAc,GAClBJ,SAAS,CAACA,SAAS,CAACK,MAAM,GAAG,CAAC,CAAC,KAAK,GAAG,IACvCL,SAAS,CAACA,SAAS,CAACK,MAAM,GAAG,CAAC,CAAC,KAAK,GAAG;EAEzC,OAAOD,cAAc;AACvB;;AAEA;AACA;AACA,SAAST,gBAAgBA,CAACC,YAAY,EAAE;EACtC,IAAMC,GAAG,GAAGD,YAAY;EACxB,IAAME,UAAU,GAAGD,GAAG,CAACE,OAAO,CAAC,wBAAwB,EAAE,EAAE,CAAC;EAC5D,IAAMC,SAAS,GAAG,IAAIC,UAAU,CAACC,MAAM,CAACC,IAAI,CAACL,UAAU,EAAE,QAAQ,CAAC,CAAC;EACnE,IAAMQ,QAAQ,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,EAAC;;EAEhE;EACA,KAAK,IAAIC,CAAC,GAAG,EAAE,EAAEA,CAAC,GAAG,CAAC,EAAEA,CAAC,EAAE,EAAE;IAC3B,IAAIP,SAAS,CAACA,SAAS,CAACK,MAAM,GAAGE,CAAC,CAAC,KAAKD,QAAQ,CAAC,EAAE,GAAGC,CAAC,CAAC,EAAE;MACxD,OAAO,KAAK;IACd;EACF;EAEA,OAAO,IAAI;AACb","ignoreList":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lighthouse/common",
3
- "version": "5.0.0-canary-8",
3
+ "version": "5.0.0-canary-10",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "module": "lib/index.js",