@lighthouse/common 6.2.0-canary.7 → 6.2.0-canary.9

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.
@@ -27,13 +27,10 @@ const fetchImageForPdfGeneratorService = async function (url) {
27
27
  if (!applicationId) {
28
28
  throw new Error('Requestor has insufficient permissions');
29
29
  }
30
- const {
31
- path,
32
- queryParams
33
- } = parseUrlString(url);
30
+ const keyWithTransformations = url.substring(url.indexOf(applicationId));
34
31
  const alreadyTransformedImage = await fetchResourceFromS3({
35
32
  bucketName: `${process.env.S3_BUCKET_IMAGE_TRANSFORMER_CACHE}`,
36
- key: `${path}/${queryParams}`
33
+ key: keyWithTransformations
37
34
  });
38
35
  if (alreadyTransformedImage?.body) {
39
36
  const fullDataUrl = formatBase64Image({
@@ -42,7 +39,7 @@ const fetchImageForPdfGeneratorService = async function (url) {
42
39
  });
43
40
  return fullDataUrl;
44
41
  }
45
- const transformerResponse = await requestImageTransformation(url);
42
+ const transformerResponse = await requestImageTransformation(keyWithTransformations);
46
43
  const statusCode = transformerResponse.statusCode;
47
44
  switch (statusCode) {
48
45
  case 200:
@@ -85,27 +82,60 @@ const fetchImageForPdfGeneratorService = async function (url) {
85
82
  }
86
83
  };
87
84
  exports.fetchImageForPdfGeneratorService = fetchImageForPdfGeneratorService;
88
- async function requestImageTransformation(key) {
89
- if (!key) {
90
- throw new Error('Image Path is required for image transformation');
85
+ async function requestImageTransformation(url) {
86
+ if (!url) {
87
+ throw new Error('Image URL is required for image transformation');
88
+ }
89
+ console.debug('ImageTransformation: Invoking image transformer lambda for URL:', url);
90
+
91
+ // Parse the URL to extract path and query parameters
92
+ const {
93
+ path,
94
+ queryParams
95
+ } = parseUrlString(url);
96
+
97
+ // Convert comma-separated params back to ampersand format for rawQueryString
98
+ const rawQueryString = queryParams ? queryParams.replace(/,/g, '&') : '';
99
+
100
+ // Convert comma-separated query params string into an object
101
+ const queryParamsObject = {};
102
+ if (queryParams) {
103
+ queryParams.split(',').forEach(param => {
104
+ const [key, value] = param.split('=');
105
+ if (key && value) {
106
+ queryParamsObject[key] = value;
107
+ }
108
+ });
91
109
  }
92
- console.debug('ImageTransformation: Invoking image transformer lambda for path:', key);
93
110
  const lambdaEvent = {
111
+ version: '2.0',
112
+ routeKey: '$default',
113
+ rawPath: `/${path}`,
114
+ rawQueryString: rawQueryString,
115
+ headers: {
116
+ 'user-agent': 'Amazon Lambda',
117
+ host: process.env.LAMBDA_URL_DOMAIN || 'lambda-url.us-east-1.on.aws'
118
+ },
119
+ queryStringParameters: Object.keys(queryParamsObject).length > 0 ? queryParamsObject : null,
94
120
  requestContext: {
121
+ routeKey: '$default',
122
+ stage: '$default',
95
123
  http: {
96
124
  method: 'GET',
97
- path: key
98
- }
99
- }
125
+ path: `/${path}`,
126
+ protocol: 'HTTP/1.1',
127
+ userAgent: 'Amazon Lambda'
128
+ },
129
+ time: new Date().toUTCString(),
130
+ timeEpoch: Date.now()
131
+ },
132
+ isBase64Encoded: false
100
133
  };
101
134
  const params = {
102
135
  FunctionName: process.env.IMAGE_TRANSFORMER_ARN,
103
136
  InvocationType: 'RequestResponse',
104
137
  Payload: JSON.stringify(lambdaEvent)
105
138
  };
106
- console.log({
107
- params
108
- });
109
139
  try {
110
140
  const result = await lambda.invoke(params).promise();
111
141
  const response = JSON.parse(result.Payload);
@@ -179,18 +209,31 @@ function parseUrlString(urlString) {
179
209
  if (!urlString || typeof urlString !== 'string') {
180
210
  throw new Error('URL string is required and must be a string');
181
211
  }
212
+
213
+ // Split on the first occurrence of '?' to separate path from query parameters
182
214
  const [path, queryString] = urlString.split('?');
183
215
  if (!path) {
184
216
  throw new Error('Invalid URL string: missing path component');
185
217
  }
218
+
219
+ // If there are no query parameters, return path with empty queryParams
186
220
  if (!queryString) {
187
- return `${path}`;
221
+ return {
222
+ path: path,
223
+ queryParams: ''
224
+ };
188
225
  }
189
226
 
190
227
  // Parse query parameters and convert to comma-separated format
191
- const queryParams = queryString.split('&').join(',');
228
+ const queryParams = queryString.split('&').map(param => {
229
+ // Handle parameters that might not have '=' (though uncommon)
230
+ if (!param.includes('=')) {
231
+ return param;
232
+ }
233
+ return param;
234
+ }).join(',');
192
235
  return {
193
- path,
194
- queryParams
236
+ path: path,
237
+ queryParams: queryParams
195
238
  };
196
239
  }
@@ -12,7 +12,7 @@ var s3 = new AWS.S3({
12
12
  });
13
13
  export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
14
14
  var _ref = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee(url) {
15
- var urlMatch, applicationId, _parseUrlString, path, queryParams, alreadyTransformedImage, fullDataUrl, transformerResponse, statusCode, _fullDataUrl, _transformerResponse$, redirectLocation, newlyTransformedImage, _fullDataUrl2, _t;
15
+ var urlMatch, applicationId, keyWithTransformations, alreadyTransformedImage, fullDataUrl, transformerResponse, statusCode, _fullDataUrl, _transformerResponse$, redirectLocation, newlyTransformedImage, _fullDataUrl2, _t;
16
16
  return _regeneratorRuntime.wrap(function (_context) {
17
17
  while (1) switch (_context.prev = _context.next) {
18
18
  case 0:
@@ -31,11 +31,11 @@ export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
31
31
  }
32
32
  throw new Error('Requestor has insufficient permissions');
33
33
  case 2:
34
- _parseUrlString = parseUrlString(url), path = _parseUrlString.path, queryParams = _parseUrlString.queryParams;
34
+ keyWithTransformations = url.substring(url.indexOf(applicationId));
35
35
  _context.next = 3;
36
36
  return fetchResourceFromS3({
37
37
  bucketName: "".concat(process.env.S3_BUCKET_IMAGE_TRANSFORMER_CACHE),
38
- key: "".concat(path, "/").concat(queryParams)
38
+ key: keyWithTransformations
39
39
  });
40
40
  case 3:
41
41
  alreadyTransformedImage = _context.sent;
@@ -50,7 +50,7 @@ export var fetchImageForPdfGeneratorService = /*#__PURE__*/function () {
50
50
  return _context.abrupt("return", fullDataUrl);
51
51
  case 4:
52
52
  _context.next = 5;
53
- return requestImageTransformation(url);
53
+ return requestImageTransformation(keyWithTransformations);
54
54
  case 5:
55
55
  transformerResponse = _context.sent;
56
56
  statusCode = transformerResponse.statusCode;
@@ -110,34 +110,63 @@ export function requestImageTransformation(_x2) {
110
110
  return _requestImageTransformation.apply(this, arguments);
111
111
  }
112
112
  function _requestImageTransformation() {
113
- _requestImageTransformation = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee2(key) {
114
- var lambdaEvent, params, result, response, errorMessage, _t2;
113
+ _requestImageTransformation = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee2(url) {
114
+ var _parseUrlString, path, queryParams, rawQueryString, queryParamsObject, lambdaEvent, params, result, response, errorMessage, _t2;
115
115
  return _regeneratorRuntime.wrap(function (_context2) {
116
116
  while (1) switch (_context2.prev = _context2.next) {
117
117
  case 0:
118
- if (key) {
118
+ if (url) {
119
119
  _context2.next = 1;
120
120
  break;
121
121
  }
122
- throw new Error('Image Path is required for image transformation');
122
+ throw new Error('Image URL is required for image transformation');
123
123
  case 1:
124
- console.debug('ImageTransformation: Invoking image transformer lambda for path:', key);
124
+ console.debug('ImageTransformation: Invoking image transformer lambda for URL:', url);
125
+
126
+ // Parse the URL to extract path and query parameters
127
+ _parseUrlString = parseUrlString(url), path = _parseUrlString.path, queryParams = _parseUrlString.queryParams; // Convert comma-separated params back to ampersand format for rawQueryString
128
+ rawQueryString = queryParams ? queryParams.replace(/,/g, '&') : ''; // Convert comma-separated query params string into an object
129
+ queryParamsObject = {};
130
+ if (queryParams) {
131
+ queryParams.split(',').forEach(function (param) {
132
+ var _param$split = param.split('='),
133
+ _param$split2 = _slicedToArray(_param$split, 2),
134
+ key = _param$split2[0],
135
+ value = _param$split2[1];
136
+ if (key && value) {
137
+ queryParamsObject[key] = value;
138
+ }
139
+ });
140
+ }
125
141
  lambdaEvent = {
142
+ version: '2.0',
143
+ routeKey: '$default',
144
+ rawPath: "/".concat(path),
145
+ rawQueryString: rawQueryString,
146
+ headers: {
147
+ 'user-agent': 'Amazon Lambda',
148
+ host: process.env.LAMBDA_URL_DOMAIN || 'lambda-url.us-east-1.on.aws'
149
+ },
150
+ queryStringParameters: Object.keys(queryParamsObject).length > 0 ? queryParamsObject : null,
126
151
  requestContext: {
152
+ routeKey: '$default',
153
+ stage: '$default',
127
154
  http: {
128
155
  method: 'GET',
129
- path: key
130
- }
131
- }
156
+ path: "/".concat(path),
157
+ protocol: 'HTTP/1.1',
158
+ userAgent: 'Amazon Lambda'
159
+ },
160
+ time: new Date().toUTCString(),
161
+ timeEpoch: Date.now()
162
+ },
163
+ isBase64Encoded: false
132
164
  };
133
165
  params = {
134
166
  FunctionName: process.env.IMAGE_TRANSFORMER_ARN,
135
167
  InvocationType: 'RequestResponse',
136
168
  Payload: JSON.stringify(lambdaEvent)
137
169
  };
138
- console.log({
139
- params: params
140
- });
141
170
  _context2.prev = 2;
142
171
  _context2.next = 3;
143
172
  return lambda.invoke(params).promise();
@@ -244,6 +273,8 @@ function parseUrlString(urlString) {
244
273
  if (!urlString || typeof urlString !== 'string') {
245
274
  throw new Error('URL string is required and must be a string');
246
275
  }
276
+
277
+ // Split on the first occurrence of '?' to separate path from query parameters
247
278
  var _urlString$split = urlString.split('?'),
248
279
  _urlString$split2 = _slicedToArray(_urlString$split, 2),
249
280
  path = _urlString$split2[0],
@@ -251,12 +282,23 @@ function parseUrlString(urlString) {
251
282
  if (!path) {
252
283
  throw new Error('Invalid URL string: missing path component');
253
284
  }
285
+
286
+ // If there are no query parameters, return path with empty queryParams
254
287
  if (!queryString) {
255
- return "".concat(path);
288
+ return {
289
+ path: path,
290
+ queryParams: ''
291
+ };
256
292
  }
257
293
 
258
294
  // Parse query parameters and convert to comma-separated format
259
- var queryParams = queryString.split('&').join(',');
295
+ var queryParams = queryString.split('&').map(function (param) {
296
+ // Handle parameters that might not have '=' (though uncommon)
297
+ if (!param.includes('=')) {
298
+ return param;
299
+ }
300
+ return param;
301
+ }).join(',');
260
302
  return {
261
303
  path: path,
262
304
  queryParams: queryParams
@@ -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","_parseUrlString","path","queryParams","alreadyTransformedImage","fullDataUrl","transformerResponse","statusCode","_fullDataUrl","_transformerResponse$","redirectLocation","newlyTransformedImage","_fullDataUrl2","_t","wrap","_context","prev","next","console","debug","Error","match","parseUrlString","fetchResourceFromS3","bucketName","concat","S3_BUCKET_IMAGE_TRANSFORMER_CACHE","key","sent","body","formatBase64Image","base64String","toString","keyWithTransformations","abrupt","requestImageTransformation","headers","Location","stop","_x","apply","arguments","_x2","_requestImageTransformation","_callee2","lambdaEvent","params","result","response","errorMessage","_t2","_context2","requestContext","http","method","FunctionName","IMAGE_TRANSFORMER_ARN","InvocationType","Payload","JSON","stringify","log","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","urlString","_urlString$split","split","_urlString$split2","_slicedToArray","queryString","join"],"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 { path, queryParams } = parseUrlString(url)\n\n const alreadyTransformedImage = await fetchResourceFromS3({\n bucketName: `${process.env.S3_BUCKET_IMAGE_TRANSFORMER_CACHE}`,\n key: `${path}/${queryParams}`,\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 transformerResponse = await requestImageTransformation(url)\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 console.log({ params })\n try {\n const result = await lambda.invoke(params).promise()\n\n const response = JSON.parse(result.Payload)\n\n return response\n } catch (error) {\n const errorMessage = `Failed to invoke image transformer lambda: ${error.message}`\n console.error(errorMessage, error)\n throw new Error(errorMessage)\n }\n}\n\nexport async function fetchResourceFromS3({ bucketName, key }) {\n console.debug(\n `Fetching resource from S3 Bucket: '${bucketName}' at path: '${key}'`\n )\n if (!bucketName || !key) {\n throw new Error(\n 'bucketName and key are required for S3 resource fetch ' +\n JSON.stringify({ bucketName, key })\n )\n }\n\n const params = {\n Bucket: bucketName,\n Key: key,\n }\n\n try {\n const result = await s3.getObject(params).promise()\n\n return {\n body: result.Body,\n contentType: result.ContentType,\n contentLength: result.ContentLength,\n lastModified: result.LastModified,\n etag: result.ETag,\n }\n } catch (error) {\n if (error.code !== 'NoSuchKey') {\n console.error('Failed to fetch image:', error)\n throw new Error(`Failed to fetch image: ${bucketName}/${key}`)\n }\n\n console.debug('Image not found in transformed bucket, invoking transformer')\n }\n}\n\nexport function formatBase64Image({ base64String, key }) {\n if (!key) {\n throw new Error('Key is required for image formatting')\n }\n\n const imageType = key.toLowerCase().includes('.png') ? 'png' : 'jpeg'\n const base64Flag = `data:image/${imageType};base64,`\n const fullDataUrl = `${base64Flag}${base64String}`\n\n // Validate the formatted data URL\n const isValid = validateBase64Image(fullDataUrl)\n if (!isValid) {\n throw new Error('InvalidImageError')\n }\n\n return fullDataUrl\n}\n\n/**\n * Parses a URL-like string into path and query parameters\n * @param {string} urlString - String like \"<applicationId>/<path>/filename.jpeg?width=100&height=100\"\n * @returns {Object} - Object with { path: string, queryParams: string }\n * @example\n * parseUrlString(\"abc123/folder/image.jpeg?width=100&height=100\")\n * // Returns: { path: \"abc123/folder/image.jpeg\", queryParams: \"width=100,height=100\" }\n */\nfunction parseUrlString(urlString) {\n if (!urlString || typeof urlString !== 'string') {\n throw new Error('URL string is required and must be a string')\n }\n\n const [path, queryString] = urlString.split('?')\n\n if (!path) {\n throw new Error('Invalid URL string: missing path component')\n }\n\n if (!queryString) {\n return `${path}`\n }\n\n // Parse query parameters and convert to comma-separated format\n const queryParams = queryString.split('&').join(',')\n\n return {\n path,\n queryParams,\n }\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","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","requestImageTransformation","headers","Location","stop","_x","apply","arguments","_x2","_requestImageTransformation","_callee2","_parseUrlString","path","queryParams","rawQueryString","queryParamsObject","lambdaEvent","params","result","response","errorMessage","_t2","_context2","parseUrlString","replace","split","forEach","param","_param$split","_param$split2","_slicedToArray","value","version","routeKey","rawPath","host","LAMBDA_URL_DOMAIN","queryStringParameters","Object","keys","length","requestContext","stage","http","method","protocol","userAgent","time","Date","toUTCString","timeEpoch","now","isBase64Encoded","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","urlString","_urlString$split","_urlString$split2","queryString","map","join"],"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 transformerResponse = await requestImageTransformation(\n keyWithTransformations\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(url) {\n if (!url) {\n throw new Error('Image URL is required for image transformation')\n }\n\n console.debug(\n 'ImageTransformation: Invoking image transformer lambda for URL:',\n url\n )\n\n // Parse the URL to extract path and query parameters\n const { path, queryParams } = parseUrlString(url)\n\n // Convert comma-separated params back to ampersand format for rawQueryString\n const rawQueryString = queryParams ? queryParams.replace(/,/g, '&') : ''\n\n // Convert comma-separated query params string into an object\n const queryParamsObject = {}\n if (queryParams) {\n queryParams.split(',').forEach((param) => {\n const [key, value] = param.split('=')\n if (key && value) {\n queryParamsObject[key] = value\n }\n })\n }\n\n const lambdaEvent = {\n version: '2.0',\n routeKey: '$default',\n rawPath: `/${path}`,\n rawQueryString: rawQueryString,\n headers: {\n 'user-agent': 'Amazon Lambda',\n host: process.env.LAMBDA_URL_DOMAIN || 'lambda-url.us-east-1.on.aws',\n },\n queryStringParameters:\n Object.keys(queryParamsObject).length > 0 ? queryParamsObject : null,\n requestContext: {\n routeKey: '$default',\n stage: '$default',\n http: {\n method: 'GET',\n path: `/${path}`,\n protocol: 'HTTP/1.1',\n userAgent: 'Amazon Lambda',\n },\n time: new Date().toUTCString(),\n timeEpoch: Date.now(),\n },\n isBase64Encoded: false,\n }\n\n const params = {\n FunctionName: process.env.IMAGE_TRANSFORMER_ARN,\n InvocationType: 'RequestResponse',\n Payload: JSON.stringify(lambdaEvent),\n }\n\n try {\n const result = await lambda.invoke(params).promise()\n\n const response = JSON.parse(result.Payload)\n\n return response\n } catch (error) {\n const errorMessage = `Failed to invoke image transformer lambda: ${error.message}`\n console.error(errorMessage, error)\n throw new Error(errorMessage)\n }\n}\n\nexport async function fetchResourceFromS3({ bucketName, key }) {\n console.debug(\n `Fetching resource from S3 Bucket: '${bucketName}' at path: '${key}'`\n )\n if (!bucketName || !key) {\n throw new Error(\n 'bucketName and key are required for S3 resource fetch ' +\n JSON.stringify({ bucketName, key })\n )\n }\n\n const params = {\n Bucket: bucketName,\n Key: key,\n }\n\n try {\n const result = await s3.getObject(params).promise()\n\n return {\n body: result.Body,\n contentType: result.ContentType,\n contentLength: result.ContentLength,\n lastModified: result.LastModified,\n etag: result.ETag,\n }\n } catch (error) {\n if (error.code !== 'NoSuchKey') {\n console.error('Failed to fetch image:', error)\n throw new Error(`Failed to fetch image: ${bucketName}/${key}`)\n }\n\n console.debug('Image not found in transformed bucket, invoking transformer')\n }\n}\n\nexport function formatBase64Image({ base64String, key }) {\n if (!key) {\n throw new Error('Key is required for image formatting')\n }\n\n const imageType = key.toLowerCase().includes('.png') ? 'png' : 'jpeg'\n const base64Flag = `data:image/${imageType};base64,`\n const fullDataUrl = `${base64Flag}${base64String}`\n\n // Validate the formatted data URL\n const isValid = validateBase64Image(fullDataUrl)\n if (!isValid) {\n throw new Error('InvalidImageError')\n }\n\n return fullDataUrl\n}\n\n/**\n * Parses a URL-like string into path and query parameters\n * @param {string} urlString - String like \"<applicationId>/<path>/filename.jpeg?width=100&height=100\"\n * @returns {Object} - Object with { path: string, queryParams: string }\n * @example\n * parseUrlString(\"abc123/folder/image.jpeg?width=100&height=100\")\n * // Returns: { path: \"abc123/folder/image.jpeg\", queryParams: \"width=100,height=100\" }\n */\nfunction parseUrlString(urlString) {\n if (!urlString || typeof urlString !== 'string') {\n throw new Error('URL string is required and must be a string')\n }\n\n // Split on the first occurrence of '?' to separate path from query parameters\n const [path, queryString] = urlString.split('?')\n\n if (!path) {\n throw new Error('Invalid URL string: missing path component')\n }\n\n // If there are no query parameters, return path with empty queryParams\n if (!queryString) {\n return {\n path: path,\n queryParams: '',\n }\n }\n\n // Parse query parameters and convert to comma-separated format\n const queryParams = queryString\n .split('&')\n .map((param) => {\n // Handle parameters that might not have '=' (though uncommon)\n if (!param.includes('=')) {\n return param\n }\n return param\n })\n .join(',')\n\n return {\n path: path,\n queryParams: queryParams,\n }\n}\n"],"mappings":";;;AAAA,SAASA,mBAAmB,QAAQ,qBAAqB;AACzD,OAAOC,GAAG,MAAM,SAAS;AACzB,IAAMC,MAAM,GAAGC,OAAO,CAACC,GAAG,CAACC,UAAU;AAErC,IAAMC,MAAM,GAAG,IAAIL,GAAG,CAACM,MAAM,CAAC;EAC5BC,MAAM,EAAEN;AACV,CAAC,CAAC;AACF,IAAMO,EAAE,GAAG,IAAIR,GAAG,CAACS,EAAE,CAAC;EACpBF,MAAM,EAAEN;AACV,CAAC,CAAC;AAEF,OAAO,IAAMS,gCAAgC;EAAA,IAAAC,IAAA,GAAAC,iBAAA,cAAAC,mBAAA,CAAAC,IAAA,CAAG,SAAAC,QAAgBC,GAAG;IAAA,IAAAC,QAAA,EAAAC,aAAA,EAAAC,sBAAA,EAAAC,uBAAA,EAAAC,WAAA,EAAAC,mBAAA,EAAAC,UAAA,EAAAC,YAAA,EAAAC,qBAAA,EAAAC,gBAAA,EAAAC,qBAAA,EAAAC,aAAA,EAAAC,EAAA;IAAA,OAAAhB,mBAAA,CAAAiB,IAAA,WAAAC,QAAA;MAAA,kBAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAAE,IAAA;QAAA;UACjEC,OAAO,CAACC,KAAK,CACX,oEACF,CAAC;UAAA,IAEInB,GAAG;YAAAe,QAAA,CAAAE,IAAA;YAAA;UAAA;UAAA,MACA,IAAIG,KAAK,CAAC,0DAA0D,CAAC;QAAA;UAGvEnB,QAAQ,GAAGD,GAAG,IAAIA,GAAG,CAACqB,KAAK,CAAC,kBAAkB,CAAC;UAC/CnB,aAAa,GAAGD,QAAQ,IAAIA,QAAQ,CAAC,CAAC,CAAC;UAAA,IAExCC,aAAa;YAAAa,QAAA,CAAAE,IAAA;YAAA;UAAA;UAAA,MACV,IAAIG,KAAK,CAAC,wCAAwC,CAAC;QAAA;UAGrDjB,sBAAsB,GAAGH,GAAG,CAACsB,SAAS,CAACtB,GAAG,CAACuB,OAAO,CAACrB,aAAa,CAAC,CAAC;UAAAa,QAAA,CAAAE,IAAA;UAAA,OAElCO,mBAAmB,CAAC;YACxDC,UAAU,KAAAC,MAAA,CAAKxC,OAAO,CAACC,GAAG,CAACwC,iCAAiC,CAAE;YAC9DC,GAAG,EAAEzB;UACP,CAAC,CAAC;QAAA;UAHIC,uBAAuB,GAAAW,QAAA,CAAAc,IAAA;UAAA,MAKzBzB,uBAAuB,aAAvBA,uBAAuB,eAAvBA,uBAAuB,CAAE0B,IAAI;YAAAf,QAAA,CAAAE,IAAA;YAAA;UAAA;UACzBZ,WAAW,GAAG0B,iBAAiB,CAAC;YACpCC,YAAY,EAAE5B,uBAAuB,CAAC0B,IAAI,CAACG,QAAQ,CAAC,QAAQ,CAAC;YAC7DL,GAAG,EAAEzB;UACP,CAAC,CAAC;UAAA,OAAAY,QAAA,CAAAmB,MAAA,WACK7B,WAAW;QAAA;UAAAU,QAAA,CAAAE,IAAA;UAAA,OAGckB,0BAA0B,CAC1DhC,sBACF,CAAC;QAAA;UAFKG,mBAAmB,GAAAS,QAAA,CAAAc,IAAA;UAInBtB,UAAU,GAAGD,mBAAmB,CAACC,UAAU;UAAAM,EAAA,GAEzCN,UAAU;UAAAQ,QAAA,CAAAE,IAAA,GAAAJ,EAAA,KACX,GAAG,OAAAA,EAAA,KAUH,GAAG,OAAAA,EAAA,KAwBH,GAAG,QAAAA,EAAA,KAIH,GAAG,QAAAA,EAAA,KAEH,GAAG,QAAAA,EAAA,KAEH,GAAG;UAAA;QAAA;UAzCNK,OAAO,CAACC,KAAK,CAAC,iCAAiC,CAAC;UAE1Cd,YAAW,GAAG0B,iBAAiB,CAAC;YACpCC,YAAY,EAAE1B,mBAAmB,CAACwB,IAAI,CAACG,QAAQ,CAAC,QAAQ,CAAC;YACzDL,GAAG,EAAEzB;UACP,CAAC,CAAC;UAAA,OAAAY,QAAA,CAAAmB,MAAA,WAEK7B,YAAW;QAAA;UAGlBa,OAAO,CAACC,KAAK,CACX,qGACF,CAAC;UACKT,gBAAgB,IAAAD,qBAAA,GAAGH,mBAAmB,CAAC8B,OAAO,cAAA3B,qBAAA,uBAA3BA,qBAAA,CAA6B4B,QAAQ;UAAA,KAC1D3B,gBAAgB;YAAAK,QAAA,CAAAE,IAAA;YAAA;UAAA;UAAAF,QAAA,CAAAE,IAAA;UAAA,OACkBO,mBAAmB,CAAC;YACtDC,UAAU,KAAAC,MAAA,CAAKxC,OAAO,CAACC,GAAG,CAACwC,iCAAiC,CAAE;YAC9DC,GAAG,EAAEzB;UACP,CAAC,CAAC;QAAA;UAHIQ,qBAAqB,GAAAI,QAAA,CAAAc,IAAA;UAI3BX,OAAO,CAACC,KAAK,CACX,wCAAwC,EACxCT,gBACF,CAAC;UAEKL,aAAW,GAAG0B,iBAAiB,CAAC;YACpCC,YAAY,EAAErB,qBAAqB,CAACmB,IAAI,CAACG,QAAQ,CAAC,QAAQ,CAAC;YAC3DL,GAAG,EAAEzB;UACP,CAAC,CAAC;UAAA,OAAAY,QAAA,CAAAmB,MAAA,WAEK7B,aAAW;QAAA;UAAA,MAEd,IAAIe,KAAK,CAAC,qDAAqD,CAAC;QAAA;UAAA,MAGhE,IAAIA,KAAK,sCAAAM,MAAA,CACwBpB,mBAAmB,CAACwB,IAAI,CAC/D,CAAC;QAAA;UAAA,MAEK,IAAIV,KAAK,CAAC,wCAAwC,CAAC;QAAA;UAAA,MAEnD,IAAIA,KAAK,CAAC,oCAAoC,CAAC;QAAA;UAAA,MAE/C,IAAIA,KAAK,iCAAAM,MAAA,CACmBpB,mBAAmB,CAACwB,IAAI,CAC1D,CAAC;QAAA;UAAA,MAEK,IAAIV,KAAK,gDAAAM,MAAA,CACkCnB,UAAU,SAAAmB,MAAA,CAAMpB,mBAAmB,CAACwB,IAAI,CACzF,CAAC;QAAA;QAAA;UAAA,OAAAf,QAAA,CAAAuB,IAAA;MAAA;IAAA,GAAAvC,OAAA;EAAA,CAEN;EAAA,gBAzFYL,gCAAgCA,CAAA6C,EAAA;IAAA,OAAA5C,IAAA,CAAA6C,KAAA,OAAAC,SAAA;EAAA;AAAA,GAyF5C;AAED,gBAAsBN,0BAA0BA,CAAAO,GAAA;EAAA,OAAAC,2BAAA,CAAAH,KAAA,OAAAC,SAAA;AAAA;AAsE/C,SAAAE,4BAAA;EAAAA,2BAAA,GAAA/C,iBAAA,cAAAC,mBAAA,CAAAC,IAAA,CAtEM,SAAA8C,SAA0C5C,GAAG;IAAA,IAAA6C,eAAA,EAAAC,IAAA,EAAAC,WAAA,EAAAC,cAAA,EAAAC,iBAAA,EAAAC,WAAA,EAAAC,MAAA,EAAAC,MAAA,EAAAC,QAAA,EAAAC,YAAA,EAAAC,GAAA;IAAA,OAAA1D,mBAAA,CAAAiB,IAAA,WAAA0C,SAAA;MAAA,kBAAAA,SAAA,CAAAxC,IAAA,GAAAwC,SAAA,CAAAvC,IAAA;QAAA;UAAA,IAC7CjB,GAAG;YAAAwD,SAAA,CAAAvC,IAAA;YAAA;UAAA;UAAA,MACA,IAAIG,KAAK,CAAC,gDAAgD,CAAC;QAAA;UAGnEF,OAAO,CAACC,KAAK,CACX,iEAAiE,EACjEnB,GACF,CAAC;;UAED;UAAA6C,eAAA,GAC8BY,cAAc,CAACzD,GAAG,CAAC,EAAzC8C,IAAI,GAAAD,eAAA,CAAJC,IAAI,EAAEC,WAAW,GAAAF,eAAA,CAAXE,WAAW,EAEzB;UACMC,cAAc,GAAGD,WAAW,GAAGA,WAAW,CAACW,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,GAAG,EAAE,EAExE;UACMT,iBAAiB,GAAG,CAAC,CAAC;UAC5B,IAAIF,WAAW,EAAE;YACfA,WAAW,CAACY,KAAK,CAAC,GAAG,CAAC,CAACC,OAAO,CAAC,UAACC,KAAK,EAAK;cACxC,IAAAC,YAAA,GAAqBD,KAAK,CAACF,KAAK,CAAC,GAAG,CAAC;gBAAAI,aAAA,GAAAC,cAAA,CAAAF,YAAA;gBAA9BlC,GAAG,GAAAmC,aAAA;gBAAEE,KAAK,GAAAF,aAAA;cACjB,IAAInC,GAAG,IAAIqC,KAAK,EAAE;gBAChBhB,iBAAiB,CAACrB,GAAG,CAAC,GAAGqC,KAAK;cAChC;YACF,CAAC,CAAC;UACJ;UAEMf,WAAW,GAAG;YAClBgB,OAAO,EAAE,KAAK;YACdC,QAAQ,EAAE,UAAU;YACpBC,OAAO,MAAA1C,MAAA,CAAMoB,IAAI,CAAE;YACnBE,cAAc,EAAEA,cAAc;YAC9BZ,OAAO,EAAE;cACP,YAAY,EAAE,eAAe;cAC7BiC,IAAI,EAAEnF,OAAO,CAACC,GAAG,CAACmF,iBAAiB,IAAI;YACzC,CAAC;YACDC,qBAAqB,EACnBC,MAAM,CAACC,IAAI,CAACxB,iBAAiB,CAAC,CAACyB,MAAM,GAAG,CAAC,GAAGzB,iBAAiB,GAAG,IAAI;YACtE0B,cAAc,EAAE;cACdR,QAAQ,EAAE,UAAU;cACpBS,KAAK,EAAE,UAAU;cACjBC,IAAI,EAAE;gBACJC,MAAM,EAAE,KAAK;gBACbhC,IAAI,MAAApB,MAAA,CAAMoB,IAAI,CAAE;gBAChBiC,QAAQ,EAAE,UAAU;gBACpBC,SAAS,EAAE;cACb,CAAC;cACDC,IAAI,EAAE,IAAIC,IAAI,CAAC,CAAC,CAACC,WAAW,CAAC,CAAC;cAC9BC,SAAS,EAAEF,IAAI,CAACG,GAAG,CAAC;YACtB,CAAC;YACDC,eAAe,EAAE;UACnB,CAAC;UAEKnC,MAAM,GAAG;YACboC,YAAY,EAAErG,OAAO,CAACC,GAAG,CAACqG,qBAAqB;YAC/CC,cAAc,EAAE,iBAAiB;YACjCC,OAAO,EAAEC,IAAI,CAACC,SAAS,CAAC1C,WAAW;UACrC,CAAC;UAAAM,SAAA,CAAAxC,IAAA;UAAAwC,SAAA,CAAAvC,IAAA;UAAA,OAGsB5B,MAAM,CAACwG,MAAM,CAAC1C,MAAM,CAAC,CAAC2C,OAAO,CAAC,CAAC;QAAA;UAA9C1C,MAAM,GAAAI,SAAA,CAAA3B,IAAA;UAENwB,QAAQ,GAAGsC,IAAI,CAACI,KAAK,CAAC3C,MAAM,CAACsC,OAAO,CAAC;UAAA,OAAAlC,SAAA,CAAAtB,MAAA,WAEpCmB,QAAQ;QAAA;UAAAG,SAAA,CAAAxC,IAAA;UAAAuC,GAAA,GAAAC,SAAA;UAETF,YAAY,iDAAA5B,MAAA,CAAiD6B,GAAA,CAAMyC,OAAO;UAChF9E,OAAO,CAAC+E,KAAK,CAAC3C,YAAY,EAAAC,GAAO,CAAC;UAAA,MAC5B,IAAInC,KAAK,CAACkC,YAAY,CAAC;QAAA;QAAA;UAAA,OAAAE,SAAA,CAAAlB,IAAA;MAAA;IAAA,GAAAM,QAAA;EAAA,CAEhC;EAAA,OAAAD,2BAAA,CAAAH,KAAA,OAAAC,SAAA;AAAA;AAED,gBAAsBjB,mBAAmBA,CAAA0E,GAAA;EAAA,OAAAC,mBAAA,CAAA3D,KAAA,OAAAC,SAAA;AAAA;AAkCxC,SAAA0D,oBAAA;EAAAA,mBAAA,GAAAvG,iBAAA,cAAAC,mBAAA,CAAAC,IAAA,CAlCM,SAAAsG,SAAAC,KAAA;IAAA,IAAA5E,UAAA,EAAAG,GAAA,EAAAuB,MAAA,EAAAC,MAAA,EAAAkD,GAAA;IAAA,OAAAzG,mBAAA,CAAAiB,IAAA,WAAAyF,SAAA;MAAA,kBAAAA,SAAA,CAAAvF,IAAA,GAAAuF,SAAA,CAAAtF,IAAA;QAAA;UAAqCQ,UAAU,GAAA4E,KAAA,CAAV5E,UAAU,EAAEG,GAAG,GAAAyE,KAAA,CAAHzE,GAAG;UACzDV,OAAO,CAACC,KAAK,uCAAAO,MAAA,CAC2BD,UAAU,kBAAAC,MAAA,CAAeE,GAAG,MACpE,CAAC;UAAA,MACG,CAACH,UAAU,IAAI,CAACG,GAAG;YAAA2E,SAAA,CAAAtF,IAAA;YAAA;UAAA;UAAA,MACf,IAAIG,KAAK,CACb,wDAAwD,GACtDuE,IAAI,CAACC,SAAS,CAAC;YAAEnE,UAAU,EAAVA,UAAU;YAAEG,GAAG,EAAHA;UAAI,CAAC,CACtC,CAAC;QAAA;UAGGuB,MAAM,GAAG;YACbqD,MAAM,EAAE/E,UAAU;YAClBgF,GAAG,EAAE7E;UACP,CAAC;UAAA2E,SAAA,CAAAvF,IAAA;UAAAuF,SAAA,CAAAtF,IAAA;UAAA,OAGsBzB,EAAE,CAACkH,SAAS,CAACvD,MAAM,CAAC,CAAC2C,OAAO,CAAC,CAAC;QAAA;UAA7C1C,MAAM,GAAAmD,SAAA,CAAA1E,IAAA;UAAA,OAAA0E,SAAA,CAAArE,MAAA,WAEL;YACLJ,IAAI,EAAEsB,MAAM,CAACuD,IAAI;YACjBC,WAAW,EAAExD,MAAM,CAACyD,WAAW;YAC/BC,aAAa,EAAE1D,MAAM,CAAC2D,aAAa;YACnCC,YAAY,EAAE5D,MAAM,CAAC6D,YAAY;YACjCC,IAAI,EAAE9D,MAAM,CAAC+D;UACf,CAAC;QAAA;UAAAZ,SAAA,CAAAvF,IAAA;UAAAsF,GAAA,GAAAC,SAAA;UAAA,MAEGD,GAAA,CAAMc,IAAI,KAAK,WAAW;YAAAb,SAAA,CAAAtF,IAAA;YAAA;UAAA;UAC5BC,OAAO,CAAC+E,KAAK,CAAC,wBAAwB,EAAAK,GAAO,CAAC;UAAA,MACxC,IAAIlF,KAAK,2BAAAM,MAAA,CAA2BD,UAAU,OAAAC,MAAA,CAAIE,GAAG,CAAE,CAAC;QAAA;UAGhEV,OAAO,CAACC,KAAK,CAAC,6DAA6D,CAAC;QAAA;QAAA;UAAA,OAAAoF,SAAA,CAAAjE,IAAA;MAAA;IAAA,GAAA8D,QAAA;EAAA,CAE/E;EAAA,OAAAD,mBAAA,CAAA3D,KAAA,OAAAC,SAAA;AAAA;AAED,OAAO,SAASV,iBAAiBA,CAAAsF,KAAA,EAAwB;EAAA,IAArBrF,YAAY,GAAAqF,KAAA,CAAZrF,YAAY;IAAEJ,GAAG,GAAAyF,KAAA,CAAHzF,GAAG;EACnD,IAAI,CAACA,GAAG,EAAE;IACR,MAAM,IAAIR,KAAK,CAAC,sCAAsC,CAAC;EACzD;EAEA,IAAMkG,SAAS,GAAG1F,GAAG,CAAC2F,WAAW,CAAC,CAAC,CAACC,QAAQ,CAAC,MAAM,CAAC,GAAG,KAAK,GAAG,MAAM;EACrE,IAAMC,UAAU,iBAAA/F,MAAA,CAAiB4F,SAAS,aAAU;EACpD,IAAMjH,WAAW,MAAAqB,MAAA,CAAM+F,UAAU,EAAA/F,MAAA,CAAGM,YAAY,CAAE;;EAElD;EACA,IAAM0F,OAAO,GAAG3I,mBAAmB,CAACsB,WAAW,CAAC;EAChD,IAAI,CAACqH,OAAO,EAAE;IACZ,MAAM,IAAItG,KAAK,CAAC,mBAAmB,CAAC;EACtC;EAEA,OAAOf,WAAW;AACpB;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAASoD,cAAcA,CAACkE,SAAS,EAAE;EACjC,IAAI,CAACA,SAAS,IAAI,OAAOA,SAAS,KAAK,QAAQ,EAAE;IAC/C,MAAM,IAAIvG,KAAK,CAAC,6CAA6C,CAAC;EAChE;;EAEA;EACA,IAAAwG,gBAAA,GAA4BD,SAAS,CAAChE,KAAK,CAAC,GAAG,CAAC;IAAAkE,iBAAA,GAAA7D,cAAA,CAAA4D,gBAAA;IAAzC9E,IAAI,GAAA+E,iBAAA;IAAEC,WAAW,GAAAD,iBAAA;EAExB,IAAI,CAAC/E,IAAI,EAAE;IACT,MAAM,IAAI1B,KAAK,CAAC,4CAA4C,CAAC;EAC/D;;EAEA;EACA,IAAI,CAAC0G,WAAW,EAAE;IAChB,OAAO;MACLhF,IAAI,EAAEA,IAAI;MACVC,WAAW,EAAE;IACf,CAAC;EACH;;EAEA;EACA,IAAMA,WAAW,GAAG+E,WAAW,CAC5BnE,KAAK,CAAC,GAAG,CAAC,CACVoE,GAAG,CAAC,UAAClE,KAAK,EAAK;IACd;IACA,IAAI,CAACA,KAAK,CAAC2D,QAAQ,CAAC,GAAG,CAAC,EAAE;MACxB,OAAO3D,KAAK;IACd;IACA,OAAOA,KAAK;EACd,CAAC,CAAC,CACDmE,IAAI,CAAC,GAAG,CAAC;EAEZ,OAAO;IACLlF,IAAI,EAAEA,IAAI;IACVC,WAAW,EAAEA;EACf,CAAC;AACH","ignoreList":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lighthouse/common",
3
- "version": "6.2.0-canary.7",
3
+ "version": "6.2.0-canary.9",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "module": "lib/index.js",
@@ -24,9 +24,7 @@
24
24
  "type-check": "tsc --noEmit",
25
25
  "type-check:watch": "yarn type-check --watch",
26
26
  "validate:circleci": "circleci config validate -c .circleci/config.yml",
27
- "version": "yarn build",
28
- "watch:es": "nodemon --watch src --ext js,ts --exec \"yarn build:es\"",
29
- "watch:node": "nodemon --watch src --ext js,ts --exec \"yarn build:node\""
27
+ "version": "yarn build"
30
28
  },
31
29
  "repository": {
32
30
  "type": "git",
@@ -72,7 +70,6 @@
72
70
  "lint-staged": "^15.2.0",
73
71
  "mockdate": "^2.0.2",
74
72
  "nock": "^12.0.2",
75
- "nodemon": "^3.0.0",
76
73
  "prettier": "^3.3.0",
77
74
  "react-visjs-timeline": "^1.6.0",
78
75
  "rimraf": "^2.6.3",