@lighthouse/common 5.0.0-canary-11 → 5.0.0-canary-13

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 (91) 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 +9 -9
  4. package/dist/helpers/fetch-image-for-web/index.js +3 -14
  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/dist/scheduling/scheduling.types.js +9 -9
  10. package/dist/service-hours/schema.js +12 -12
  11. package/lib/errors/DomainError.js +7 -8
  12. package/lib/errors/DomainError.js.map +1 -1
  13. package/lib/errors/ValidationError.js +11 -9
  14. package/lib/errors/ValidationError.js.map +1 -1
  15. package/lib/helpers/build-fetch-url/index.js +2 -2
  16. package/lib/helpers/build-fetch-url/index.js.map +1 -1
  17. package/lib/helpers/fetch-image/index.js +1 -1
  18. package/lib/helpers/fetch-image/index.js.map +1 -1
  19. package/lib/helpers/fetch-image-for-pdf-generator-service/index.js +174 -180
  20. package/lib/helpers/fetch-image-for-pdf-generator-service/index.js.map +1 -1
  21. package/lib/helpers/fetch-image-for-web/index.js +60 -74
  22. package/lib/helpers/fetch-image-for-web/index.js.map +1 -1
  23. package/lib/helpers/fetch-lighthouse-logo/index.js +41 -43
  24. package/lib/helpers/fetch-lighthouse-logo/index.js.map +1 -1
  25. package/lib/helpers/get-audit-entry-details/index.js +2 -0
  26. package/lib/helpers/get-audit-entry-details/index.js.map +1 -1
  27. package/lib/helpers/get-audit-items-data/index.js +8 -8
  28. package/lib/helpers/get-audit-items-data/index.js.map +1 -1
  29. package/lib/helpers/get-issue-details/index.js +2 -0
  30. package/lib/helpers/get-issue-details/index.js.map +1 -1
  31. package/lib/helpers/get-job-details/index.js.map +1 -1
  32. package/lib/helpers/get-location-reference/index.js +6 -4
  33. package/lib/helpers/get-location-reference/index.js.map +1 -1
  34. package/lib/helpers/get-reference-details/index.js.map +1 -1
  35. package/lib/helpers/get-task-entry-details/index.js +3 -1
  36. package/lib/helpers/get-task-entry-details/index.js.map +1 -1
  37. package/lib/helpers/get-timezone-datetime/index.js.map +1 -1
  38. package/lib/pdf/activity-report/index.js +299 -311
  39. package/lib/pdf/activity-report/index.js.map +1 -1
  40. package/lib/pdf/audit/index.js.map +1 -1
  41. package/lib/pdf/helpers/build-audit-content/index.js.map +1 -1
  42. package/lib/pdf/helpers/build-audit-follow-ups/index.js.map +1 -1
  43. package/lib/pdf/helpers/build-location-scans-content/index.js.map +1 -1
  44. package/lib/pdf/helpers/build-template-content/index.js.map +1 -1
  45. package/lib/pdf/helpers/fields/index.js +14 -14
  46. package/lib/pdf/helpers/fields/index.js.map +1 -1
  47. package/lib/pdf/helpers/generate-definition/index.js.map +1 -1
  48. package/lib/pdf/helpers/horizontal-line/index.js.map +1 -1
  49. package/lib/pdf/helpers/html-transformer/index.js +1 -2
  50. package/lib/pdf/helpers/html-transformer/index.js.map +1 -1
  51. package/lib/pdf/helpers/table/index.js +63 -65
  52. package/lib/pdf/helpers/table/index.js.map +1 -1
  53. package/lib/pdf/issue/index.js.map +1 -1
  54. package/lib/pdf/job/index.js.map +1 -1
  55. package/lib/pdf/shift-report/index.js +275 -291
  56. package/lib/pdf/shift-report/index.js.map +1 -1
  57. package/lib/pdf/task/index.js.map +1 -1
  58. package/lib/scheduling/generators/occurrenceIntervalsGenerator.js +27 -30
  59. package/lib/scheduling/generators/occurrenceIntervalsGenerator.js.map +1 -1
  60. package/lib/scheduling/generators/scheduleIntervalsGenerator.js +19 -21
  61. package/lib/scheduling/generators/scheduleIntervalsGenerator.js.map +1 -1
  62. package/lib/scheduling/generators/serviceIntervalsGenerator.js +134 -136
  63. package/lib/scheduling/generators/serviceIntervalsGenerator.js.map +1 -1
  64. package/lib/scheduling/helpers/generateNonRepeatingSchedule.js +81 -83
  65. package/lib/scheduling/helpers/generateNonRepeatingSchedule.js.map +1 -1
  66. package/lib/scheduling/helpers/generateRepeatingSchedule.js +104 -106
  67. package/lib/scheduling/helpers/generateRepeatingSchedule.js.map +1 -1
  68. package/lib/scheduling/helpers/generateScheduleEnd.js.map +1 -1
  69. package/lib/scheduling/helpers/mergeIntervals.js.map +1 -1
  70. package/lib/scheduling/scheduling.types.js +9 -9
  71. package/lib/scheduling/scheduling.types.js.map +1 -1
  72. package/lib/scheduling/strategies/getNext.js +21 -17
  73. package/lib/scheduling/strategies/getNext.js.map +1 -1
  74. package/lib/scheduling/strategies/getNextExactDateOfMonth.js +21 -18
  75. package/lib/scheduling/strategies/getNextExactDateOfMonth.js.map +1 -1
  76. package/lib/scheduling/strategies/getNextLastDayOfMonth.js +20 -17
  77. package/lib/scheduling/strategies/getNextLastDayOfMonth.js.map +1 -1
  78. package/lib/scheduling/strategies/getNextLastWeekdayOfMonth.js +20 -17
  79. package/lib/scheduling/strategies/getNextLastWeekdayOfMonth.js.map +1 -1
  80. package/lib/scheduling/strategies/getNextNoRepeat.js +15 -14
  81. package/lib/scheduling/strategies/getNextNoRepeat.js.map +1 -1
  82. package/lib/scheduling/strategies/getNextWeekday.js +36 -33
  83. package/lib/scheduling/strategies/getNextWeekday.js.map +1 -1
  84. package/lib/scheduling/strategies/getNextXDayOfXWeekOfMonth.js +20 -17
  85. package/lib/scheduling/strategies/getNextXDayOfXWeekOfMonth.js.map +1 -1
  86. package/lib/schema/schema.js +21 -23
  87. package/lib/schema/schema.js.map +1 -1
  88. package/lib/service-hours/schema.js +15 -13
  89. package/lib/service-hours/schema.js.map +1 -1
  90. package/package.json +2 -2
  91. package/yarn-error.log +0 -13549
