@lighthouse/common 4.37.0-canary-6 → 4.37.0-canary-8

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.
@@ -20,8 +20,9 @@ function buildFetchUrl(url, options) {
20
20
  cloudfrontBaseUrl,
21
21
  cloudinaryBaseUrl
22
22
  });
23
+ const shouldUseCloudfront = cloudfrontBaseUrl && cloudfrontBaseUrl.includes('.cloudfront.net');
23
24
 
24
- if (cloudfrontBaseUrl) {
25
+ if (shouldUseCloudfront) {
25
26
  console.info('Using CloudFront base URL', cloudfrontBaseUrl);
26
27
  const transformations = [];
27
28
  let transformationsString = '';
@@ -29,6 +30,7 @@ function buildFetchUrl(url, options) {
29
30
  if (height) transformations.push(`h_${height.toString()}`);
30
31
  if (quality) transformations.push(`q_${quality.toString()}`);
31
32
  if (fit) transformations.push('c_fit');
33
+ transformationsString = `${transformations.join(',')}/`;
32
34
  const fetchUrl = `${cloudfrontBaseUrl}/${transformationsString}${awsS3BaseUrl}/${url}`;
33
35
  return fetchUrl;
34
36
  }
@@ -20,7 +20,7 @@ var _constants = require("../../constants");
20
20
 
21
21
  var _images = require("../../images");
22
22
 
23
- var _getCloudfrontCookies = require("../get-cloudfront-cookies");
23
+ var _generateCloudfrontJwt = require("../generate-cloudfront-jwt");
24
24
 
25
25
  // NOTE use the native fetch if it's available in the browser, because the
26
26
  // ponyfill (which actually uses the github polyfill) does not support all the
@@ -53,57 +53,64 @@ function fetchImage(url, options = {}) {
53
53
  const {
54
54
  isHeader = false
55
55
  } = options;
56
- return shouldUseCloudfront ? (async () => {
57
- fetchOptions.credentials = 'include'; // Ensure cookies are sent with the request
58
-
59
- const signedCookies = await (0, _getCloudfrontCookies.generateCloudFrontCookies)({
60
- userId: 'anonymous',
61
- applicationId
62
- });
63
- fetchOptions.headers.Cookie = Object.entries(signedCookies).map(([key, value]) => `${key}=${value}`).join('; ');
64
- return fetch(encodedUrl, fetchOptions).then(response => {
65
- const contentHeader = response.headers.get('content-length');
66
- const contentType = response.headers.get('content-type'); // NOTE: the response will be ok but we won't be able to render any
67
- // image meaning pdfmake will error. Raise error here and return early.
68
-
69
- if (contentHeader === '0') {
70
- return _bluebird.default.reject(new Error(`Failed to fetch image as no content length: ${encodedUrl}`));
71
- }
72
56
 
73
- if (!response.ok) {
74
- return _bluebird.default.reject(new Error(`Failed to fetch image: ${encodedUrl}`));
57
+ if (shouldUseCloudfront) {
58
+ return (async () => {
59
+ fetchOptions.credentials = 'include'; // Ensure cookies are sent with the request
60
+
61
+ const token = await (0, _generateCloudfrontJwt.generateCloudFrontJWT)(applicationId);
62
+
63
+ if (!fetchOptions.headers) {
64
+ fetchOptions.headers = {};
75
65
  }
76
66
 
77
- const imageType = contentTypes[contentType];
78
- return response.arrayBuffer().then(buffer => ({
67
+ fetchOptions.headers.Authorization = `Bearer ${token}`;
68
+ return fetch(encodedUrl, fetchOptions).then(response => {
69
+ const contentHeader = response.headers.get('content-length');
70
+ const contentType = response.headers.get('content-type'); // NOTE: the response will be ok but we won't be able to render any
71
+ // image meaning pdfmake will error. Raise error here and return early.
72
+
73
+ if (contentHeader === '0') {
74
+ return _bluebird.default.reject(new Error(`Failed to fetch image as no content length: ${encodedUrl}`));
75
+ }
76
+
77
+ if (!response.ok) {
78
+ return _bluebird.default.reject(new Error(`Failed to fetch image: ${encodedUrl}`));
79
+ }
80
+
81
+ const imageType = contentTypes[contentType];
82
+ return response.arrayBuffer().then(buffer => ({
83
+ buffer,
84
+ imageType
85
+ }));
86
+ }).then(({
79
87
  buffer,
80
88
  imageType
81
- }));
82
- }).then(({
83
- buffer,
84
- imageType
85
- }) => {
86
- const base64Flag = `data:image/${imageType};base64,`;
87
- const imageStr = arrayBufferToBase64(buffer);
88
- const base64 = `${base64Flag}${imageStr}`;
89
- const isValid = validateBase64Image(base64);
90
-
91
- if (!isValid) {
92
- return _bluebird.default.reject(new Error('InvalidImageError'));
93
- }
94
-
95
- return base64;
96
- }).catch(error => {
97
- if (isHeader) {
98
- // NOTE: Replace failed headers with LH logo
99
- console.error('FetchImageHeaderError', error);
100
- return fetchImage(_constants.LIGHTHOUSE_LOGO_URL, defaultOptions);
101
- }
89
+ }) => {
90
+ const base64Flag = `data:image/${imageType};base64,`;
91
+ const imageStr = arrayBufferToBase64(buffer);
92
+ const base64 = `${base64Flag}${imageStr}`;
93
+ const isValid = validateBase64Image(base64);
94
+
95
+ if (!isValid) {
96
+ return _bluebird.default.reject(new Error('InvalidImageError'));
97
+ }
98
+
99
+ return base64;
100
+ }).catch(error => {
101
+ if (isHeader) {
102
+ // NOTE: Replace failed headers with LH logo
103
+ console.error('FetchImageHeaderError', error);
104
+ return fetchImage(_constants.LIGHTHOUSE_LOGO_URL, defaultOptions);
105
+ }
106
+
107
+ console.error(error);
108
+ return _images.imageNotFound;
109
+ });
110
+ })();
111
+ }
102
112
 
103
- console.error(error);
104
- return _images.imageNotFound;
105
- });
106
- })() : fetch(encodedUrl, fetchOptions).then(response => {
113
+ return fetch(encodedUrl, fetchOptions).then(response => {
107
114
  const contentHeader = response.headers.get('content-length');
108
115
  const contentType = response.headers.get('content-type'); // NOTE: the response will be ok but we won't be able to render any
109
116
  // image meaning pdfmake will error. Raise error here and return early.
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.generateCloudFrontJWT = generateCloudFrontJWT;
7
+
8
+ async function generateCloudFrontJWT(applicationId) {
9
+ return `your-generated-jwt-token-for-${applicationId}`;
10
+ }
@@ -12,8 +12,9 @@ export function buildFetchUrl(url, options) {
12
12
  cloudfrontBaseUrl: cloudfrontBaseUrl,
13
13
  cloudinaryBaseUrl: cloudinaryBaseUrl
14
14
  });
15
+ var shouldUseCloudfront = cloudfrontBaseUrl && cloudfrontBaseUrl.includes('.cloudfront.net');
15
16
 
16
- if (cloudfrontBaseUrl) {
17
+ if (shouldUseCloudfront) {
17
18
  console.info('Using CloudFront base URL', cloudfrontBaseUrl);
18
19
  var _transformations = [];
19
20
  var _transformationsString = '';
@@ -21,6 +22,7 @@ export function buildFetchUrl(url, options) {
21
22
  if (height) _transformations.push("h_".concat(height.toString()));
22
23
  if (quality) _transformations.push("q_".concat(quality.toString()));
23
24
  if (fit) _transformations.push('c_fit');
25
+ _transformationsString = "".concat(_transformations.join(','), "/");
24
26
 
25
27
  var _fetchUrl = "".concat(cloudfrontBaseUrl, "/").concat(_transformationsString).concat(awsS3BaseUrl, "/").concat(url);
26
28
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/helpers/build-fetch-url/index.js"],"names":["buildFetchUrl","url","options","awsS3BaseUrl","cloudfrontBaseUrl","cloudinaryBaseUrl","fit","height","width","quality","console","info","transformations","transformationsString","push","toString","fetchUrl","join"],"mappings":"AAAA,OAAO,SAASA,aAAT,CAAuBC,GAAvB,EAA4BC,OAA5B,EAAqC;AAAA,MAExCC,YAFwC,GAStCD,OATsC,CAExCC,YAFwC;AAAA,8BAStCD,OATsC,CAGxCE,iBAHwC;AAAA,MAGxCA,iBAHwC,sCAGpB,EAHoB;AAAA,MAIxCC,iBAJwC,GAStCH,OATsC,CAIxCG,iBAJwC;AAAA,MAKxCC,GALwC,GAStCJ,OATsC,CAKxCI,GALwC;AAAA,MAMxCC,MANwC,GAStCL,OATsC,CAMxCK,MANwC;AAAA,MAOxCC,KAPwC,GAStCN,OATsC,CAOxCM,KAPwC;AAAA,MAQxCC,OARwC,GAStCP,OATsC,CAQxCO,OARwC;AAW1CC,EAAAA,OAAO,CAACC,IAAR,CAAa,oBAAb,EAAmC;AACjCV,IAAAA,GAAG,EAAHA,GADiC;AAEjCG,IAAAA,iBAAiB,EAAjBA,iBAFiC;AAGjCC,IAAAA,iBAAiB,EAAjBA;AAHiC,GAAnC;;AAMA,MAAID,iBAAJ,EAAuB;AACrBM,IAAAA,OAAO,CAACC,IAAR,CAAa,2BAAb,EAA0CP,iBAA1C;AACA,QAAMQ,gBAAe,GAAG,EAAxB;AACA,QAAIC,sBAAqB,GAAG,EAA5B;AAEA,QAAIL,KAAJ,EAAWI,gBAAe,CAACE,IAAhB,aAA0BN,KAAK,CAACO,QAAN,EAA1B;AACX,QAAIR,MAAJ,EAAYK,gBAAe,CAACE,IAAhB,aAA0BP,MAAM,CAACQ,QAAP,EAA1B;AACZ,QAAIN,OAAJ,EAAaG,gBAAe,CAACE,IAAhB,aAA0BL,OAAO,CAACM,QAAR,EAA1B;AACb,QAAIT,GAAJ,EAASM,gBAAe,CAACE,IAAhB,CAAqB,OAArB;;AAET,QAAME,SAAQ,aAAMZ,iBAAN,cAA2BS,sBAA3B,SAAmDV,YAAnD,cAAmEF,GAAnE,CAAd;;AACA,WAAOe,SAAP;AACD;;AAED,MAAMJ,eAAe,GAAG,EAAxB;AACA,MAAIC,qBAAqB,GAAG,EAA5B;AAEA,MAAIL,KAAJ,EAAWI,eAAe,CAACE,IAAhB,aAA0BN,KAAK,CAACO,QAAN,EAA1B;AACX,MAAIR,MAAJ,EAAYK,eAAe,CAACE,IAAhB,aAA0BP,MAAM,CAACQ,QAAP,EAA1B;AACZ,MAAIN,OAAJ,EAAaG,eAAe,CAACE,IAAhB,aAA0BL,OAAO,CAACM,QAAR,EAA1B;AACb,MAAIT,GAAJ,EAASM,eAAe,CAACE,IAAhB,CAAqB,OAArB;AAETD,EAAAA,qBAAqB,aAAMD,eAAe,CAACK,IAAhB,CAAqB,GAArB,CAAN,MAArB;AAEA,MAAMD,QAAQ,aAAMX,iBAAN,cAA2BQ,qBAA3B,SAAmDV,YAAnD,cAAmEF,GAAnE,CAAd;AAEA,SAAOe,QAAP;AACD","sourcesContent":["export function buildFetchUrl(url, options) {\n const {\n awsS3BaseUrl,\n cloudfrontBaseUrl = '',\n cloudinaryBaseUrl,\n fit,\n height,\n width,\n quality,\n } = options\n\n console.info('Building fetch URL', {\n url,\n cloudfrontBaseUrl,\n cloudinaryBaseUrl,\n })\n\n if (cloudfrontBaseUrl) {\n console.info('Using CloudFront base URL', cloudfrontBaseUrl)\n const transformations = []\n let transformationsString = ''\n\n if (width) transformations.push(`w_${width.toString()}`)\n if (height) transformations.push(`h_${height.toString()}`)\n if (quality) transformations.push(`q_${quality.toString()}`)\n if (fit) transformations.push('c_fit')\n\n const fetchUrl = `${cloudfrontBaseUrl}/${transformationsString}${awsS3BaseUrl}/${url}`\n return fetchUrl\n }\n\n const transformations = []\n let transformationsString = ''\n\n if (width) transformations.push(`w_${width.toString()}`)\n if (height) transformations.push(`h_${height.toString()}`)\n if (quality) transformations.push(`q_${quality.toString()}`)\n if (fit) transformations.push('c_fit')\n\n transformationsString = `${transformations.join(',')}/`\n\n const fetchUrl = `${cloudinaryBaseUrl}/${transformationsString}${awsS3BaseUrl}/${url}`\n\n return fetchUrl\n}\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../../../src/helpers/build-fetch-url/index.js"],"names":["buildFetchUrl","url","options","awsS3BaseUrl","cloudfrontBaseUrl","cloudinaryBaseUrl","fit","height","width","quality","console","info","shouldUseCloudfront","includes","transformations","transformationsString","push","toString","join","fetchUrl"],"mappings":"AAAA,OAAO,SAASA,aAAT,CAAuBC,GAAvB,EAA4BC,OAA5B,EAAqC;AAAA,MAExCC,YAFwC,GAStCD,OATsC,CAExCC,YAFwC;AAAA,8BAStCD,OATsC,CAGxCE,iBAHwC;AAAA,MAGxCA,iBAHwC,sCAGpB,EAHoB;AAAA,MAIxCC,iBAJwC,GAStCH,OATsC,CAIxCG,iBAJwC;AAAA,MAKxCC,GALwC,GAStCJ,OATsC,CAKxCI,GALwC;AAAA,MAMxCC,MANwC,GAStCL,OATsC,CAMxCK,MANwC;AAAA,MAOxCC,KAPwC,GAStCN,OATsC,CAOxCM,KAPwC;AAAA,MAQxCC,OARwC,GAStCP,OATsC,CAQxCO,OARwC;AAW1CC,EAAAA,OAAO,CAACC,IAAR,CAAa,oBAAb,EAAmC;AACjCV,IAAAA,GAAG,EAAHA,GADiC;AAEjCG,IAAAA,iBAAiB,EAAjBA,iBAFiC;AAGjCC,IAAAA,iBAAiB,EAAjBA;AAHiC,GAAnC;AAMA,MAAMO,mBAAmB,GACvBR,iBAAiB,IAAIA,iBAAiB,CAACS,QAAlB,CAA2B,iBAA3B,CADvB;;AAGA,MAAID,mBAAJ,EAAyB;AACvBF,IAAAA,OAAO,CAACC,IAAR,CAAa,2BAAb,EAA0CP,iBAA1C;AACA,QAAMU,gBAAe,GAAG,EAAxB;AACA,QAAIC,sBAAqB,GAAG,EAA5B;AAEA,QAAIP,KAAJ,EAAWM,gBAAe,CAACE,IAAhB,aAA0BR,KAAK,CAACS,QAAN,EAA1B;AACX,QAAIV,MAAJ,EAAYO,gBAAe,CAACE,IAAhB,aAA0BT,MAAM,CAACU,QAAP,EAA1B;AACZ,QAAIR,OAAJ,EAAaK,gBAAe,CAACE,IAAhB,aAA0BP,OAAO,CAACQ,QAAR,EAA1B;AACb,QAAIX,GAAJ,EAASQ,gBAAe,CAACE,IAAhB,CAAqB,OAArB;AAETD,IAAAA,sBAAqB,aAAMD,gBAAe,CAACI,IAAhB,CAAqB,GAArB,CAAN,MAArB;;AAEA,QAAMC,SAAQ,aAAMf,iBAAN,cAA2BW,sBAA3B,SAAmDZ,YAAnD,cAAmEF,GAAnE,CAAd;;AACA,WAAOkB,SAAP;AACD;;AAED,MAAML,eAAe,GAAG,EAAxB;AACA,MAAIC,qBAAqB,GAAG,EAA5B;AAEA,MAAIP,KAAJ,EAAWM,eAAe,CAACE,IAAhB,aAA0BR,KAAK,CAACS,QAAN,EAA1B;AACX,MAAIV,MAAJ,EAAYO,eAAe,CAACE,IAAhB,aAA0BT,MAAM,CAACU,QAAP,EAA1B;AACZ,MAAIR,OAAJ,EAAaK,eAAe,CAACE,IAAhB,aAA0BP,OAAO,CAACQ,QAAR,EAA1B;AACb,MAAIX,GAAJ,EAASQ,eAAe,CAACE,IAAhB,CAAqB,OAArB;AAETD,EAAAA,qBAAqB,aAAMD,eAAe,CAACI,IAAhB,CAAqB,GAArB,CAAN,MAArB;AAEA,MAAMC,QAAQ,aAAMd,iBAAN,cAA2BU,qBAA3B,SAAmDZ,YAAnD,cAAmEF,GAAnE,CAAd;AAEA,SAAOkB,QAAP;AACD","sourcesContent":["export function buildFetchUrl(url, options) {\n const {\n awsS3BaseUrl,\n cloudfrontBaseUrl = '',\n cloudinaryBaseUrl,\n fit,\n height,\n width,\n quality,\n } = options\n\n console.info('Building fetch URL', {\n url,\n cloudfrontBaseUrl,\n cloudinaryBaseUrl,\n })\n\n const shouldUseCloudfront =\n cloudfrontBaseUrl && cloudfrontBaseUrl.includes('.cloudfront.net')\n\n if (shouldUseCloudfront) {\n console.info('Using CloudFront base URL', cloudfrontBaseUrl)\n const transformations = []\n let transformationsString = ''\n\n if (width) transformations.push(`w_${width.toString()}`)\n if (height) transformations.push(`h_${height.toString()}`)\n if (quality) transformations.push(`q_${quality.toString()}`)\n if (fit) transformations.push('c_fit')\n\n transformationsString = `${transformations.join(',')}/`\n\n const fetchUrl = `${cloudfrontBaseUrl}/${transformationsString}${awsS3BaseUrl}/${url}`\n return fetchUrl\n }\n\n const transformations = []\n let transformationsString = ''\n\n if (width) transformations.push(`w_${width.toString()}`)\n if (height) transformations.push(`h_${height.toString()}`)\n if (quality) transformations.push(`q_${quality.toString()}`)\n if (fit) transformations.push('c_fit')\n\n transformationsString = `${transformations.join(',')}/`\n\n const fetchUrl = `${cloudinaryBaseUrl}/${transformationsString}${awsS3BaseUrl}/${url}`\n\n return fetchUrl\n}\n"],"file":"index.js"}
@@ -1,5 +1,4 @@
1
1
  import _regeneratorRuntime from "@babel/runtime/regenerator";
2
- import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
3
2
  import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
4
3
  import _defineProperty from "@babel/runtime/helpers/defineProperty";
5
4
  import _typeof from "@babel/runtime/helpers/typeof";
@@ -13,7 +12,7 @@ import fetchPonyfill from 'fetch-ponyfill';
13
12
  import Promise from 'bluebird';
14
13
  import { LIGHTHOUSE_LOGO_URL } from '../../constants';
15
14
  import { imageNotFound } from '../../images';
16
- import { generateCloudFrontCookies } from '../get-cloudfront-cookies'; // NOTE use the native fetch if it's available in the browser, because the
15
+ import { generateCloudFrontJWT } from '../generate-cloudfront-jwt'; // NOTE use the native fetch if it's available in the browser, because the
17
16
  // ponyfill (which actually uses the github polyfill) does not support all the
18
17
  // same options as native fetch
19
18
 
@@ -44,80 +43,81 @@ export function fetchImage(url) {
44
43
  var shouldUseCloudfront = url && url.includes('.cloudfront.net');
45
44
  var _options$isHeader = options.isHeader,
46
45
  isHeader = _options$isHeader === void 0 ? false : _options$isHeader;
47
- return shouldUseCloudfront ? _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {
48
- var signedCookies;
49
- return _regeneratorRuntime.wrap(function _callee$(_context) {
50
- while (1) {
51
- switch (_context.prev = _context.next) {
52
- case 0:
53
- fetchOptions.credentials = 'include'; // Ensure cookies are sent with the request
54
-
55
- _context.next = 3;
56
- return generateCloudFrontCookies({
57
- userId: 'anonymous',
58
- applicationId: applicationId
59
- });
60
-
61
- case 3:
62
- signedCookies = _context.sent;
63
- fetchOptions.headers.Cookie = Object.entries(signedCookies).map(function (_ref2) {
64
- var _ref3 = _slicedToArray(_ref2, 2),
65
- key = _ref3[0],
66
- value = _ref3[1];
67
-
68
- return "".concat(key, "=").concat(value);
69
- }).join('; ');
70
- return _context.abrupt("return", fetch(encodedUrl, fetchOptions).then(function (response) {
71
- var contentHeader = response.headers.get('content-length');
72
- var contentType = response.headers.get('content-type'); // NOTE: the response will be ok but we won't be able to render any
73
- // image meaning pdfmake will error. Raise error here and return early.
74
-
75
- if (contentHeader === '0') {
76
- return Promise.reject(new Error("Failed to fetch image as no content length: ".concat(encodedUrl)));
77
- }
78
46
 
79
- if (!response.ok) {
80
- return Promise.reject(new Error("Failed to fetch image: ".concat(encodedUrl)));
81
- }
47
+ if (shouldUseCloudfront) {
48
+ return _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {
49
+ var token;
50
+ return _regeneratorRuntime.wrap(function _callee$(_context) {
51
+ while (1) {
52
+ switch (_context.prev = _context.next) {
53
+ case 0:
54
+ fetchOptions.credentials = 'include'; // Ensure cookies are sent with the request
82
55
 
83
- var imageType = contentTypes[contentType];
84
- return response.arrayBuffer().then(function (buffer) {
85
- return {
86
- buffer: buffer,
87
- imageType: imageType
88
- };
89
- });
90
- }).then(function (_ref4) {
91
- var buffer = _ref4.buffer,
92
- imageType = _ref4.imageType;
93
- var base64Flag = "data:image/".concat(imageType, ";base64,");
94
- var imageStr = arrayBufferToBase64(buffer);
95
- var base64 = "".concat(base64Flag).concat(imageStr);
96
- var isValid = validateBase64Image(base64);
97
-
98
- if (!isValid) {
99
- return Promise.reject(new Error('InvalidImageError'));
100
- }
56
+ _context.next = 3;
57
+ return generateCloudFrontJWT(applicationId);
101
58
 
102
- return base64;
103
- }).catch(function (error) {
104
- if (isHeader) {
105
- // NOTE: Replace failed headers with LH logo
106
- console.error('FetchImageHeaderError', error);
107
- return fetchImage(LIGHTHOUSE_LOGO_URL, defaultOptions);
108
- }
59
+ case 3:
60
+ token = _context.sent;
109
61
 
110
- console.error(error);
111
- return imageNotFound;
112
- }));
62
+ if (!fetchOptions.headers) {
63
+ fetchOptions.headers = {};
64
+ }
113
65
 
114
- case 6:
115
- case "end":
116
- return _context.stop();
66
+ fetchOptions.headers.Authorization = "Bearer ".concat(token);
67
+ return _context.abrupt("return", fetch(encodedUrl, fetchOptions).then(function (response) {
68
+ var contentHeader = response.headers.get('content-length');
69
+ var contentType = response.headers.get('content-type'); // NOTE: the response will be ok but we won't be able to render any
70
+ // image meaning pdfmake will error. Raise error here and return early.
71
+
72
+ if (contentHeader === '0') {
73
+ return Promise.reject(new Error("Failed to fetch image as no content length: ".concat(encodedUrl)));
74
+ }
75
+
76
+ if (!response.ok) {
77
+ return Promise.reject(new Error("Failed to fetch image: ".concat(encodedUrl)));
78
+ }
79
+
80
+ var imageType = contentTypes[contentType];
81
+ return response.arrayBuffer().then(function (buffer) {
82
+ return {
83
+ buffer: buffer,
84
+ imageType: imageType
85
+ };
86
+ });
87
+ }).then(function (_ref2) {
88
+ var buffer = _ref2.buffer,
89
+ imageType = _ref2.imageType;
90
+ var base64Flag = "data:image/".concat(imageType, ";base64,");
91
+ var imageStr = arrayBufferToBase64(buffer);
92
+ var base64 = "".concat(base64Flag).concat(imageStr);
93
+ var isValid = validateBase64Image(base64);
94
+
95
+ if (!isValid) {
96
+ return Promise.reject(new Error('InvalidImageError'));
97
+ }
98
+
99
+ return base64;
100
+ }).catch(function (error) {
101
+ if (isHeader) {
102
+ // NOTE: Replace failed headers with LH logo
103
+ console.error('FetchImageHeaderError', error);
104
+ return fetchImage(LIGHTHOUSE_LOGO_URL, defaultOptions);
105
+ }
106
+
107
+ console.error(error);
108
+ return imageNotFound;
109
+ }));
110
+
111
+ case 7:
112
+ case "end":
113
+ return _context.stop();
114
+ }
117
115
  }
118
- }
119
- }, _callee);
120
- }))() : fetch(encodedUrl, fetchOptions).then(function (response) {
116
+ }, _callee);
117
+ }))();
118
+ }
119
+
120
+ return fetch(encodedUrl, fetchOptions).then(function (response) {
121
121
  var contentHeader = response.headers.get('content-length');
122
122
  var contentType = response.headers.get('content-type'); // NOTE: the response will be ok but we won't be able to render any
123
123
  // image meaning pdfmake will error. Raise error here and return early.
@@ -137,9 +137,9 @@ export function fetchImage(url) {
137
137
  imageType: imageType
138
138
  };
139
139
  });
140
- }).then(function (_ref5) {
141
- var buffer = _ref5.buffer,
142
- imageType = _ref5.imageType;
140
+ }).then(function (_ref3) {
141
+ var buffer = _ref3.buffer,
142
+ imageType = _ref3.imageType;
143
143
  var base64Flag = "data:image/".concat(imageType, ";base64,");
144
144
  var imageStr = arrayBufferToBase64(buffer);
145
145
  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","generateCloudFrontCookies","fetch","self","contentTypes","defaultOptions","cache","fetchImage","url","options","encodedUrl","encodeURI","fetchOptions","applicationId","shouldUseCloudfront","includes","isHeader","credentials","userId","signedCookies","headers","Cookie","Object","entries","map","key","value","join","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 { generateCloudFrontCookies } from '../get-cloudfront-cookies'\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 }\n\n const applicationId = options.applicationId\n\n const shouldUseCloudfront = url && url.includes('.cloudfront.net')\n\n const { isHeader = false } = options\n\n return shouldUseCloudfront ?\n (async () => {\n fetchOptions.credentials = 'include' // Ensure cookies are sent with the request\n const signedCookies = await generateCloudFrontCookies({\n userId: 'anonymous',\n applicationId,\n })\n\n fetchOptions.headers.Cookie = Object.entries(signedCookies)\n .map(([key, value]) => `${key}=${value}`)\n .join('; ')\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 : 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","applicationId","shouldUseCloudfront","includes","isHeader","credentials","token","headers","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 }\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 if (!fetchOptions.headers) {\n fetchOptions.headers = {}\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"}
@@ -0,0 +1,24 @@
1
+ import _regeneratorRuntime from "@babel/runtime/regenerator";
2
+ import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
3
+ export function generateCloudFrontJWT(_x) {
4
+ return _generateCloudFrontJWT.apply(this, arguments);
5
+ }
6
+
7
+ function _generateCloudFrontJWT() {
8
+ _generateCloudFrontJWT = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(applicationId) {
9
+ return _regeneratorRuntime.wrap(function _callee$(_context) {
10
+ while (1) {
11
+ switch (_context.prev = _context.next) {
12
+ case 0:
13
+ return _context.abrupt("return", "your-generated-jwt-token-for-".concat(applicationId));
14
+
15
+ case 1:
16
+ case "end":
17
+ return _context.stop();
18
+ }
19
+ }
20
+ }, _callee);
21
+ }));
22
+ return _generateCloudFrontJWT.apply(this, arguments);
23
+ }
24
+ //# sourceMappingURL=index.js.map
@@ -0,0 +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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lighthouse/common",
3
- "version": "4.37.0-canary-6",
3
+ "version": "4.37.0-canary-8",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "module": "lib/index.js",