@lighthouse/common 5.0.0-canary-12 → 5.0.0-canary-14

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.
Files changed (29) hide show
  1. package/dist/helpers/build-fetch-url/index.js +2 -2
  2. package/dist/helpers/fetch-image/index.js +1 -1
  3. package/dist/helpers/fetch-image-for-pdf-generator-service/index.js +11 -11
  4. package/dist/helpers/fetch-image-for-web/index.js +3 -5
  5. package/dist/helpers/get-audit-entry-details/index.js +2 -0
  6. package/dist/helpers/get-issue-details/index.js +2 -0
  7. package/dist/helpers/get-task-entry-details/index.js +3 -1
  8. package/dist/pdf/helpers/fields/index.js +2 -2
  9. package/lib/helpers/build-fetch-url/index.js +2 -2
  10. package/lib/helpers/build-fetch-url/index.js.map +1 -1
  11. package/lib/helpers/fetch-image/index.js +1 -1
  12. package/lib/helpers/fetch-image/index.js.map +1 -1
  13. package/lib/helpers/fetch-image-for-pdf-generator-service/index.js +11 -11
  14. package/lib/helpers/fetch-image-for-pdf-generator-service/index.js.map +1 -1
  15. package/lib/helpers/fetch-image-for-web/index.js +4 -7
  16. package/lib/helpers/fetch-image-for-web/index.js.map +1 -1
  17. package/lib/helpers/get-audit-entry-details/index.js +2 -0
  18. package/lib/helpers/get-audit-entry-details/index.js.map +1 -1
  19. package/lib/helpers/get-issue-details/index.js +2 -0
  20. package/lib/helpers/get-issue-details/index.js.map +1 -1
  21. package/lib/helpers/get-task-entry-details/index.js +3 -1
  22. package/lib/helpers/get-task-entry-details/index.js.map +1 -1
  23. package/lib/pdf/helpers/fields/index.js +14 -14
  24. package/lib/pdf/helpers/fields/index.js.map +1 -1
  25. package/lib/scheduling/generators/serviceIntervalsGenerator.js.map +1 -1
  26. package/lib/scheduling/helpers/mergeIntervals.js.map +1 -1
  27. package/lib/service-hours/schema.js.map +1 -1
  28. package/package.json +2 -2
  29. package/package-lock.json +0 -25484
@@ -12,9 +12,9 @@ function buildFetchUrl(url, options) {
12
12
  fit,
13
13
  height,
14
14
  width,
15
- quality
15
+ quality,
16
+ shouldUseCloudfront
16
17
  } = options;