@@ -1,5 +1,5 @@
1
- import _regeneratorRuntime from "@babel/runtime/regenerator";
2
1
  import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
2
+ import _regeneratorRuntime from "@babel/runtime/regenerator";
3
3
  import { validateBase64Image } from '../image-validators';
4
4
  import AWS from 'aws-sdk';
5
5
  var REGION = process.env.AWS_REGION;
@@ -11,96 +11,94 @@ var s3 = new AWS.S3({
11
11
  });
12
12
  export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
13
13
  var _ref = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee(url) {
14
- var urlMatch, applicationId, keyWithTransformations, alreadyTransformedImage, fullDataUrl, keyWithoutTransformations, transformerResponse, statusCode, _fullDataUrl, _transformerResponse$, redirectLocation, newlyTransformedImage, _fullDataUrl2;
15
- return _regeneratorRuntime.wrap(function _callee$(_context) {
16
- while (1) {
17
- switch (_context.prev = _context.next) {
18
- case 0:
19
- console.info('Fetching image via CloudFront For Serverless Pdf Generator Service');
20
- if (url) {
21
- _context.next = 3;
22
- break;
23
- }
24
- throw new Error('URL is required to fetch image for PDF generator service');
25
- case 3:
26
- urlMatch = url && url.match(/([a-f0-9]{24})\//);
27
- applicationId = urlMatch && urlMatch[1];
28
- if (applicationId) {
29
- _context.next = 7;
30
- break;
31
- }
32
- throw new Error('Requestor has insufficient permissions');
33
- case 7:
34
- keyWithTransformations = url.substring(url.indexOf(applicationId));
35
- _context.next = 10;
36
- return fetchResourceFromS3({
37
- bucketName: "".concat(process.env.S3_BUCKET_UPLOADS, "-transformed"),
38
- key: keyWithTransformations
39
- });
40
- case 10:
41
- alreadyTransformedImage = _context.sent;
42
- if (!(alreadyTransformedImage && alreadyTransformedImage.body)) {
43
- _context.next = 14;
44
- break;
45
- }
46
- fullDataUrl = formatBase64Image({
47
- base64String: alreadyTransformedImage.body.toString('base64'),
48
- key: keyWithTransformations
49
- });
50
- return _context.abrupt("return", fullDataUrl);
51
- case 14:
52
- keyWithoutTransformations = "/".concat(keyWithTransformations.split('?')[0]);
53
- _context.next = 17;
54
- return requestImageTransformation(keyWithoutTransformations);
55
- case 17:
56
- transformerResponse = _context.sent;
57
- statusCode = transformerResponse.statusCode;
58
- _context.t0 = statusCode;
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;
14
+ var urlMatch, applicationId, keyWithTransformations, alreadyTransformedImage, fullDataUrl, keyWithoutTransformations, transformerResponse, statusCode, _fullDataUrl, _transformerResponse$, redirectLocation, newlyTransformedImage, _fullDataUrl2, _t;
15
+ return _regeneratorRuntime.wrap(function (_context) {
16
+ while (1) switch (_context.prev = _context.next) {
17
+ case 0:
18
+ console.debug('Fetching image via CloudFront For Serverless Pdf Generator Service');
19
+ if (url) {
20
+ _context.next = 1;
60
21
  break;
61
- case 22:
62
- console.log('Image transformation successful');
63
- _fullDataUrl = formatBase64Image({
64
- base64String: transformerResponse.body.toString('base64'),
65
- key: keyWithTransformations
66
- });
67
- return _context.abrupt("return", _fullDataUrl);
68
- case 25:
69
- console.log('Image transformation successful but image is too big for lambda delivery, fetching directly from S3');
70
- redirectLocation = (_transformerResponse$ = transformerResponse.headers) === null || _transformerResponse$ === void 0 ? void 0 : _transformerResponse$.Location;
71
- if (!redirectLocation) {
72
- _context.next = 34;
73
- break;
74
- }
75
- _context.next = 30;
76
- return fetchResourceFromS3({
77
- bucketName: "".concat(process.env.S3_BUCKET_UPLOADS, "-transformed"),
78
- key: keyWithTransformations
79
- });
80
- case 30:
81
- newlyTransformedImage = _context.sent;
82
- console.log('Image successfully fetched from S3 at:', redirectLocation);
83
- _fullDataUrl2 = formatBase64Image({
84
- base64String: newlyTransformedImage.body.toString('base64'),
85
- key: keyWithTransformations
86
- });
87
- return _context.abrupt("return", _fullDataUrl2);
88
- case 34:
89
- throw new Error('Redirect response received but no location provided');
90
- case 35:
91
- throw new Error("Bad request to image transformer: ".concat(transformerResponse.body));
92
- case 36:
93
- throw new Error('Requested transformed image is too big');
94
- case 37:
95
- throw new Error('The requested image does not exist');
96
- case 38:
97
- throw new Error("Image transformation failed: ".concat(transformerResponse.body));
98
- case 39:
99
- throw new Error("Unexpected response from image transformer: ".concat(statusCode, " - ").concat(transformerResponse.body));
100
- case 40:
101
- case "end":
102
- return _context.stop();
103
- }
22
+ }
23
+ throw new Error('URL is required to fetch image for PDF generator service');
24
+ case 1:
25
+ urlMatch = url && url.match(/([a-f0-9]{24})\//);
26
+ applicationId = urlMatch && urlMatch[1];
27
+ if (applicationId) {
28
+ _context.next = 2;
29
+ break;
30
+ }
31
+ throw new Error('Requestor has insufficient permissions');
32
+ case 2:
33
+ keyWithTransformations = url.substring(url.indexOf(applicationId));
34
+ _context.next = 3;
35
+ return fetchResourceFromS3({
36
+ bucketName: "".concat(process.env.S3_BUCKET_UPLOADS, "-transformed"),
37
+ key: keyWithTransformations
38
+ });
39
+ case 3:
40
+ alreadyTransformedImage = _context.sent;
41
+ if (!(alreadyTransformedImage !== null && alreadyTransformedImage !== void 0 && alreadyTransformedImage.body)) {
42
+ _context.next = 4;
43
+ break;
44
+ }
45
+ fullDataUrl = formatBase64Image({
46
+ base64String: alreadyTransformedImage.body.toString('base64'),
47
+ key: keyWithTransformations
48
+ });
49
+ return _context.abrupt("return", fullDataUrl);
50
+ case 4:
51
+ keyWithoutTransformations = "/".concat(keyWithTransformations.split('?')[0]);
52
+ _context.next = 5;
53
+ return requestImageTransformation(keyWithoutTransformations);
54
+ case 5:
55
+ transformerResponse = _context.sent;
56
+ statusCode = transformerResponse.statusCode;
57
+ _t = statusCode;
58
+ _context.next = _t === 200 ? 6 : _t === 302 ? 7 : _t === 400 ? 10 : _t === 403 ? 11 : _t === 404 ? 12 : _t === 500 ? 13 : 14;
59
+ break;
60
+ case 6:
61
+ console.debug('Image transformation successful');
62
+ _fullDataUrl = formatBase64Image({
63
+ base64String: transformerResponse.body.toString('base64'),
64
+ key: keyWithTransformations
65
+ });
66
+ return _context.abrupt("return", _fullDataUrl);
67
+ case 7:
68
+ console.debug('Image transformation successful but image is too big for lambda delivery, fetching directly from S3');
69
+ redirectLocation = (_transformerResponse$ = transformerResponse.headers) === null || _transformerResponse$ === void 0 ? void 0 : _transformerResponse$.Location;
70
+ if (!redirectLocation) {
71
+ _context.next = 9;
72
+ break;
73
+ }
74
+ _context.next = 8;
75
+ return fetchResourceFromS3({
76
+ bucketName: "".concat(process.env.S3_BUCKET_UPLOADS, "-transformed"),
77
+ key: keyWithTransformations
78
+ });
79
+ case 8:
80
+ newlyTransformedImage = _context.sent;
81
+ console.debug('Image successfully fetched from S3 at:', redirectLocation);
82
+ _fullDataUrl2 = formatBase64Image({
83
+ base64String: newlyTransformedImage.body.toString('base64'),
84
+ key: keyWithTransformations
85
+ });
86
+ return _context.abrupt("return", _fullDataUrl2);
87
+ case 9:
88
+ throw new Error('Redirect response received but no location provided');
89
+ case 10:
90
+ throw new Error("Bad request to image transformer: ".concat(transformerResponse.body));
91
+ case 11:
92
+ throw new Error('Requested transformed image is too big');
93
+ case 12:
94
+ throw new Error('The requested image does not exist');
95
+ case 13:
96
+ throw new Error("Image transformation failed: ".concat(transformerResponse.body));
97
+ case 14:
98
+ throw new Error("Unexpected response from image transformer: ".concat(statusCode, " - ").concat(transformerResponse.body));
99
+ case 15:
100
+ case "end":
101
+ return _context.stop();
104
102
  }
105
103
  }, _callee);
106
104
  }));
@@ -113,50 +111,48 @@ export function requestImageTransformation(_x2) {
113
111
  }
114
112
  function _requestImageTransformation() {
115
113
  _requestImageTransformation = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee2(key) {
116
- var lambdaEvent, params, result, response, errorMessage;
117
- return _regeneratorRuntime.wrap(function _callee2$(_context2) {
118
- while (1) {
119
- switch (_context2.prev = _context2.next) {
120
- case 0:
121
- if (key) {
122
- _context2.next = 2;
123
- break;
124
- }
125
- throw new Error('Image Path is required for image transformation');
126
- case 2:
127
- console.log('ImageTransformation: Invoking image transformer lambda for path:', key);
128
- lambdaEvent = {
129
- requestContext: {
130
- http: {
131
- method: 'GET',
132
- path: key
133
- }
114
+ var lambdaEvent, params, result, response, errorMessage, _t2;
115
+ return _regeneratorRuntime.wrap(function (_context2) {
116
+ while (1) switch (_context2.prev = _context2.next) {
117
+ case 0:
118
+ if (key) {
119
+ _context2.next = 1;
120
+ break;
121
+ }
122
+ throw new Error('Image Path is required for image transformation');
123
+ case 1:
124
+ console.debug('ImageTransformation: Invoking image transformer lambda for path:', key);
125
+ lambdaEvent = {
126
+ requestContext: {
127
+ http: {
128
+ method: 'GET',
129
+ path: key
134
130
  }
135
- };
136
- params = {
137
- FunctionName: process.env.IMAGE_TRANSFORMER_ARN,
138
- InvocationType: 'RequestResponse',
139
- Payload: JSON.stringify(lambdaEvent)
140
- };
141
- _context2.prev = 5;
142
- _context2.next = 8;
143
- return lambda.invoke(params).promise();
144
- case 8:
145
- result = _context2.sent;
146
- response = JSON.parse(result.Payload);
147
- return _context2.abrupt("return", response);
148
- case 13:
149
- _context2.prev = 13;
150
- _context2.t0 = _context2["catch"](5);
151
- errorMessage = "Failed to invoke image transformer lambda: ".concat(_context2.t0.message);
152
- console.error(errorMessage, _context2.t0);
153
- throw new Error(errorMessage);
154
- case 18:
155
- case "end":
156
- return _context2.stop();
157
- }
131
+ }
132
+ };
133
+ params = {
134
+ FunctionName: process.env.IMAGE_TRANSFORMER_ARN,
135
+ InvocationType: 'RequestResponse',
136
+ Payload: JSON.stringify(lambdaEvent)
137
+ };
138
+ _context2.prev = 2;
139
+ _context2.next = 3;
140
+ return lambda.invoke(params).promise();
141
+ case 3:
142
+ result = _context2.sent;
143
+ response = JSON.parse(result.Payload);
144
+ return _context2.abrupt("return", response);
145
+ case 4:
146
+ _context2.prev = 4;
147
+ _t2 = _context2["catch"](2);
148
+ errorMessage = "Failed to invoke image transformer lambda: ".concat(_t2.message);
149
+ console.error(errorMessage, _t2);
150
+ throw new Error(errorMessage);
151
+ case 5:
152
+ case "end":
153
+ return _context2.stop();
158
154
  }
159
- }, _callee2, null, [[5, 13]]);
155
+ }, _callee2, null, [[2, 4]]);
160
156
  }));
161
157
  return _requestImageTransformation.apply(this, arguments);
162
158
  }
@@ -165,55 +161,53 @@ export function fetchResourceFromS3(_x3) {
165
161
  }
166
162
  function _fetchResourceFromS() {
167
163
  _fetchResourceFromS = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee3(_ref2) {
168
- var bucketName, key, params, result;
169
- return _regeneratorRuntime.wrap(function _callee3$(_context3) {
170
- while (1) {
171
- switch (_context3.prev = _context3.next) {
172
- case 0:
173
- bucketName = _ref2.bucketName, key = _ref2.key;
174
- console.info("Fetching resource from S3 Bucket: '".concat(bucketName, "' at path: '").concat(key, "'"));
175
- if (!(!bucketName || !key)) {
176
- _context3.next = 4;
177
- break;
178
- }
179
- throw new Error('bucketName and key are required for S3 resource fetch ' + JSON.stringify({
180
- bucketName: bucketName,
181
- key: key
182
- }));
183
- case 4:
184
- params = {
185
- Bucket: bucketName,
186
- Key: key
187
- };
188
- _context3.prev = 5;
189
- _context3.next = 8;
190
- return s3.getObject(params).promise();
191
- case 8:
192
- result = _context3.sent;
193
- return _context3.abrupt("return", {
194
- body: result.Body,
195
- contentType: result.ContentType,
196
- contentLength: result.ContentLength,
197
- lastModified: result.LastModified,
198
- etag: result.ETag
199
- });
200
- case 12:
201
- _context3.prev = 12;
202
- _context3.t0 = _context3["catch"](5);
203
- if (!(_context3.t0.code !== 'NoSuchKey')) {
204
- _context3.next = 17;
205
- break;
206
- }
207
- console.info('Failed to fetch image:', _context3.t0);
208
- throw new Error("Failed to fetch image: ".concat(bucketName, "/").concat(key));
209
- case 17:
210
- console.info('Image not found in transformed bucket, invoking transformer');
211
- case 18:
212
- case "end":
213
- return _context3.stop();
214
- }
164
+ var bucketName, key, params, result, _t3;
165
+ return _regeneratorRuntime.wrap(function (_context3) {
166
+ while (1) switch (_context3.prev = _context3.next) {
167
+ case 0:
168
+ bucketName = _ref2.bucketName, key = _ref2.key;
169
+ console.debug("Fetching resource from S3 Bucket: '".concat(bucketName, "' at path: '").concat(key, "'"));
170
+ if (!(!bucketName || !key)) {
171
+ _context3.next = 1;
172
+ break;
173
+ }
174
+ throw new Error('bucketName and key are required for S3 resource fetch ' + JSON.stringify({
175
+ bucketName: bucketName,
176
+ key: key
177
+ }));
178
+ case 1:
179
+ params = {
180
+ Bucket: bucketName,
181
+ Key: key
182
+ };
183
+ _context3.prev = 2;
184
+ _context3.next = 3;
185
+ return s3.getObject(params).promise();
186
+ case 3:
187
+ result = _context3.sent;
188
+ return _context3.abrupt("return", {
189
+ body: result.Body,
190
+ contentType: result.ContentType,
191
+ contentLength: result.ContentLength,
192
+ lastModified: result.LastModified,
193
+ etag: result.ETag
194
+ });
195
+ case 4:
196
+ _context3.prev = 4;
197
+ _t3 = _context3["catch"](2);
198
+ if (!(_t3.code !== 'NoSuchKey')) {
199
+ _context3.next = 5;
200
+ break;
201
+ }
202
+ console.error('Failed to fetch image:', _t3);
203
+ throw new Error("Failed to fetch image: ".concat(bucketName, "/").concat(key));
204
+ case 5:
205
+ console.debug('Image not found in transformed bucket, invoking transformer');
206
+ case 6:
207
+ case "end":
208
+ return _context3.stop();
215
209
  }
216
- }, _callee3, null, [[5, 12]]);
210
+ }, _callee3, null, [[2, 4]]);
217
211
  }));
218
212
  return _fetchResourceFromS.apply(this, arguments);
219
213
  }
@@ -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","_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_UPLOADS","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_UPLOADS}-transformed`,\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_UPLOADS}-transformed`,\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":[]}
@@ -1,91 +1,77 @@
1
- import _regeneratorRuntime from "@babel/runtime/regenerator";
2
1
  import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
3
- import _typeof from "@babel/runtime/helpers/typeof";
2
+ import _regeneratorRuntime from "@babel/runtime/regenerator";
4
3
  import { imageNotFound } from '../../images';
5
4
  import { fetchLighthouseLogo } from '../fetch-lighthouse-logo';
6
5
  import { arrayBufferToBase64 } from '../array-buffer-to-base-64';
7
6
  import { validateBase64Image } from '../image-validators';
8
- import fetchPonyfill from 'fetch-ponyfill';
9
7
  var contentTypes = {
10
8
  'image/png': 'png',
11
9
  'image/jpeg': 'jpeg'
12
10
  };
13
-
14
- // NOTE use the native fetch if it's available in the browser, because the
15
- // ponyfill (which actually uses the github polyfill) does not support all the
16
- // same options as native fetch
17
- var fetch = (typeof self === "undefined" ? "undefined" : _typeof(self)) === 'object' && self.fetch || fetchPonyfill({
18
- Promise: Promise
19
- }).fetch;
20
11
  export var fetchImageForWeb = /*#__PURE__*/function () {
21
12
  var _ref = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee(url, options) {
22
- var _options$isHeader, isHeader, Signature, Policy, KeyPairId, firstParamConnector, urlToEncode, encodedUrl, imageResponse, contentLengthHeader, contentType, imageType, logoArrayBuffer, base64Flag, imageStr, base64, isValid;
23
- return _regeneratorRuntime.wrap(function _callee$(_context) {
24
- while (1) {
25
- switch (_context.prev = _context.next) {
26
- case 0:
27
- _options$isHeader = options.isHeader, isHeader = _options$isHeader === void 0 ? false : _options$isHeader, Signature = options.Signature, Policy = options.Policy, KeyPairId = options.KeyPairId;
28
- _context.prev = 1;
29
- firstParamConnector = url.indexOf('?') > -1 ? '&' : '?';
30
- urlToEncode = "".concat(url).concat(firstParamConnector, "Signature=").concat(Signature, "&Policy=").concat(Policy, "&Key-Pair-Id=").concat(KeyPairId);
31
- encodedUrl = encodeURI(urlToEncode);
32
- console.info('Fetching image via CloudFront For Web');
13
+ var _options$isHeader, isHeader, Signature, Policy, KeyPairId, firstParamConnector, urlToEncode, encodedUrl, imageResponse, contentLengthHeader, contentType, imageType, logoArrayBuffer, base64Flag, imageStr, base64, isValid, _t;
14
+ return _regeneratorRuntime.wrap(function (_context) {
15
+ while (1) switch (_context.prev = _context.next) {
16
+ case 0:
17
+ _options$isHeader = options.isHeader, isHeader = _options$isHeader === void 0 ? false : _options$isHeader, Signature = options.Signature, Policy = options.Policy, KeyPairId = options.KeyPairId;
18
+ _context.prev = 1;
19
+ firstParamConnector = url.indexOf('?') > -1 ? '&' : '?';
20
+ urlToEncode = "".concat(url).concat(firstParamConnector, "Signature=").concat(Signature, "&Policy=").concat(Policy, "&Key-Pair-Id=").concat(KeyPairId);
21
+ encodedUrl = encodeURI(urlToEncode);
22
+ console.debug('Fetching image via CloudFront For Web');
23
+ _context.next = 2;
24
+ return fetch(encodedUrl);
25
+ case 2:
26
+ imageResponse = _context.sent;
27
+ contentLengthHeader = imageResponse.headers.get('content-length');
28
+ contentType = imageResponse.headers.get('content-type');
29
+ if (!(contentLengthHeader === '0')) {
30
+ _context.next = 3;
31
+ break;
32
+ }
33
+ return _context.abrupt("return", Promise.reject(new Error("Failed to fetch image as no content length: ".concat(encodedUrl))));
34
+ case 3:
35
+ if (imageResponse.ok) {
36
+ _context.next = 4;
37
+ break;
38
+ }
39
+ return _context.abrupt("return", Promise.reject(new Error("Failed to fetch image: ".concat(encodedUrl))));
40
+ case 4:
41
+ imageType = contentTypes[contentType];
42
+ _context.next = 5;
43
+ return imageResponse.arrayBuffer();
44
+ case 5:
45
+ logoArrayBuffer = _context.sent;
46
+ base64Flag = "data:image/".concat(imageType, ";base64,");
47
+ imageStr = arrayBufferToBase64(logoArrayBuffer);
48
+ base64 = "".concat(base64Flag).concat(imageStr);
49
+ isValid = validateBase64Image(base64);
50
+ if (isValid) {
51
+ _context.next = 6;
52
+ break;
53
+ }
54
+ throw new Error('InvalidImageError');
55
+ case 6:
56
+ return _context.abrupt("return", base64);
57
+ case 7:
58
+ _context.prev = 7;
59
+ _t = _context["catch"](1);
60
+ if (!isHeader) {
33
61
  _context.next = 8;
34
- return fetch(encodedUrl);
35
- case 8:
36
- imageResponse = _context.sent;
37
- contentLengthHeader = imageResponse.headers.get('content-length');
38
- contentType = imageResponse.headers.get('content-type');
39
- if (!(contentLengthHeader === '0')) {
40
- _context.next = 13;
41
- break;
42
- }
43
- return _context.abrupt("return", Promise.reject(new Error("Failed to fetch image as no content length: ".concat(encodedUrl))));
44
- case 13:
45
- if (imageResponse.ok) {
46
- _context.next = 15;
47
- break;
48
- }
49
- return _context.abrupt("return", Promise.reject(new Error("Failed to fetch image: ".concat(encodedUrl))));
50
- case 15:
51
- imageType = contentTypes[contentType];
52
- _context.next = 18;
53
- return imageResponse.arrayBuffer();
54
- case 18:
55
- logoArrayBuffer = _context.sent;
56
- base64Flag = "data:image/".concat(imageType, ";base64,");
57
- imageStr = arrayBufferToBase64(logoArrayBuffer);
58
- base64 = "".concat(base64Flag).concat(imageStr);
59
- isValid = validateBase64Image(base64);
60
- if (!isValid) {
61
- _context.next = 25;
62
- break;
63
- }
64
- return _context.abrupt("return", base64);
65
- case 25:
66
- _context.next = 34;
67
62
  break;
68
- case 27:
69
- _context.prev = 27;
70
- _context.t0 = _context["catch"](1);
71
- if (!isHeader) {
72
- _context.next = 32;
73
- break;
74
- }
75
- // NOTE: Replace failed headers with LH logo
76
- console.error('FetchImageHeaderError', _context.t0);
77
- return _context.abrupt("return", fetchLighthouseLogo());
78
- case 32:
79
- console.error(_context.t0);
80
- return _context.abrupt("return", imageNotFound);
81
- case 34:
82
- return _context.abrupt("return", Promise.reject(new Error('InvalidImageError')));
83
- case 35:
84
- case "end":
85
- return _context.stop();
86
- }
63
+ }
64
+ // NOTE: Replace failed headers with LH logo
65
+ console.error('FetchImageHeaderError', _t);
66
+ return _context.abrupt("return", fetchLighthouseLogo());
67
+ case 8:
68
+ console.error(_t);
69
+ return _context.abrupt("return", imageNotFound);
70
+ case 9:
71
+ case "end":
72
+ return _context.stop();
87
73
  }
88
- }, _callee, null, [[1, 27]]);
74
+ }, _callee, null, [[1, 7]]);
89
75
  }));
90
76
  return function fetchImageForWeb(_x, _x2) {
91
77
  return _ref.apply(this, arguments);