@lighthouse/common 4.37.0-canary-9 → 4.37.0-canary-11

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.
@@ -50,17 +50,21 @@ function fetchImage(url, options = {}) {
50
50
  headers: { ...(options.headers || {})
51
51
  }
52
52
  };
53
- const applicationId = options.applicationId;
53
+ const urlMatch = url && url.match(/([a-f0-9]{24})\//);
54
+ const applicationId = urlMatch && urlMatch[1];
54
55
  const shouldUseCloudfront = url && url.includes('.cloudfront.net');
55
56
  const {
56
57
  isHeader = false
57
58
  } = options;
58
59
 
59
60
  if (shouldUseCloudfront) {
61
+ console.info('Fetching image via CloudFront');
60
62
  return (async () => {
61
63
  fetchOptions.credentials = 'include'; // Ensure cookies are sent with the request
62
64
 
63
- const token = await (0, _generateCloudfrontJwt.generateCloudFrontJWT)(applicationId);
65
+ const {
66
+ token
67
+ } = await (0, _generateCloudfrontJwt.generateCloudFrontJWT)(applicationId);
64
68
  fetchOptions.headers.Authorization = `Bearer ${token}`;
65
69
  return fetch(encodedUrl, fetchOptions).then(response => {
66
70
  const contentHeader = response.headers.get('content-length');
@@ -1,10 +1,46 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
3
5
  Object.defineProperty(exports, "__esModule", {
4
6
  value: true
5
7
  });
6
8
  exports.generateCloudFrontJWT = generateCloudFrontJWT;
7
9
 
10
+ var _awsSdk = _interopRequireDefault(require("aws-sdk"));
11
+
12
+ const region = process.env.AWS_REGION || 'us-east-1';
13
+ const lambda = new _awsSdk.default.Lambda({
14
+ region
15
+ });
16
+
8
17
  async function generateCloudFrontJWT(applicationId) {
9
- return `your-generated-jwt-token-for-${applicationId}`;
18
+ if (!applicationId) {
19
+ throw new Error('applicationId is required for CloudFront JWT generation');
20
+ }
21
+
22
+ const params = {
23
+ FunctionName: `arn:aws:lambda:${region}:649076221710:function:image-optimisation-jwt-generation`,
24
+ InvocationType: 'RequestResponse',
25
+ Payload: JSON.stringify({
26
+ applicationId
27
+ })
28
+ };
29
+
30
+ try {
31
+ const result = await lambda.invoke(params).promise();
32
+ console.dir(result, {
33
+ depth: null
34
+ });
35
+ console.info('GenerateCloudFrontJWT: Raw Lambda result:', result);
36
+ const response = JSON.parse(result.Payload);
37
+ console.info('GenerateCloudFrontJWT: Parsed Lambda response:', response);
38
+ return {
39
+ expiration: response.expiration,
40
+ token: response.token
41
+ };
42
+ } catch (error) {
43
+ console.error('Error invoking JWT Lambda:', error);
44
+ throw new Error('Failed to generate CloudFront JWT');
45
+ }
10
46
  }
@@ -41,14 +41,17 @@ export function fetchImage(url) {
41
41
  headers: _objectSpread({}, options.headers || {})
42
42
  });
43
43
 
44
- var applicationId = options.applicationId;
44
+ var urlMatch = url && url.match(/([a-f0-9]{24})\//);
45
+ var applicationId = urlMatch && urlMatch[1];
45
46
  var shouldUseCloudfront = url && url.includes('.cloudfront.net');
46
47
  var _options$isHeader = options.isHeader,
47
48
  isHeader = _options$isHeader === void 0 ? false : _options$isHeader;
48
49
 
49
50
  if (shouldUseCloudfront) {
51
+ console.info('Fetching image via CloudFront');
50
52
  return _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {
51
- var token;
53
+ var _ref2, token;
54
+
52
55
  return _regeneratorRuntime.wrap(function _callee$(_context) {
53
56
  while (1) {
54
57
  switch (_context.prev = _context.next) {
@@ -59,7 +62,8 @@ export function fetchImage(url) {
59
62
  return generateCloudFrontJWT(applicationId);
60
63
 
61
64
  case 3:
62
- token = _context.sent;
65
+ _ref2 = _context.sent;
66
+ token = _ref2.token;
63
67
  fetchOptions.headers.Authorization = "Bearer ".concat(token);
64
68
  return _context.abrupt("return", fetch(encodedUrl, fetchOptions).then(function (response) {
65
69
  var contentHeader = response.headers.get('content-length');
@@ -81,9 +85,9 @@ export function fetchImage(url) {
81
85
  imageType: imageType
82
86
  };
83
87
  });
84
- }).then(function (_ref2) {
85
- var buffer = _ref2.buffer,
86
- imageType = _ref2.imageType;
88
+ }).then(function (_ref3) {
89
+ var buffer = _ref3.buffer,
90
+ imageType = _ref3.imageType;
87
91
  var base64Flag = "data:image/".concat(imageType, ";base64,");
88
92
  var imageStr = arrayBufferToBase64(buffer);
89
93
  var base64 = "".concat(base64Flag).concat(imageStr);
@@ -105,7 +109,7 @@ export function fetchImage(url) {
105
109
  return imageNotFound;
106
110
  }));
107
111
 
108
- case 6:
112
+ case 7:
109
113
  case "end":
110
114
  return _context.stop();
111
115
  }
@@ -134,9 +138,9 @@ export function fetchImage(url) {
134
138
  imageType: imageType
135
139
  };
136
140
  });
137
- }).then(function (_ref3) {
138
- var buffer = _ref3.buffer,
139
- imageType = _ref3.imageType;
141
+ }).then(function (_ref4) {
142
+ var buffer = _ref4.buffer,
143
+ imageType = _ref4.imageType;
140
144
  var base64Flag = "data:image/".concat(imageType, ";base64,");
141
145
  var imageStr = arrayBufferToBase64(buffer);
142
146
  var base64 = "".concat(base64Flag).concat(imageStr);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/helpers/fetch-image/index.js"],"names":["atob","btoa","fetchPonyfill","Promise","LIGHTHOUSE_LOGO_URL","imageNotFound","generateCloudFrontJWT","fetch","self","contentTypes","defaultOptions","cache","fetchImage","url","options","encodedUrl","encodeURI","fetchOptions","headers","applicationId","shouldUseCloudfront","includes","isHeader","credentials","token","Authorization","then","response","contentHeader","get","contentType","reject","Error","ok","imageType","arrayBuffer","buffer","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","length","sequence","i"],"mappings":"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","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 { generateCloudFrontJWT } from '../generate-cloudfront-jwt'\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 encodedUrl = encodeURI(url)\n const fetchOptions = {\n ...defaultOptions,\n ...options,\n headers: {\n ...(options.headers || {}),\n },\n }\n\n const applicationId = options.applicationId\n\n const shouldUseCloudfront = url && url.includes('.cloudfront.net')\n\n const { isHeader = false } = options\n\n if (shouldUseCloudfront) {\n return (async () => {\n fetchOptions.credentials = 'include' // Ensure cookies are sent with the request\n const token = await generateCloudFrontJWT(applicationId)\n\n fetchOptions.headers.Authorization = `Bearer ${token}`\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(\n `Failed to fetch image as no content length: ${encodedUrl}`\n )\n )\n }\n\n if (!response.ok) {\n return Promise.reject(\n new Error(`Failed to fetch image: ${encodedUrl}`)\n )\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 }\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] // in hex:\n\n //check last 12 elements of array so they contains needed values\n for (let i = 12; i > 0; i--) {\n if (imageData[imageData.length - i] !== sequence[12 - i]) {\n return false\n }\n }\n\n return true\n}\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../../../src/helpers/fetch-image/index.js"],"names":["atob","btoa","fetchPonyfill","Promise","LIGHTHOUSE_LOGO_URL","imageNotFound","generateCloudFrontJWT","fetch","self","contentTypes","defaultOptions","cache","fetchImage","url","options","encodedUrl","encodeURI","fetchOptions","headers","urlMatch","match","applicationId","shouldUseCloudfront","includes","isHeader","console","info","credentials","token","Authorization","then","response","contentHeader","get","contentType","reject","Error","ok","imageType","arrayBuffer","buffer","base64Flag","imageStr","arrayBufferToBase64","base64","isValid","validateBase64Image","catch","error","binary","bytes","slice","call","Uint8Array","forEach","b","String","fromCharCode","base64String","isJpeg","startsWith","validateJpegImage","isPng","validatePngImage","base64string","src","imageData","from","replace","c","charCodeAt","imageCorrupted","length","sequence","i"],"mappings":"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","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 { generateCloudFrontJWT } from '../generate-cloudfront-jwt'\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 encodedUrl = encodeURI(url)\n const fetchOptions = {\n ...defaultOptions,\n ...options,\n headers: {\n ...(options.headers || {}),\n },\n }\n\n const urlMatch = url && url.match(/([a-f0-9]{24})\\//)\n const applicationId = urlMatch && urlMatch[1]\n\n const shouldUseCloudfront = url && url.includes('.cloudfront.net')\n\n const { isHeader = false } = options\n\n if (shouldUseCloudfront) {\n console.info('Fetching image via CloudFront')\n return (async () => {\n fetchOptions.credentials = 'include' // Ensure cookies are sent with the request\n const { token } = await generateCloudFrontJWT(applicationId)\n\n fetchOptions.headers.Authorization = `Bearer ${token}`\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(\n `Failed to fetch image as no content length: ${encodedUrl}`\n )\n )\n }\n\n if (!response.ok) {\n return Promise.reject(\n new Error(`Failed to fetch image: ${encodedUrl}`)\n )\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 }\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] // in hex:\n\n //check last 12 elements of array so they contains needed values\n for (let i = 12; i > 0; i--) {\n if (imageData[imageData.length - i] !== sequence[12 - i]) {\n return false\n }\n }\n\n return true\n}\n"],"file":"index.js"}
@@ -1,23 +1,65 @@
1
1
  import _regeneratorRuntime from "@babel/runtime/regenerator";
2
2
  import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
3
+ import AWS from 'aws-sdk';
4
+ var region = process.env.AWS_REGION || 'us-east-1';
5
+ var lambda = new AWS.Lambda({
6
+ region: region
7
+ });
3
8
  export function generateCloudFrontJWT(_x) {
4
9
  return _generateCloudFrontJWT.apply(this, arguments);
5
10
  }
6
11
 
7
12
  function _generateCloudFrontJWT() {
8
13
  _generateCloudFrontJWT = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(applicationId) {
14
+ var params, result, response;
9
15
  return _regeneratorRuntime.wrap(function _callee$(_context) {
10
16
  while (1) {
11
17
  switch (_context.prev = _context.next) {
12
18
  case 0:
13
- return _context.abrupt("return", "your-generated-jwt-token-for-".concat(applicationId));
19
+ if (applicationId) {
20
+ _context.next = 2;
21
+ break;
22
+ }
14
23
 
15
- case 1:
24
+ throw new Error('applicationId is required for CloudFront JWT generation');
25
+
26
+ case 2:
27
+ params = {
28
+ FunctionName: "arn:aws:lambda:".concat(region, ":649076221710:function:image-optimisation-jwt-generation"),
29
+ InvocationType: 'RequestResponse',
30
+ Payload: JSON.stringify({
31
+ applicationId: applicationId
32
+ })
33
+ };
34
+ _context.prev = 3;
35
+ _context.next = 6;
36
+ return lambda.invoke(params).promise();
37
+
38
+ case 6:
39
+ result = _context.sent;
40
+ console.dir(result, {
41
+ depth: null
42
+ });
43
+ console.info('GenerateCloudFrontJWT: Raw Lambda result:', result);
44
+ response = JSON.parse(result.Payload);
45
+ console.info('GenerateCloudFrontJWT: Parsed Lambda response:', response);
46
+ return _context.abrupt("return", {
47
+ expiration: response.expiration,
48
+ token: response.token
49
+ });
50
+
51
+ case 14:
52
+ _context.prev = 14;
53
+ _context.t0 = _context["catch"](3);
54
+ console.error('Error invoking JWT Lambda:', _context.t0);
55
+ throw new Error('Failed to generate CloudFront JWT');
56
+
57
+ case 18:
16
58
  case "end":
17
59
  return _context.stop();
18
60
  }
19
61
  }
20
- }, _callee);
62
+ }, _callee, null, [[3, 14]]);
21
63
  }));
22
64
  return _generateCloudFrontJWT.apply(this, arguments);
23
65
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/helpers/generate-cloudfront-jwt/index.js"],"names":["generateCloudFrontJWT","applicationId"],"mappings":";;AAAA,gBAAsBA,qBAAtB;AAAA;AAAA;;;oFAAO,iBAAqCC,aAArC;AAAA;AAAA;AAAA;AAAA;AAAA,oFACkCA,aADlC;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G","sourcesContent":["export async function generateCloudFrontJWT(applicationId) {\n return `your-generated-jwt-token-for-${applicationId}`\n}\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../../../src/helpers/generate-cloudfront-jwt/index.js"],"names":["AWS","region","process","env","AWS_REGION","lambda","Lambda","generateCloudFrontJWT","applicationId","Error","params","FunctionName","InvocationType","Payload","JSON","stringify","invoke","promise","result","console","dir","depth","info","response","parse","expiration","token","error"],"mappings":";;AAAA,OAAOA,GAAP,MAAgB,SAAhB;AAEA,IAAMC,MAAM,GAAGC,OAAO,CAACC,GAAR,CAAYC,UAAZ,IAA0B,WAAzC;AACA,IAAMC,MAAM,GAAG,IAAIL,GAAG,CAACM,MAAR,CAAe;AAC5BL,EAAAA,MAAM,EAANA;AAD4B,CAAf,CAAf;AAIA,gBAAsBM,qBAAtB;AAAA;AAAA;;;oFAAO,iBAAqCC,aAArC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,gBACAA,aADA;AAAA;AAAA;AAAA;;AAAA,kBAEG,IAAIC,KAAJ,CAAU,yDAAV,CAFH;;AAAA;AAKCC,YAAAA,MALD,GAKU;AACbC,cAAAA,YAAY,2BAAoBV,MAApB,6DADC;AAEbW,cAAAA,cAAc,EAAE,iBAFH;AAGbC,cAAAA,OAAO,EAAEC,IAAI,CAACC,SAAL,CAAe;AAAEP,gBAAAA,aAAa,EAAbA;AAAF,eAAf;AAHI,aALV;AAAA;AAAA;AAAA,mBAYkBH,MAAM,CAACW,MAAP,CAAcN,MAAd,EAAsBO,OAAtB,EAZlB;;AAAA;AAYGC,YAAAA,MAZH;AAcHC,YAAAA,OAAO,CAACC,GAAR,CAAYF,MAAZ,EAAoB;AAAEG,cAAAA,KAAK,EAAE;AAAT,aAApB;AACAF,YAAAA,OAAO,CAACG,IAAR,CAAa,2CAAb,EAA0DJ,MAA1D;AAEMK,YAAAA,QAjBH,GAiBcT,IAAI,CAACU,KAAL,CAAWN,MAAM,CAACL,OAAlB,CAjBd;AAkBHM,YAAAA,OAAO,CAACG,IAAR,CAAa,gDAAb,EAA+DC,QAA/D;AAlBG,6CAoBI;AACLE,cAAAA,UAAU,EAAEF,QAAQ,CAACE,UADhB;AAELC,cAAAA,KAAK,EAAEH,QAAQ,CAACG;AAFX,aApBJ;;AAAA;AAAA;AAAA;AAyBHP,YAAAA,OAAO,CAACQ,KAAR,CAAc,4BAAd;AAzBG,kBA0BG,IAAIlB,KAAJ,CAAU,mCAAV,CA1BH;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G","sourcesContent":["import AWS from 'aws-sdk'\n\nconst region = process.env.AWS_REGION || 'us-east-1'\nconst lambda = new AWS.Lambda({\n region,\n})\n\nexport async function generateCloudFrontJWT(applicationId) {\n if (!applicationId) {\n throw new Error('applicationId is required for CloudFront JWT generation')\n }\n\n const params = {\n FunctionName: `arn:aws:lambda:${region}:649076221710:function:image-optimisation-jwt-generation`,\n InvocationType: 'RequestResponse',\n Payload: JSON.stringify({ applicationId }),\n }\n\n try {\n const result = await lambda.invoke(params).promise()\n\n console.dir(result, { depth: null })\n console.info('GenerateCloudFrontJWT: Raw Lambda result:', result)\n\n const response = JSON.parse(result.Payload)\n console.info('GenerateCloudFrontJWT: Parsed Lambda response:', response)\n\n return {\n expiration: response.expiration,\n token: response.token,\n }\n } catch (error) {\n console.error('Error invoking JWT Lambda:', error)\n throw new Error('Failed to generate CloudFront JWT')\n }\n}\n"],"file":"index.js"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lighthouse/common",
3
- "version": "4.37.0-canary-9",
3
+ "version": "4.37.0-canary-11",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "module": "lib/index.js",