17
- const shouldUseCloudfront = cloudfrontBaseUrl && cloudfrontBaseUrl.includes('.cloudfront.net');
18
18
  if (shouldUseCloudfront) {
19
19
  const transformations = [];
20
20
  if (width) transformations.push(`width=${width.toString()}`);
@@ -36,7 +36,7 @@ const defaultOptions = {
36
36
  cache: 'no-cache'
37
37
  };
38
38
  function fetchImage(url, options = {}) {
39
- const shouldUseCloudfront = url && url.includes('.cloudfront.net');
39
+ const shouldUseCloudfront = options.shouldUseCloudfront;
40
40
  if (shouldUseCloudfront) {
41
41
  const isWebContext = typeof window === 'object';
42
42
  return isWebContext ?
@@ -18,7 +18,7 @@ const s3 = new _awsSdk.default.S3({
18
18
  region: REGION
19
19
  });
20
20
  const fetchImageForPdfGeneratorService = async function (url) {
21
- console.info('Fetching image via CloudFront For Serverless Pdf Generator Service');
21
+ console.debug('Fetching image via CloudFront For Serverless Pdf Generator Service');
22
22
  if (!url) {
23
23
  throw new Error('URL is required to fetch image for PDF generator service');
24
24
  }
@@ -29,10 +29,10 @@ const fetchImageForPdfGeneratorService = async function (url) {
29
29
  }
30
30
  const keyWithTransformations = url.substring(url.indexOf(applicationId));
31
31
  const alreadyTransformedImage = await fetchResourceFromS3({
32
- bucketName: `${process.env.S3_BUCKET_UPLOADS}-transformed`,
32
+ bucketName: `${process.env.S3_BUCKET_IMAGE_TRANSFORMER_CACHE}`,
33
33
  key: keyWithTransformations
34
34
  });
35
- if (alreadyTransformedImage && alreadyTransformedImage.body) {
35
+ if (alreadyTransformedImage?.body) {
36
36
  const fullDataUrl = formatBase64Image({
37
37
  base64String: alreadyTransformedImage.body.toString('base64'),
38
38
  key: keyWithTransformations
@@ -45,7 +45,7 @@ const fetchImageForPdfGeneratorService = async function (url) {
45
45
  switch (statusCode) {
46
46
  case 200:
47
47
  {
48
- console.log('Image transformation successful');
48
+ console.debug('Image transformation successful');
49
49
  const fullDataUrl = formatBase64Image({
50
50
  base64String: transformerResponse.body.toString('base64'),
51
51
  key: keyWithTransformations
@@ -54,14 +54,14 @@ const fetchImageForPdfGeneratorService = async function (url) {
54
54
  }
55
55
  case 302:
56
56
  {
57
- console.log('Image transformation successful but image is too big for lambda delivery, fetching directly from S3');
57
+ console.debug('Image transformation successful but image is too big for lambda delivery, fetching directly from S3');
58
58
  const redirectLocation = transformerResponse.headers?.Location;
59
59
  if (redirectLocation) {
60
60
  const newlyTransformedImage = await fetchResourceFromS3({
61
- bucketName: `${process.env.S3_BUCKET_UPLOADS}-transformed`,
61
+ bucketName: `${process.env.S3_BUCKET_IMAGE_TRANSFORMER_CACHE}`,
62
62
  key: keyWithTransformations
63
63
  });
64
- console.log('Image successfully fetched from S3 at:', redirectLocation);
64
+ console.debug('Image successfully fetched from S3 at:', redirectLocation);
65
65
  const fullDataUrl = formatBase64Image({
66
66
  base64String: newlyTransformedImage.body.toString('base64'),
67
67
  key: keyWithTransformations
@@ -87,7 +87,7 @@ async function requestImageTransformation(key) {
87
87
  if (!key) {
88
88
  throw new Error('Image Path is required for image transformation');
89
89
  }
90
- console.log('ImageTransformation: Invoking image transformer lambda for path:', key);
90
+ console.debug('ImageTransformation: Invoking image transformer lambda for path:', key);
91
91
  const lambdaEvent = {
92
92
  requestContext: {
93
93
  http: {
@@ -115,7 +115,7 @@ async function fetchResourceFromS3({
115
115
  bucketName,
116
116
  key
117
117
  }) {
118
- console.info(`Fetching resource from S3 Bucket: '${bucketName}' at path: '${key}'`);
118
+ console.debug(`Fetching resource from S3 Bucket: '${bucketName}' at path: '${key}'`);
119
119
  if (!bucketName || !key) {
120
120
  throw new Error('bucketName and key are required for S3 resource fetch ' + JSON.stringify({
121
121
  bucketName,
@@ -137,10 +137,10 @@ async function fetchResourceFromS3({
137
137
  };
138
138
  } catch (error) {
139
139
  if (error.code !== 'NoSuchKey') {
140
- console.info('Failed to fetch image:', error);
140
+ console.error('Failed to fetch image:', error);
141
141
  throw new Error(`Failed to fetch image: ${bucketName}/${key}`);
142
142
  }
143
- console.info('Image not found in transformed bucket, invoking transformer');
143
+ console.debug('Image not found in transformed bucket, invoking transformer');
144
144
  }
145
145
  }
146
146
  function formatBase64Image({
@@ -23,7 +23,7 @@ const fetchImageForWeb = async function (url, options) {
23
23
  const firstParamConnector = url.indexOf('?') > -1 ? '&' : '?';
24
24
  const urlToEncode = `${url}${firstParamConnector}Signature=${Signature}&Policy=${Policy}&Key-Pair-Id=${KeyPairId}`;
25
25
  const encodedUrl = encodeURI(urlToEncode);
26
- console.info('Fetching image via CloudFront For Web');
26
+ console.debug('Fetching image via CloudFront For Web');
27
27
  const imageResponse = await fetch(encodedUrl);
28
28
  const contentLengthHeader = imageResponse.headers.get('content-length');
29
29
  const contentType = imageResponse.headers.get('content-type');
@@ -39,9 +39,8 @@ const fetchImageForWeb = async function (url, options) {
39
39
  const imageStr = (0, _arrayBufferToBase.arrayBufferToBase64)(logoArrayBuffer);
40
40
  const base64 = `${base64Flag}${imageStr}`;
41
41
  const isValid = (0, _imageValidators.validateBase64Image)(base64);
42
- if (isValid) {
43
- return base64;
44
- }
42
+ if (!isValid) throw new Error('InvalidImageError');
43
+ return base64;
45
44
  } catch (error) {
46
45
  if (isHeader) {
47
46
  // NOTE: Replace failed headers with LH logo
@@ -51,6 +50,5 @@ const fetchImageForWeb = async function (url, options) {
51
50
  console.error(error);
52
51
  return _images.imageNotFound;
53
52
  }
54
- return Promise.reject(new Error('InvalidImageError'));
55
53
  };
56
54
  exports.fetchImageForWeb = fetchImageForWeb;
@@ -15,6 +15,7 @@ function getAuditEntryDetails(data) {
15
15
  createdAt,
16
16
  gps,
17
17
  items,
18
+ templateRevision,
18
19
  sequenceId,
19
20
  score,
20
21
  target,
@@ -40,6 +41,7 @@ function getAuditEntryDetails(data) {
40
41
  locationText,
41
42
  referenceLabel: referenceDetails.label,
42
43
  referenceValue: referenceDetails.value,
44
+ templateRevision,
43
45
  scoreText,
44
46
  sequenceId,
45
47
  target,
@@ -19,6 +19,7 @@ function getIssueDetails(data) {
19
19
  createdAt,
20
20
  duration,
21
21
  gps,
22
+ templateRevision,
22
23
  sequenceId,
23
24
  status,
24
25
  user
@@ -45,6 +46,7 @@ function getIssueDetails(data) {
45
46
  fullName,
46
47
  isClosedStatus,
47
48
  locationText,
49
+ templateRevision,
48
50
  sequenceId,
49
51
  statusStyle,
50
52
  statusColor,
@@ -14,7 +14,8 @@ function getTaskEntryDetails(data) {
14
14
  const {
15
15
  createdAt,
16
16
  gps,
17
- sequenceId
17
+ sequenceId,
18
+ templateRevision
18
19
  } = entity;
19
20
  const gpsText = (0, _lodash.get)(gps, 'reverseGeocoded.label', 'Unknown Location');
20
21
  const locationText = (0, _.getLocationReference)(data);
@@ -34,6 +35,7 @@ function getTaskEntryDetails(data) {
34
35
  referenceLabel: referenceDetails.label,
35
36
  referenceValue: referenceDetails.value,
36
37
  sequenceId,
38
+ templateRevision,
37
39
  timezoneHourTime,
38
40
  timezoneDatetime
39
41
  };
@@ -36,14 +36,14 @@ function buildImage(options) {
36
36
  alignment = 'center',
37
37
  filepath,
38
38
  height = 210,
39
- settings,
39
+ settings = {},
40
40
  width = 210
41
41
  } = options;
42
42
  const {
43
43
  awsS3BaseUrl,
44
44
  cloudinaryBaseUrl,
45
45
  cloudfrontBaseUrl
46
- } = settings || {};
46
+ } = settings;
47
47
  const isVideoType = new RegExp('.mp4$').test(filepath);
48
48
  const link = `${awsS3BaseUrl}/${filepath}`;
49
49
  if (isVideoType) {
@@ -6,8 +6,8 @@ export function buildFetchUrl(url, options) {
6
6
  fit = options.fit,
7
7
  height = options.height,
8
8
  width = options.width,
9
- quality = options.quality;
10
- var shouldUseCloudfront = cloudfrontBaseUrl && cloudfrontBaseUrl.includes('.cloudfront.net');
9
+ quality = options.quality,
10
+ shouldUseCloudfront = options.shouldUseCloudfront;
11
11
  if (shouldUseCloudfront) {
12
12
  var _transformations = [];
13
13
  if (width) _transformations.push("width=".concat(width.toString()));
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["buildFetchUrl","url","options","awsS3BaseUrl","_options$cloudfrontBa","cloudfrontBaseUrl","cloudinaryBaseUrl","fit","height","width","quality","shouldUseCloudfront","includes","transformations","push","concat","toString","transformationsString","join","fetchUrl"],"sources":["../../../src/helpers/build-fetch-url/index.js"],"sourcesContent":["export function buildFetchUrl(url, options) {\n const {\n awsS3BaseUrl,\n cloudfrontBaseUrl = '',\n cloudinaryBaseUrl,\n fit,\n height,\n width,\n quality,\n } = options\n\n const shouldUseCloudfront =\n cloudfrontBaseUrl && cloudfrontBaseUrl.includes('.cloudfront.net')\n\n if (shouldUseCloudfront) {\n const transformations = []\n\n if (width) transformations.push(`width=${width.toString()}`)\n if (height) transformations.push(`height=${height.toString()}`)\n if (quality) transformations.push(`quality=${quality.toString()}`)\n transformations.push(`fit=contain`)\n\n const transformationsString = transformations.join('&')\n\n const fetchUrl = `${cloudfrontBaseUrl}/${url}?${transformationsString}`\n return fetchUrl\n }\n\n const transformations = []\n let transformationsString = ''\n\n if (width) transformations.push(`w_${width.toString()}`)\n if (height) transformations.push(`h_${height.toString()}`)\n if (quality) transformations.push(`q_${quality.toString()}`)\n if (fit) transformations.push('c_fit')\n\n transformationsString = `${transformations.join(',')}/`\n\n const fetchUrl = `${cloudinaryBaseUrl}/${transformationsString}${awsS3BaseUrl}/${url}`\n\n return fetchUrl\n}\n"],"mappings":"AAAA,OAAO,SAASA,aAAaA,CAACC,GAAG,EAAEC,OAAO,EAAE;EAC1C,IACEC,YAAY,GAOVD,OAAO,CAPTC,YAAY;IAAAC,qBAAA,GAOVF,OAAO,CANTG,iBAAiB;IAAjBA,iBAAiB,GAAAD,qBAAA,cAAG,EAAE,GAAAA,qBAAA;IACtBE,iBAAiB,GAKfJ,OAAO,CALTI,iBAAiB;IACjBC,GAAG,GAIDL,OAAO,CAJTK,GAAG;IACHC,MAAM,GAGJN,OAAO,CAHTM,MAAM;IACNC,KAAK,GAEHP,OAAO,CAFTO,KAAK;IACLC,OAAO,GACLR,OAAO,CADTQ,OAAO;EAGT,IAAMC,mBAAmB,GACvBN,iBAAiB,IAAIA,iBAAiB,CAACO,QAAQ,CAAC,iBAAiB,CAAC;EAEpE,IAAID,mBAAmB,EAAE;IACvB,IAAME,gBAAe,GAAG,EAAE;IAE1B,IAAIJ,KAAK,EAAEI,gBAAe,CAACC,IAAI,UAAAC,MAAA,CAAUN,KAAK,CAACO,QAAQ,CAAC,CAAC,CAAE,CAAC;IAC5D,IAAIR,MAAM,EAAEK,gBAAe,CAACC,IAAI,WAAAC,MAAA,CAAWP,MAAM,CAACQ,QAAQ,CAAC,CAAC,CAAE,CAAC;IAC/D,IAAIN,OAAO,EAAEG,gBAAe,CAACC,IAAI,YAAAC,MAAA,CAAYL,OAAO,CAACM,QAAQ,CAAC,CAAC,CAAE,CAAC;IAClEH,gBAAe,CAACC,IAAI,cAAc,CAAC;IAEnC,IAAMG,sBAAqB,GAAGJ,gBAAe,CAACK,IAAI,CAAC,GAAG,CAAC;IAEvD,IAAMC,SAAQ,MAAAJ,MAAA,CAAMV,iBAAiB,OAAAU,MAAA,CAAId,GAAG,OAAAc,MAAA,CAAIE,sBAAqB,CAAE;IACvE,OAAOE,SAAQ;EACjB;EAEA,IAAMN,eAAe,GAAG,EAAE;EAC1B,IAAII,qBAAqB,GAAG,EAAE;EAE9B,IAAIR,KAAK,EAAEI,eAAe,CAACC,IAAI,MAAAC,MAAA,CAAMN,KAAK,CAACO,QAAQ,CAAC,CAAC,CAAE,CAAC;EACxD,IAAIR,MAAM,EAAEK,eAAe,CAACC,IAAI,MAAAC,MAAA,CAAMP,MAAM,CAACQ,QAAQ,CAAC,CAAC,CAAE,CAAC;EAC1D,IAAIN,OAAO,EAAEG,eAAe,CAACC,IAAI,MAAAC,MAAA,CAAML,OAAO,CAACM,QAAQ,CAAC,CAAC,CAAE,CAAC;EAC5D,IAAIT,GAAG,EAAEM,eAAe,CAACC,IAAI,CAAC,OAAO,CAAC;EAEtCG,qBAAqB,MAAAF,MAAA,CAAMF,eAAe,CAACK,IAAI,CAAC,GAAG,CAAC,MAAG;EAEvD,IAAMC,QAAQ,MAAAJ,MAAA,CAAMT,iBAAiB,OAAAS,MAAA,CAAIE,qBAAqB,EAAAF,MAAA,CAAGZ,YAAY,OAAAY,MAAA,CAAId,GAAG,CAAE;EAEtF,OAAOkB,QAAQ;AACjB","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["buildFetchUrl","url","options","awsS3BaseUrl","_options$cloudfrontBa","cloudfrontBaseUrl","cloudinaryBaseUrl","fit","height","width","quality","shouldUseCloudfront","transformations","push","concat","toString","transformationsString","join","fetchUrl"],"sources":["../../../src/helpers/build-fetch-url/index.js"],"sourcesContent":["export function buildFetchUrl(url, options) {\n const {\n awsS3BaseUrl,\n cloudfrontBaseUrl = '',\n cloudinaryBaseUrl,\n fit,\n height,\n width,\n quality,\n shouldUseCloudfront,\n } = options\n\n if (shouldUseCloudfront) {\n const transformations = []\n\n if (width) transformations.push(`width=${width.toString()}`)\n if (height) transformations.push(`height=${height.toString()}`)\n if (quality) transformations.push(`quality=${quality.toString()}`)\n transformations.push(`fit=contain`)\n\n const transformationsString = transformations.join('&')\n\n const fetchUrl = `${cloudfrontBaseUrl}/${url}?${transformationsString}`\n return fetchUrl\n }\n\n const transformations = []\n let transformationsString = ''\n\n if (width) transformations.push(`w_${width.toString()}`)\n if (height) transformations.push(`h_${height.toString()}`)\n if (quality) transformations.push(`q_${quality.toString()}`)\n if (fit) transformations.push('c_fit')\n\n transformationsString = `${transformations.join(',')}/`\n\n const fetchUrl = `${cloudinaryBaseUrl}/${transformationsString}${awsS3BaseUrl}/${url}`\n\n return fetchUrl\n}\n"],"mappings":"AAAA,OAAO,SAASA,aAAaA,CAACC,GAAG,EAAEC,OAAO,EAAE;EAC1C,IACEC,YAAY,GAQVD,OAAO,CARTC,YAAY;IAAAC,qBAAA,GAQVF,OAAO,CAPTG,iBAAiB;IAAjBA,iBAAiB,GAAAD,qBAAA,cAAG,EAAE,GAAAA,qBAAA;IACtBE,iBAAiB,GAMfJ,OAAO,CANTI,iBAAiB;IACjBC,GAAG,GAKDL,OAAO,CALTK,GAAG;IACHC,MAAM,GAIJN,OAAO,CAJTM,MAAM;IACNC,KAAK,GAGHP,OAAO,CAHTO,KAAK;IACLC,OAAO,GAELR,OAAO,CAFTQ,OAAO;IACPC,mBAAmB,GACjBT,OAAO,CADTS,mBAAmB;EAGrB,IAAIA,mBAAmB,EAAE;IACvB,IAAMC,gBAAe,GAAG,EAAE;IAE1B,IAAIH,KAAK,EAAEG,gBAAe,CAACC,IAAI,UAAAC,MAAA,CAAUL,KAAK,CAACM,QAAQ,CAAC,CAAC,CAAE,CAAC;IAC5D,IAAIP,MAAM,EAAEI,gBAAe,CAACC,IAAI,WAAAC,MAAA,CAAWN,MAAM,CAACO,QAAQ,CAAC,CAAC,CAAE,CAAC;IAC/D,IAAIL,OAAO,EAAEE,gBAAe,CAACC,IAAI,YAAAC,MAAA,CAAYJ,OAAO,CAACK,QAAQ,CAAC,CAAC,CAAE,CAAC;IAClEH,gBAAe,CAACC,IAAI,cAAc,CAAC;IAEnC,IAAMG,sBAAqB,GAAGJ,gBAAe,CAACK,IAAI,CAAC,GAAG,CAAC;IAEvD,IAAMC,SAAQ,MAAAJ,MAAA,CAAMT,iBAAiB,OAAAS,MAAA,CAAIb,GAAG,OAAAa,MAAA,CAAIE,sBAAqB,CAAE;IACvE,OAAOE,SAAQ;EACjB;EAEA,IAAMN,eAAe,GAAG,EAAE;EAC1B,IAAII,qBAAqB,GAAG,EAAE;EAE9B,IAAIP,KAAK,EAAEG,eAAe,CAACC,IAAI,MAAAC,MAAA,CAAML,KAAK,CAACM,QAAQ,CAAC,CAAC,CAAE,CAAC;EACxD,IAAIP,MAAM,EAAEI,eAAe,CAACC,IAAI,MAAAC,MAAA,CAAMN,MAAM,CAACO,QAAQ,CAAC,CAAC,CAAE,CAAC;EAC1D,IAAIL,OAAO,EAAEE,eAAe,CAACC,IAAI,MAAAC,MAAA,CAAMJ,OAAO,CAACK,QAAQ,CAAC,CAAC,CAAE,CAAC;EAC5D,IAAIR,GAAG,EAAEK,eAAe,CAACC,IAAI,CAAC,OAAO,CAAC;EAEtCG,qBAAqB,MAAAF,MAAA,CAAMF,eAAe,CAACK,IAAI,CAAC,GAAG,CAAC,MAAG;EAEvD,IAAMC,QAAQ,MAAAJ,MAAA,CAAMR,iBAAiB,OAAAQ,MAAA,CAAIE,qBAAqB,EAAAF,MAAA,CAAGX,YAAY,OAAAW,MAAA,CAAIb,GAAG,CAAE;EAEtF,OAAOiB,QAAQ;AACjB","ignoreList":[]}
@@ -32,7 +32,7 @@ var defaultOptions = {
32
32
  };
33
33
  export function fetchImage(url) {
34
34
  var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
35
- var shouldUseCloudfront = url && url.includes('.cloudfront.net');
35
+ var shouldUseCloudfront = options.shouldUseCloudfront;
36
36
  if (shouldUseCloudfront) {
37
37
  var isWebContext = (typeof window === "undefined" ? "undefined" : _typeof(window)) === 'object';
38
38
  return isWebContext ?
@@ -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","includes","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","console","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 = url && url.includes('.cloudfront.net')\n\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\nfunction 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","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","console","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.shouldUseCloudfront\n\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\nfunction 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":";;;;AAAA,SAASA,IAAI,EAAEC,IAAI,QAAQ,kBAAkB;AAC7C,OAAOC,aAAa,MAAM,gBAAgB;AAC1C,OAAOC,OAAO,MAAM,UAAU;AAC9B,SAASC,mBAAmB,QAAQ,iBAAiB;AACrD,SAASC,aAAa,QAAQ,cAAc;AAC5C,SAASC,gCAAgC,QAAQ,0CAA0C;AAC3F,SAASC,gBAAgB,QAAQ,wBAAwB;;AAEzD;AACA;AACA;AACA,IAAMC,KAAK,GACR,QAAOC,IAAI,iCAAAC,OAAA,CAAJD,IAAI,OAAK,QAAQ,IAAIA,IAAI,CAACD,KAAK,IAAKN,aAAa,CAAC;EAAEC,OAAO,EAAPA;AAAQ,CAAC,CAAC,CAACK,KAAK;AAE9E,IAAMG,YAAY,GAAG;EACnB,WAAW,EAAE,KAAK;EAClB,YAAY,EAAE;AAChB,CAAC;AAED,IAAMC,cAAc,GAAG;EACrB;EACA;EACA;EACA;EACA;EACA;EACA;EACAC,KAAK,EAAE;AACT,CAAC;AAED,OAAO,SAASC,UAAUA,CAACC,GAAG,EAAgB;EAAA,IAAdC,OAAO,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAAC,CAAC;EAC1C,IAAMG,mBAAmB,GAAGJ,OAAO,CAACI,mBAAmB;EAEvD,IAAIA,mBAAmB,EAAE;IACvB,IAAMC,YAAY,GAAG,QAAOC,MAAM,iCAAAZ,OAAA,CAANY,MAAM,OAAK,QAAQ;IAE/C,OAAOD,YAAY;IACf;IACAd,gBAAgB,CAACQ,GAAG,EAAEC,OAAO,CAAC,GAC9BV,gCAAgC,CAACS,GAAG,CAAC;EAC3C;EAEA,IAAMQ,UAAU,GAAGC,SAAS,CAACT,GAAG,CAAC;EAEjC,IAAMU,YAAY,GAAAC,aAAA,CAAAA,aAAA,KACbd,cAAc,GACdI,OAAO,CACX;EACD,IAAAW,iBAAA,GAA6BX,OAAO,CAA5BY,QAAQ;IAARA,QAAQ,GAAAD,iBAAA,cAAG,KAAK,GAAAA,iBAAA;EAExB,OAAOnB,KAAK,CAACe,UAAU,EAAEE,YAAY,CAAC,CACnCI,IAAI,CAAC,UAAAC,QAAQ,EAAI;IAChB,IAAMC,aAAa,GAAGD,QAAQ,CAACE,OAAO,CAACC,GAAG,CAAC,gBAAgB,CAAC;IAC5D,IAAMC,WAAW,GAAGJ,QAAQ,CAACE,OAAO,CAACC,GAAG,CAAC,cAAc,CAAC;;IAExD;IACA;IACA,IAAIF,aAAa,KAAK,GAAG,EAAE;MACzB,OAAO5B,OAAO,CAACgC,MAAM,CACnB,IAAIC,KAAK,gDAAAC,MAAA,CAAgDd,UAAU,CAAE,CACvE,CAAC;IACH;IAEA,IAAI,CAACO,QAAQ,CAACQ,EAAE,EAAE;MAChB,OAAOnC,OAAO,CAACgC,MAAM,CAAC,IAAIC,KAAK,2BAAAC,MAAA,CAA2Bd,UAAU,CAAE,CAAC,CAAC;IAC1E;IAEA,IAAMgB,SAAS,GAAG5B,YAAY,CAACuB,WAAW,CAAC;IAE3C,OAAOJ,QAAQ,CAACU,WAAW,CAAC,CAAC,CAACX,IAAI,CAAC,UAAAY,MAAM;MAAA,OAAK;QAC5CA,MAAM,EAANA,MAAM;QACNF,SAAS,EAATA;MACF,CAAC;IAAA,CAAC,CAAC;EACL,CAAC,CAAC,CACDV,IAAI,CAAC,UAAAa,IAAA,EAA2B;IAAA,IAAxBD,MAAM,GAAAC,IAAA,CAAND,MAAM;MAAEF,SAAS,GAAAG,IAAA,CAATH,SAAS;IACxB,IAAMI,UAAU,iBAAAN,MAAA,CAAiBE,SAAS,aAAU;IACpD,IAAMK,QAAQ,GAAGC,mBAAmB,CAACJ,MAAM,CAAC;IAE5C,IAAMK,MAAM,MAAAT,MAAA,CAAMM,UAAU,EAAAN,MAAA,CAAGO,QAAQ,CAAE;IACzC,IAAMG,OAAO,GAAGC,mBAAmB,CAACF,MAAM,CAAC;IAE3C,IAAI,CAACC,OAAO,EAAE;MACZ,OAAO5C,OAAO,CAACgC,MAAM,CAAC,IAAIC,KAAK,CAAC,mBAAmB,CAAC,CAAC;IACvD;IAEA,OAAOU,MAAM;EACf,CAAC,CAAC,CACDG,KAAK,CAAC,UAAAC,KAAK,EAAI;IACd,IAAItB,QAAQ,EAAE;MACZ;MACAuB,OAAO,CAACD,KAAK,CAAC,uBAAuB,EAAEA,KAAK,CAAC;MAC7C,OAAOpC,UAAU,CAACV,mBAAmB,EAAEQ,cAAc,CAAC;IACxD;IAEAuC,OAAO,CAACD,KAAK,CAACA,KAAK,CAAC;IACpB,OAAO7C,aAAa;EACtB,CAAC,CAAC;AACN;AAEA,SAASwC,mBAAmBA,CAACJ,MAAM,EAAE;EACnC,IAAIW,MAAM,GAAG,EAAE;EACf,IAAMC,KAAK,GAAG,EAAE,CAACC,KAAK,CAACC,IAAI,CAAC,IAAIC,UAAU,CAACf,MAAM,CAAC,CAAC;EAEnDY,KAAK,CAACI,OAAO,CAAC,UAAAC,CAAC;IAAA,OAAKN,MAAM,IAAIO,MAAM,CAACC,YAAY,CAACF,CAAC,CAAC;EAAA,CAAC,CAAC;EAEtD,OAAOzD,IAAI,CAACmD,MAAM,CAAC;AACrB;AAEA,OAAO,SAASJ,mBAAmBA,CAACa,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,OAAO,SAASG,iBAAiBA,CAACG,YAAY,EAAE;EAC9C,IAAMC,GAAG,GAAGD,YAAY;EACxB,IAAME,SAAS,GAAGb,UAAU,CAACc,IAAI,CAC/BtE,IAAI,CAACoE,GAAG,CAACG,OAAO,CAAC,yBAAyB,EAAE,EAAE,CAAC,CAAC,EAChD,UAAAC,CAAC;IAAA,OAAIA,CAAC,CAACC,UAAU,CAAC,CAAC,CAAC;EAAA,CACtB,CAAC;EACD,IAAMC,cAAc,GAClBL,SAAS,CAACA,SAAS,CAACnD,MAAM,GAAG,CAAC,CAAC,KAAK,GAAG,IACvCmD,SAAS,CAACA,SAAS,CAACnD,MAAM,GAAG,CAAC,CAAC,KAAK,GAAG;EAEzC,OAAOwD,cAAc;AACvB;;AAEA;AACA;AACA,OAAO,SAASR,gBAAgBA,CAACC,YAAY,EAAE;EAC7C,IAAMC,GAAG,GAAGD,YAAY;EACxB,IAAME,SAAS,GAAGb,UAAU,CAACc,IAAI,CAC/BtE,IAAI,CAACoE,GAAG,CAACG,OAAO,CAAC,wBAAwB,EAAE,EAAE,CAAC,CAAC,EAC/C,UAAAC,CAAC;IAAA,OAAIA,CAAC,CAACC,UAAU,CAAC,CAAC,CAAC;EAAA,CACtB,CAAC;EACD,IAAME,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;;EAE/D;EACA,KAAK,IAAIC,CAAC,GAAG,EAAE,EAAEA,CAAC,GAAG,CAAC,EAAEA,CAAC,EAAE,EAAE;IAC3B,IAAIP,SAAS,CAACA,SAAS,CAACnD,MAAM,GAAG0D,CAAC,CAAC,KAAKD,QAAQ,CAAC,EAAE,GAAGC,CAAC,CAAC,EAAE;MACxD,OAAO,KAAK;IACd;EACF;EAEA,OAAO,IAAI;AACb","ignoreList":[]}
@@ -15,7 +15,7 @@ export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
15
15
  return _regeneratorRuntime.wrap(function (_context) {
16
16
  while (1) switch (_context.prev = _context.next) {
17
17
  case 0:
18
- console.info('Fetching image via CloudFront For Serverless Pdf Generator Service');
18
+ console.debug('Fetching image via CloudFront For Serverless Pdf Generator Service');
19
19
  if (url) {
20
20
  _context.next = 1;
21
21
  break;
@@ -33,12 +33,12 @@ export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
33
33
  keyWithTransformations = url.substring(url.indexOf(applicationId));
34
34
  _context.next = 3;
35
35
  return fetchResourceFromS3({
36
- bucketName: "".concat(process.env.S3_BUCKET_UPLOADS, "-transformed"),
36
+ bucketName: "".concat(process.env.S3_BUCKET_IMAGE_TRANSFORMER_CACHE),
37
37
  key: keyWithTransformations
38
38
  });
39
39
  case 3:
40
40
  alreadyTransformedImage = _context.sent;
41
- if (!(alreadyTransformedImage && alreadyTransformedImage.body)) {
41
+ if (!(alreadyTransformedImage !== null && alreadyTransformedImage !== void 0 && alreadyTransformedImage.body)) {
42
42
  _context.next = 4;
43
43
  break;
44
44
  }
@@ -58,14 +58,14 @@ export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
58
58
  _context.next = _t === 200 ? 6 : _t === 302 ? 7 : _t === 400 ? 10 : _t === 403 ? 11 : _t === 404 ? 12 : _t === 500 ? 13 : 14;
59
59
  break;
60
60
  case 6:
61
- console.log('Image transformation successful');
61
+ console.debug('Image transformation successful');
62
62
  _fullDataUrl = formatBase64Image({
63
63
  base64String: transformerResponse.body.toString('base64'),
64
64
  key: keyWithTransformations
65
65
  });
66
66
  return _context.abrupt("return", _fullDataUrl);
67
67
  case 7:
68
- console.log('Image transformation successful but image is too big for lambda delivery, fetching directly from S3');
68
+ console.debug('Image transformation successful but image is too big for lambda delivery, fetching directly from S3');
69
69
  redirectLocation = (_transformerResponse$ = transformerResponse.headers) === null || _transformerResponse$ === void 0 ? void 0 : _transformerResponse$.Location;
70
70
  if (!redirectLocation) {
71
71
  _context.next = 9;
@@ -73,12 +73,12 @@ export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
73
73
  }
74
74
  _context.next = 8;
75
75
  return fetchResourceFromS3({
76
- bucketName: "".concat(process.env.S3_BUCKET_UPLOADS, "-transformed"),
76
+ bucketName: "".concat(process.env.S3_BUCKET_IMAGE_TRANSFORMER_CACHE),
77
77
  key: keyWithTransformations
78
78
  });
79
79
  case 8:
80
80
  newlyTransformedImage = _context.sent;
81
- console.log('Image successfully fetched from S3 at:', redirectLocation);
81
+ console.debug('Image successfully fetched from S3 at:', redirectLocation);
82
82
  _fullDataUrl2 = formatBase64Image({
83
83
  base64String: newlyTransformedImage.body.toString('base64'),
84
84
  key: keyWithTransformations
@@ -121,7 +121,7 @@ function _requestImageTransformation() {
121
121
  }
122
122
  throw new Error('Image Path is required for image transformation');
123
123
  case 1:
124
- console.log('ImageTransformation: Invoking image transformer lambda for path:', key);
124
+ console.debug('ImageTransformation: Invoking image transformer lambda for path:', key);
125
125
  lambdaEvent = {
126
126
  requestContext: {
127
127
  http: {
@@ -166,7 +166,7 @@ function _fetchResourceFromS() {
166
166
  while (1) switch (_context3.prev = _context3.next) {
167
167
  case 0:
168
168
  bucketName = _ref2.bucketName, key = _ref2.key;
169
- console.info("Fetching resource from S3 Bucket: '".concat(bucketName, "' at path: '").concat(key, "'"));
169
+ console.debug("Fetching resource from S3 Bucket: '".concat(bucketName, "' at path: '").concat(key, "'"));
170
170
  if (!(!bucketName || !key)) {
171
171
  _context3.next = 1;
172
172
  break;
@@ -199,10 +199,10 @@ function _fetchResourceFromS() {
199
199
  _context3.next = 5;
200
200
  break;
201
201
  }
202
- console.info('Failed to fetch image:', _t3);
202
+ console.error('Failed to fetch image:', _t3);
203
203
  throw new Error("Failed to fetch image: ".concat(bucketName, "/").concat(key));
204
204
  case 5:
205
- console.info('Image not found in transformed bucket, invoking transformer');
205
+ console.debug('Image not found in transformed bucket, invoking transformer');
206
206
  case 6:
207
207
  case "end":
208
208
  return _context3.stop();
@@ -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","_t","wrap","_context","prev","next","console","info","Error","match","substring","indexOf","fetchResourceFromS3","bucketName","concat","S3_BUCKET_UPLOADS","key","sent","body","formatBase64Image","base64String","toString","abrupt","split","requestImageTransformation","log","headers","Location","stop","_x","apply","arguments","_x2","_requestImageTransformation","_callee2","lambdaEvent","params","result","response","errorMessage","_t2","_context2","requestContext","http","method","path","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"],"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":[]}
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","_t","wrap","_context","prev","next","console","debug","Error","match","substring","indexOf","fetchResourceFromS3","bucketName","concat","S3_BUCKET_IMAGE_TRANSFORMER_CACHE","key","sent","body","formatBase64Image","base64String","toString","abrupt","split","requestImageTransformation","headers","Location","stop","_x","apply","arguments","_x2","_requestImageTransformation","_callee2","lambdaEvent","params","result","response","errorMessage","_t2","_context2","requestContext","http","method","path","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"],"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 keyWithTransformations = url.substring(url.indexOf(applicationId))\n\n const alreadyTransformedImage = await fetchResourceFromS3({\n bucketName: `${process.env.S3_BUCKET_IMAGE_TRANSFORMER_CACHE}`,\n key: keyWithTransformations,\n })\n\n if (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.debug('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.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: keyWithTransformations,\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: 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.debug(\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.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"],"mappings":"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","ignoreList":[]}
@@ -19,7 +19,7 @@ export var fetchImageForWeb = /*#__PURE__*/function () {
19
19
  firstParamConnector = url.indexOf('?') > -1 ? '&' : '?';
20
20
  urlToEncode = "".concat(url).concat(firstParamConnector, "Signature=").concat(Signature, "&Policy=").concat(Policy, "&Key-Pair-Id=").concat(KeyPairId);
21
21
  encodedUrl = encodeURI(urlToEncode);
22
- console.info('Fetching image via CloudFront For Web');
22
+ console.debug('Fetching image via CloudFront For Web');
23
23
  _context.next = 2;
24
24
  return fetch(encodedUrl);
25
25
  case 2:
@@ -47,14 +47,13 @@ export var fetchImageForWeb = /*#__PURE__*/function () {
47
47
  imageStr = arrayBufferToBase64(logoArrayBuffer);
48
48
  base64 = "".concat(base64Flag).concat(imageStr);
49
49
  isValid = validateBase64Image(base64);
50
- if (!isValid) {
50
+ if (isValid) {
51
51
  _context.next = 6;
52
52
  break;
53
53
  }
54
- return _context.abrupt("return", base64);
54
+ throw new Error('InvalidImageError');
55
55
  case 6:
56
- _context.next = 9;
57
- break;
56
+ return _context.abrupt("return", base64);
58
57
  case 7:
59
58
  _context.prev = 7;
60
59
  _t = _context["catch"](1);
@@ -69,8 +68,6 @@ export var fetchImageForWeb = /*#__PURE__*/function () {
69
68
  console.error(_t);
70
69
  return _context.abrupt("return", imageNotFound);
71
70
  case 9:
72
- return _context.abrupt("return", Promise.reject(new Error('InvalidImageError')));
73
- case 10:
74
71
  case "end":
75
72
  return _context.stop();
76
73
  }
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["imageNotFound","fetchLighthouseLogo","arrayBufferToBase64","validateBase64Image","contentTypes","fetchImageForWeb","_ref","_asyncToGenerator","_regeneratorRuntime","mark","_callee","url","options","_options$isHeader","isHeader","Signature","Policy","KeyPairId","firstParamConnector","urlToEncode","encodedUrl","imageResponse","contentLengthHeader","contentType","imageType","logoArrayBuffer","base64Flag","imageStr","base64","isValid","_t","wrap","_context","prev","next","indexOf","concat","encodeURI","console","info","fetch","sent","headers","get","abrupt","Promise","reject","Error","ok","arrayBuffer","error","stop","_x","_x2","apply","arguments"],"sources":["../../../src/helpers/fetch-image-for-web/index.js"],"sourcesContent":["import { imageNotFound } from '../../images'\nimport { fetchLighthouseLogo } from '../fetch-lighthouse-logo'\nimport { arrayBufferToBase64 } from '../array-buffer-to-base-64'\nimport { validateBase64Image } from '../image-validators'\nconst contentTypes = {\n 'image/png': 'png',\n 'image/jpeg': 'jpeg',\n}\n\nexport const fetchImageForWeb = async function(url, options) {\n const { isHeader = false, Signature, Policy, KeyPairId } = options\n\n try {\n const firstParamConnector = url.indexOf('?') > -1 ? '&' : '?'\n const urlToEncode = `${url}${firstParamConnector}Signature=${Signature}&Policy=${Policy}&Key-Pair-Id=${KeyPairId}`\n\n const encodedUrl = encodeURI(urlToEncode)\n\n console.info('Fetching image via CloudFront For Web')\n\n const imageResponse = await fetch(encodedUrl)\n\n const contentLengthHeader = imageResponse.headers.get('content-length')\n const contentType = imageResponse.headers.get('content-type')\n\n if (contentLengthHeader === '0') {\n return Promise.reject(\n new Error(`Failed to fetch image as no content length: ${encodedUrl}`)\n )\n }\n\n if (!imageResponse.ok) {\n return Promise.reject(new Error(`Failed to fetch image: ${encodedUrl}`))\n }\n\n const imageType = contentTypes[contentType]\n\n const logoArrayBuffer = await imageResponse.arrayBuffer()\n\n const base64Flag = `data:image/${imageType};base64,`\n const imageStr = arrayBufferToBase64(logoArrayBuffer)\n\n const base64 = `${base64Flag}${imageStr}`\n const isValid = validateBase64Image(base64)\n\n if (isValid) {\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 fetchLighthouseLogo()\n }\n\n console.error(error)\n return imageNotFound\n }\n\n return Promise.reject(new Error('InvalidImageError'))\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["imageNotFound","fetchLighthouseLogo","arrayBufferToBase64","validateBase64Image","contentTypes","fetchImageForWeb","_ref","_asyncToGenerator","_regeneratorRuntime","mark","_callee","url","options","_options$isHeader","isHeader","Signature","Policy","KeyPairId","firstParamConnector","urlToEncode","encodedUrl","imageResponse","contentLengthHeader","contentType","imageType","logoArrayBuffer","base64Flag","imageStr","base64","isValid","_t","wrap","_context","prev","next","indexOf","concat","encodeURI","console","debug","fetch","sent","headers","get","abrupt","Promise","reject","Error","ok","arrayBuffer","error","stop","_x","_x2","apply","arguments"],"sources":["../../../src/helpers/fetch-image-for-web/index.js"],"sourcesContent":["import { imageNotFound } from '../../images'\nimport { fetchLighthouseLogo } from '../fetch-lighthouse-logo'\nimport { arrayBufferToBase64 } from '../array-buffer-to-base-64'\nimport { validateBase64Image } from '../image-validators'\nconst contentTypes = {\n 'image/png': 'png',\n 'image/jpeg': 'jpeg',\n}\n\nexport const fetchImageForWeb = async function(url, options) {\n const { isHeader = false, Signature, Policy, KeyPairId } = options\n\n try {\n const firstParamConnector = url.indexOf('?') > -1 ? '&' : '?'\n const urlToEncode = `${url}${firstParamConnector}Signature=${Signature}&Policy=${Policy}&Key-Pair-Id=${KeyPairId}`\n\n const encodedUrl = encodeURI(urlToEncode)\n\n console.debug('Fetching image via CloudFront For Web')\n\n const imageResponse = await fetch(encodedUrl)\n\n const contentLengthHeader = imageResponse.headers.get('content-length')\n const contentType = imageResponse.headers.get('content-type')\n\n if (contentLengthHeader === '0') {\n return Promise.reject(\n new Error(`Failed to fetch image as no content length: ${encodedUrl}`)\n )\n }\n\n if (!imageResponse.ok) {\n return Promise.reject(new Error(`Failed to fetch image: ${encodedUrl}`))\n }\n\n const imageType = contentTypes[contentType]\n\n const logoArrayBuffer = await imageResponse.arrayBuffer()\n\n const base64Flag = `data:image/${imageType};base64,`\n const imageStr = arrayBufferToBase64(logoArrayBuffer)\n\n const base64 = `${base64Flag}${imageStr}`\n const isValid = validateBase64Image(base64)\n\n if (!isValid) throw new Error('InvalidImageError')\n\n return base64\n } catch (error) {\n if (isHeader) {\n // NOTE: Replace failed headers with LH logo\n console.error('FetchImageHeaderError', error)\n return fetchLighthouseLogo()\n }\n\n console.error(error)\n return imageNotFound\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -6,6 +6,7 @@ export function getAuditEntryDetails(data) {
6
6
  var createdAt = entity.createdAt,
7
7
  gps = entity.gps,
8
8
  items = entity.items,
9
+ templateRevision = entity.templateRevision,
9
10
  sequenceId = entity.sequenceId,
10
11
  score = entity.score,
11
12
  target = entity.target,
@@ -30,6 +31,7 @@ export function getAuditEntryDetails(data) {
30
31
  locationText: locationText,
31
32
  referenceLabel: referenceDetails.label,
32
33
  referenceValue: referenceDetails.value,
34
+ templateRevision: templateRevision,
33
35
  scoreText: scoreText,
34
36
  sequenceId: sequenceId,
35
37
  target: target,
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["get","getAuditItemsData","getLocationReference","getReferenceDetails","getTimezoneDatetime","getAuditEntryDetails","data","entity","timezone","createdAt","gps","items","sequenceId","score","target","targetServiceLevel","locationText","gpsText","groupedData","referenceDetails","scoreText","percentageResult","undefined","concat","timezoneHourTime","format","timestamp","timezoneDatetime","referenceLabel","label","referenceValue","value"],"sources":["../../../src/helpers/get-audit-entry-details/index.js"],"sourcesContent":["import { get } from 'lodash'\n\nimport {\n getAuditItemsData,\n getLocationReference,\n getReferenceDetails,\n getTimezoneDatetime,\n} from '../'\n\nexport function getAuditEntryDetails(data) {\n const { entity, timezone } = data\n\n const {\n createdAt,\n gps,\n items,\n sequenceId,\n score,\n target,\n targetServiceLevel,\n } = entity\n\n const locationText = getLocationReference(data)\n const gpsText = get(gps, 'reverseGeocoded.label', 'Unknown Location')\n const groupedData = getAuditItemsData(items, data)\n const referenceDetails = getReferenceDetails(data)\n const scoreText =\n score && score.percentageResult !== undefined\n ? `${score.percentageResult}%`\n : ''\n const timezoneHourTime = getTimezoneDatetime({\n format: 'h:mm a',\n timestamp: createdAt,\n timezone,\n })\n const timezoneDatetime = getTimezoneDatetime({\n timestamp: createdAt,\n timezone,\n })\n\n return {\n gpsText,\n groupedData,\n locationText,\n referenceLabel: referenceDetails.label,\n referenceValue: referenceDetails.value,\n scoreText,\n sequenceId,\n target,\n targetServiceLevel,\n timezoneDatetime,\n timezoneHourTime,\n }\n}\n"],"mappings":"AAAA,SAASA,GAAG,QAAQ,QAAQ;AAE5B,SACEC,iBAAiB,EACjBC,oBAAoB,EACpBC,mBAAmB,EACnBC,mBAAmB,QACd,KAAK;AAEZ,OAAO,SAASC,oBAAoBA,CAACC,IAAI,EAAE;EACzC,IAAQC,MAAM,GAAeD,IAAI,CAAzBC,MAAM;IAAEC,QAAQ,GAAKF,IAAI,CAAjBE,QAAQ;EAExB,IACEC,SAAS,GAOPF,MAAM,CAPRE,SAAS;IACTC,GAAG,GAMDH,MAAM,CANRG,GAAG;IACHC,KAAK,GAKHJ,MAAM,CALRI,KAAK;IACLC,UAAU,GAIRL,MAAM,CAJRK,UAAU;IACVC,KAAK,GAGHN,MAAM,CAHRM,KAAK;IACLC,MAAM,GAEJP,MAAM,CAFRO,MAAM;IACNC,kBAAkB,GAChBR,MAAM,CADRQ,kBAAkB;EAGpB,IAAMC,YAAY,GAAGd,oBAAoB,CAACI,IAAI,CAAC;EAC/C,IAAMW,OAAO,GAAGjB,GAAG,CAACU,GAAG,EAAE,uBAAuB,EAAE,kBAAkB,CAAC;EACrE,IAAMQ,WAAW,GAAGjB,iBAAiB,CAACU,KAAK,EAAEL,IAAI,CAAC;EAClD,IAAMa,gBAAgB,GAAGhB,mBAAmB,CAACG,IAAI,CAAC;EAClD,IAAMc,SAAS,GACbP,KAAK,IAAIA,KAAK,CAACQ,gBAAgB,KAAKC,SAAS,MAAAC,MAAA,CACtCV,KAAK,CAACQ,gBAAgB,SACzB,EAAE;EACR,IAAMG,gBAAgB,GAAGpB,mBAAmB,CAAC;IAC3CqB,MAAM,EAAE,QAAQ;IAChBC,SAAS,EAAEjB,SAAS;IACpBD,QAAQ,EAARA;EACF,CAAC,CAAC;EACF,IAAMmB,gBAAgB,GAAGvB,mBAAmB,CAAC;IAC3CsB,SAAS,EAAEjB,SAAS;IACpBD,QAAQ,EAARA;EACF,CAAC,CAAC;EAEF,OAAO;IACLS,OAAO,EAAPA,OAAO;IACPC,WAAW,EAAXA,WAAW;IACXF,YAAY,EAAZA,YAAY;IACZY,cAAc,EAAET,gBAAgB,CAACU,KAAK;IACtCC,cAAc,EAAEX,gBAAgB,CAACY,KAAK;IACtCX,SAAS,EAATA,SAAS;IACTR,UAAU,EAAVA,UAAU;IACVE,MAAM,EAANA,MAAM;IACNC,kBAAkB,EAAlBA,kBAAkB;IAClBY,gBAAgB,EAAhBA,gBAAgB;IAChBH,gBAAgB,EAAhBA;EACF,CAAC;AACH","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["get","getAuditItemsData","getLocationReference","getReferenceDetails","getTimezoneDatetime","getAuditEntryDetails","data","entity","timezone","createdAt","gps","items","templateRevision","sequenceId","score","target","targetServiceLevel","locationText","gpsText","groupedData","referenceDetails","scoreText","percentageResult","undefined","concat","timezoneHourTime","format","timestamp","timezoneDatetime","referenceLabel","label","referenceValue","value"],"sources":["../../../src/helpers/get-audit-entry-details/index.js"],"sourcesContent":["import { get } from 'lodash'\n\nimport {\n getAuditItemsData,\n getLocationReference,\n getReferenceDetails,\n getTimezoneDatetime,\n} from '../'\n\nexport function getAuditEntryDetails(data) {\n const { entity, timezone } = data\n\n const {\n createdAt,\n gps,\n items,\n templateRevision,\n sequenceId,\n score,\n target,\n targetServiceLevel,\n } = entity\n\n const locationText = getLocationReference(data)\n const gpsText = get(gps, 'reverseGeocoded.label', 'Unknown Location')\n const groupedData = getAuditItemsData(items, data)\n const referenceDetails = getReferenceDetails(data)\n const scoreText =\n score && score.percentageResult !== undefined\n ? `${score.percentageResult}%`\n : ''\n const timezoneHourTime = getTimezoneDatetime({\n format: 'h:mm a',\n timestamp: createdAt,\n timezone,\n })\n const timezoneDatetime = getTimezoneDatetime({\n timestamp: createdAt,\n timezone,\n })\n\n return {\n gpsText,\n groupedData,\n locationText,\n referenceLabel: referenceDetails.label,\n referenceValue: referenceDetails.value,\n templateRevision,\n scoreText,\n sequenceId,\n target,\n targetServiceLevel,\n timezoneDatetime,\n timezoneHourTime,\n }\n}\n"],"mappings":"AAAA,SAASA,GAAG,QAAQ,QAAQ;AAE5B,SACEC,iBAAiB,EACjBC,oBAAoB,EACpBC,mBAAmB,EACnBC,mBAAmB,QACd,KAAK;AAEZ,OAAO,SAASC,oBAAoBA,CAACC,IAAI,EAAE;EACzC,IAAQC,MAAM,GAAeD,IAAI,CAAzBC,MAAM;IAAEC,QAAQ,GAAKF,IAAI,CAAjBE,QAAQ;EAExB,IACEC,SAAS,GAQPF,MAAM,CARRE,SAAS;IACTC,GAAG,GAODH,MAAM,CAPRG,GAAG;IACHC,KAAK,GAMHJ,MAAM,CANRI,KAAK;IACLC,gBAAgB,GAKdL,MAAM,CALRK,gBAAgB;IAChBC,UAAU,GAIRN,MAAM,CAJRM,UAAU;IACVC,KAAK,GAGHP,MAAM,CAHRO,KAAK;IACLC,MAAM,GAEJR,MAAM,CAFRQ,MAAM;IACNC,kBAAkB,GAChBT,MAAM,CADRS,kBAAkB;EAGpB,IAAMC,YAAY,GAAGf,oBAAoB,CAACI,IAAI,CAAC;EAC/C,IAAMY,OAAO,GAAGlB,GAAG,CAACU,GAAG,EAAE,uBAAuB,EAAE,kBAAkB,CAAC;EACrE,IAAMS,WAAW,GAAGlB,iBAAiB,CAACU,KAAK,EAAEL,IAAI,CAAC;EAClD,IAAMc,gBAAgB,GAAGjB,mBAAmB,CAACG,IAAI,CAAC;EAClD,IAAMe,SAAS,GACbP,KAAK,IAAIA,KAAK,CAACQ,gBAAgB,KAAKC,SAAS,MAAAC,MAAA,CACtCV,KAAK,CAACQ,gBAAgB,SACzB,EAAE;EACR,IAAMG,gBAAgB,GAAGrB,mBAAmB,CAAC;IAC3CsB,MAAM,EAAE,QAAQ;IAChBC,SAAS,EAAElB,SAAS;IACpBD,QAAQ,EAARA;EACF,CAAC,CAAC;EACF,IAAMoB,gBAAgB,GAAGxB,mBAAmB,CAAC;IAC3CuB,SAAS,EAAElB,SAAS;IACpBD,QAAQ,EAARA;EACF,CAAC,CAAC;EAEF,OAAO;IACLU,OAAO,EAAPA,OAAO;IACPC,WAAW,EAAXA,WAAW;IACXF,YAAY,EAAZA,YAAY;IACZY,cAAc,EAAET,gBAAgB,CAACU,KAAK;IACtCC,cAAc,EAAEX,gBAAgB,CAACY,KAAK;IACtCpB,gBAAgB,EAAhBA,gBAAgB;IAChBS,SAAS,EAATA,SAAS;IACTR,UAAU,EAAVA,UAAU;IACVE,MAAM,EAANA,MAAM;IACNC,kBAAkB,EAAlBA,kBAAkB;IAClBY,gBAAgB,EAAhBA,gBAAgB;IAChBH,gBAAgB,EAAhBA;EACF,CAAC;AACH","ignoreList":[]}
@@ -9,6 +9,7 @@ export function getIssueDetails(data) {
9
9
  createdAt = entity.createdAt,
10
10
  duration = entity.duration,
11
11
  gps = entity.gps,
12
+ templateRevision = entity.templateRevision,
12
13
  sequenceId = entity.sequenceId,
13
14
  status = entity.status,
14
15
  user = entity.user;
@@ -34,6 +35,7 @@ export function getIssueDetails(data) {
34
35
  fullName: fullName,
35
36
  isClosedStatus: isClosedStatus,
36
37
  locationText: locationText,
38
+ templateRevision: templateRevision,
37
39
  sequenceId: sequenceId,
38
40
  statusStyle: statusStyle,
39
41
  statusColor: statusColor,
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["get","upperCase","moment","getAssigneesFullNames","getLocationReference","getPrettyDuration","getStatusDetails","getTimezoneDatetime","getUserFullName","getIssueDetails","data","entity","timezone","users","assignees","createdAt","duration","gps","sequenceId","status","user","assigneeNames","durationInMins","durationText","fullName","gpsText","isClosedStatus","locationText","statusDetails","statusStyle","style","statusColor","color","statusText","text","timezoneDatetime","timestamp"],"sources":["../../../src/helpers/get-issue-details/index.js"],"sourcesContent":["import { get, upperCase } from 'lodash'\nimport moment from 'moment-timezone'\n\nimport {\n getAssigneesFullNames,\n getLocationReference,\n getPrettyDuration,\n getStatusDetails,\n getTimezoneDatetime,\n getUserFullName,\n} from '../'\n\nexport function getIssueDetails(data) {\n const { entity, timezone, users } = data\n\n const {\n assignees,\n createdAt,\n duration,\n gps,\n sequenceId,\n status,\n user,\n } = entity\n\n const assigneeNames = getAssigneesFullNames(users, assignees)\n const durationInMins = moment.duration(duration, 'minutes')\n const durationText = getPrettyDuration(durationInMins)\n const fullName = getUserFullName(users, user)\n const gpsText = get(gps, 'reverseGeocoded.label', 'Unknown Location')\n const isClosedStatus = status === 'closed'\n const locationText = getLocationReference(data)\n const statusDetails = getStatusDetails(status)\n const statusStyle = statusDetails.style\n const statusColor = statusStyle.color\n const statusText = upperCase(statusDetails.text)\n const timezoneDatetime = getTimezoneDatetime({\n timestamp: createdAt,\n timezone,\n })\n\n return {\n assigneeNames,\n durationText,\n gpsText,\n fullName,\n isClosedStatus,\n locationText,\n sequenceId,\n statusStyle,\n statusColor,\n statusText,\n timezoneDatetime,\n }\n}\n"],"mappings":"AAAA,SAASA,GAAG,EAAEC,SAAS,QAAQ,QAAQ;AACvC,OAAOC,MAAM,MAAM,iBAAiB;AAEpC,SACEC,qBAAqB,EACrBC,oBAAoB,EACpBC,iBAAiB,EACjBC,gBAAgB,EAChBC,mBAAmB,EACnBC,eAAe,QACV,KAAK;AAEZ,OAAO,SAASC,eAAeA,CAACC,IAAI,EAAE;EACpC,IAAQC,MAAM,GAAsBD,IAAI,CAAhCC,MAAM;IAAEC,QAAQ,GAAYF,IAAI,CAAxBE,QAAQ;IAAEC,KAAK,GAAKH,IAAI,CAAdG,KAAK;EAE/B,IACEC,SAAS,GAOPH,MAAM,CAPRG,SAAS;IACTC,SAAS,GAMPJ,MAAM,CANRI,SAAS;IACTC,QAAQ,GAKNL,MAAM,CALRK,QAAQ;IACRC,GAAG,GAIDN,MAAM,CAJRM,GAAG;IACHC,UAAU,GAGRP,MAAM,CAHRO,UAAU;IACVC,MAAM,GAEJR,MAAM,CAFRQ,MAAM;IACNC,IAAI,GACFT,MAAM,CADRS,IAAI;EAGN,IAAMC,aAAa,GAAGlB,qBAAqB,CAACU,KAAK,EAAEC,SAAS,CAAC;EAC7D,IAAMQ,cAAc,GAAGpB,MAAM,CAACc,QAAQ,CAACA,QAAQ,EAAE,SAAS,CAAC;EAC3D,IAAMO,YAAY,GAAGlB,iBAAiB,CAACiB,cAAc,CAAC;EACtD,IAAME,QAAQ,GAAGhB,eAAe,CAACK,KAAK,EAAEO,IAAI,CAAC;EAC7C,IAAMK,OAAO,GAAGzB,GAAG,CAACiB,GAAG,EAAE,uBAAuB,EAAE,kBAAkB,CAAC;EACrE,IAAMS,cAAc,GAAGP,MAAM,KAAK,QAAQ;EAC1C,IAAMQ,YAAY,GAAGvB,oBAAoB,CAACM,IAAI,CAAC;EAC/C,IAAMkB,aAAa,GAAGtB,gBAAgB,CAACa,MAAM,CAAC;EAC9C,IAAMU,WAAW,GAAGD,aAAa,CAACE,KAAK;EACvC,IAAMC,WAAW,GAAGF,WAAW,CAACG,KAAK;EACrC,IAAMC,UAAU,GAAGhC,SAAS,CAAC2B,aAAa,CAACM,IAAI,CAAC;EAChD,IAAMC,gBAAgB,GAAG5B,mBAAmB,CAAC;IAC3C6B,SAAS,EAAErB,SAAS;IACpBH,QAAQ,EAARA;EACF,CAAC,CAAC;EAEF,OAAO;IACLS,aAAa,EAAbA,aAAa;IACbE,YAAY,EAAZA,YAAY;IACZE,OAAO,EAAPA,OAAO;IACPD,QAAQ,EAARA,QAAQ;IACRE,cAAc,EAAdA,cAAc;IACdC,YAAY,EAAZA,YAAY;IACZT,UAAU,EAAVA,UAAU;IACVW,WAAW,EAAXA,WAAW;IACXE,WAAW,EAAXA,WAAW;IACXE,UAAU,EAAVA,UAAU;IACVE,gBAAgB,EAAhBA;EACF,CAAC;AACH","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["get","upperCase","moment","getAssigneesFullNames","getLocationReference","getPrettyDuration","getStatusDetails","getTimezoneDatetime","getUserFullName","getIssueDetails","data","entity","timezone","users","assignees","createdAt","duration","gps","templateRevision","sequenceId","status","user","assigneeNames","durationInMins","durationText","fullName","gpsText","isClosedStatus","locationText","statusDetails","statusStyle","style","statusColor","color","statusText","text","timezoneDatetime","timestamp"],"sources":["../../../src/helpers/get-issue-details/index.js"],"sourcesContent":["import { get, upperCase } from 'lodash'\nimport moment from 'moment-timezone'\n\nimport {\n getAssigneesFullNames,\n getLocationReference,\n getPrettyDuration,\n getStatusDetails,\n getTimezoneDatetime,\n getUserFullName,\n} from '../'\n\nexport function getIssueDetails(data) {\n const { entity, timezone, users } = data\n\n const {\n assignees,\n createdAt,\n duration,\n gps,\n templateRevision,\n sequenceId,\n status,\n user,\n } = entity\n\n const assigneeNames = getAssigneesFullNames(users, assignees)\n const durationInMins = moment.duration(duration, 'minutes')\n const durationText = getPrettyDuration(durationInMins)\n const fullName = getUserFullName(users, user)\n const gpsText = get(gps, 'reverseGeocoded.label', 'Unknown Location')\n const isClosedStatus = status === 'closed'\n const locationText = getLocationReference(data)\n const statusDetails = getStatusDetails(status)\n const statusStyle = statusDetails.style\n const statusColor = statusStyle.color\n const statusText = upperCase(statusDetails.text)\n const timezoneDatetime = getTimezoneDatetime({\n timestamp: createdAt,\n timezone,\n })\n\n return {\n assigneeNames,\n durationText,\n gpsText,\n fullName,\n isClosedStatus,\n locationText,\n templateRevision,\n sequenceId,\n statusStyle,\n statusColor,\n statusText,\n timezoneDatetime,\n }\n}\n"],"mappings":"AAAA,SAASA,GAAG,EAAEC,SAAS,QAAQ,QAAQ;AACvC,OAAOC,MAAM,MAAM,iBAAiB;AAEpC,SACEC,qBAAqB,EACrBC,oBAAoB,EACpBC,iBAAiB,EACjBC,gBAAgB,EAChBC,mBAAmB,EACnBC,eAAe,QACV,KAAK;AAEZ,OAAO,SAASC,eAAeA,CAACC,IAAI,EAAE;EACpC,IAAQC,MAAM,GAAsBD,IAAI,CAAhCC,MAAM;IAAEC,QAAQ,GAAYF,IAAI,CAAxBE,QAAQ;IAAEC,KAAK,GAAKH,IAAI,CAAdG,KAAK;EAE/B,IACEC,SAAS,GAQPH,MAAM,CARRG,SAAS;IACTC,SAAS,GAOPJ,MAAM,CAPRI,SAAS;IACTC,QAAQ,GAMNL,MAAM,CANRK,QAAQ;IACRC,GAAG,GAKDN,MAAM,CALRM,GAAG;IACHC,gBAAgB,GAIdP,MAAM,CAJRO,gBAAgB;IAChBC,UAAU,GAGRR,MAAM,CAHRQ,UAAU;IACVC,MAAM,GAEJT,MAAM,CAFRS,MAAM;IACNC,IAAI,GACFV,MAAM,CADRU,IAAI;EAGN,IAAMC,aAAa,GAAGnB,qBAAqB,CAACU,KAAK,EAAEC,SAAS,CAAC;EAC7D,IAAMS,cAAc,GAAGrB,MAAM,CAACc,QAAQ,CAACA,QAAQ,EAAE,SAAS,CAAC;EAC3D,IAAMQ,YAAY,GAAGnB,iBAAiB,CAACkB,cAAc,CAAC;EACtD,IAAME,QAAQ,GAAGjB,eAAe,CAACK,KAAK,EAAEQ,IAAI,CAAC;EAC7C,IAAMK,OAAO,GAAG1B,GAAG,CAACiB,GAAG,EAAE,uBAAuB,EAAE,kBAAkB,CAAC;EACrE,IAAMU,cAAc,GAAGP,MAAM,KAAK,QAAQ;EAC1C,IAAMQ,YAAY,GAAGxB,oBAAoB,CAACM,IAAI,CAAC;EAC/C,IAAMmB,aAAa,GAAGvB,gBAAgB,CAACc,MAAM,CAAC;EAC9C,IAAMU,WAAW,GAAGD,aAAa,CAACE,KAAK;EACvC,IAAMC,WAAW,GAAGF,WAAW,CAACG,KAAK;EACrC,IAAMC,UAAU,GAAGjC,SAAS,CAAC4B,aAAa,CAACM,IAAI,CAAC;EAChD,IAAMC,gBAAgB,GAAG7B,mBAAmB,CAAC;IAC3C8B,SAAS,EAAEtB,SAAS;IACpBH,QAAQ,EAARA;EACF,CAAC,CAAC;EAEF,OAAO;IACLU,aAAa,EAAbA,aAAa;IACbE,YAAY,EAAZA,YAAY;IACZE,OAAO,EAAPA,OAAO;IACPD,QAAQ,EAARA,QAAQ;IACRE,cAAc,EAAdA,cAAc;IACdC,YAAY,EAAZA,YAAY;IACZV,gBAAgB,EAAhBA,gBAAgB;IAChBC,UAAU,EAAVA,UAAU;IACVW,WAAW,EAAXA,WAAW;IACXE,WAAW,EAAXA,WAAW;IACXE,UAAU,EAAVA,UAAU;IACVE,gBAAgB,EAAhBA;EACF,CAAC;AACH","ignoreList":[]}