@lighthouse/common 4.36.1 → 4.37.0-canary-2
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.
- package/dist/helpers/build-fetch-url/index.js +13 -0
- package/dist/helpers/fetch-image/index.js +14 -0
- package/dist/helpers/get-audit-items-data/index.js +4 -1
- package/dist/helpers/get-cloudfront-cookies/index.js +118 -0
- package/dist/helpers/get-secret-value/index.js +49 -0
- package/dist/pdf/helpers/fields/index.js +3 -1
- package/lib/helpers/build-fetch-url/index.js +16 -0
- package/lib/helpers/build-fetch-url/index.js.map +1 -1
- package/lib/helpers/fetch-image/index.js +24 -4
- package/lib/helpers/fetch-image/index.js.map +1 -1
- package/lib/helpers/get-audit-items-data/index.js +3 -0
- package/lib/helpers/get-audit-items-data/index.js.map +1 -1
- package/lib/helpers/get-cloudfront-cookies/index.js +176 -0
- package/lib/helpers/get-cloudfront-cookies/index.js.map +1 -0
- package/lib/helpers/get-secret-value/index.js +38 -0
- package/lib/helpers/get-secret-value/index.js.map +1 -0
- package/lib/pdf/helpers/fields/index.js +3 -1
- package/lib/pdf/helpers/fields/index.js.map +1 -1
- package/mise.toml +2 -0
- package/package.json +2 -1
|
@@ -8,12 +8,25 @@ exports.buildFetchUrl = buildFetchUrl;
|
|
|
8
8
|
function buildFetchUrl(url, options) {
|
|
9
9
|
const {
|
|
10
10
|
awsS3BaseUrl,
|
|
11
|
+
cloudfrontBaseUrl = '',
|
|
11
12
|
cloudinaryBaseUrl,
|
|
12
13
|
fit,
|
|
13
14
|
height,
|
|
14
15
|
width,
|
|
15
16
|
quality
|
|
16
17
|
} = options;
|
|
18
|
+
|
|
19
|
+
if (cloudfrontBaseUrl) {
|
|
20
|
+
const transformations = [];
|
|
21
|
+
let transformationsString = '';
|
|
22
|
+
if (width) transformations.push(`w_${width.toString()}`);
|
|
23
|
+
if (height) transformations.push(`h_${height.toString()}`);
|
|
24
|
+
if (quality) transformations.push(`q_${quality.toString()}`);
|
|
25
|
+
if (fit) transformations.push('c_fit');
|
|
26
|
+
const fetchUrl = `${cloudfrontBaseUrl}/${transformationsString}${awsS3BaseUrl}/${url}`;
|
|
27
|
+
return fetchUrl;
|
|
28
|
+
}
|
|
29
|
+
|
|
17
30
|
const transformations = [];
|
|
18
31
|
let transformationsString = '';
|
|
19
32
|
if (width) transformations.push(`w_${width.toString()}`);
|
|
@@ -20,6 +20,8 @@ var _constants = require("../../constants");
|
|
|
20
20
|
|
|
21
21
|
var _images = require("../../images");
|
|
22
22
|
|
|
23
|
+
var _getCloudfrontCookies = require("../get-cloudfront-cookies");
|
|
24
|
+
|
|
23
25
|
// NOTE use the native fetch if it's available in the browser, because the
|
|
24
26
|
// ponyfill (which actually uses the github polyfill) does not support all the
|
|
25
27
|
// same options as native fetch
|
|
@@ -46,6 +48,18 @@ function fetchImage(url, options = {}) {
|
|
|
46
48
|
const fetchOptions = { ...defaultOptions,
|
|
47
49
|
...options
|
|
48
50
|
};
|
|
51
|
+
const applicationId = options.applicationId;
|
|
52
|
+
|
|
53
|
+
if (url.contains('.cloudfront.net')) {
|
|
54
|
+
fetchOptions.credentials = 'include'; // Ensure cookies are sent with the request
|
|
55
|
+
|
|
56
|
+
const signedCookies = (0, _getCloudfrontCookies.generateCloudFrontCookies)({
|
|
57
|
+
userId: 'anonymous',
|
|
58
|
+
applicationId
|
|
59
|
+
});
|
|
60
|
+
fetchOptions.headers.Cookie = Object.entries(signedCookies).map(([key, value]) => `${key}=${value}`).join('; ');
|
|
61
|
+
}
|
|
62
|
+
|
|
49
63
|
const {
|
|
50
64
|
isHeader = false
|
|
51
65
|
} = options;
|
|
@@ -13,7 +13,8 @@ function getAuditItemsData(items, data) {
|
|
|
13
13
|
const {
|
|
14
14
|
settings: {
|
|
15
15
|
awsS3BaseUrl,
|
|
16
|
-
cloudinaryBaseUrl
|
|
16
|
+
cloudinaryBaseUrl,
|
|
17
|
+
cloudfrontBaseUrl
|
|
17
18
|
} = {},
|
|
18
19
|
entity: {
|
|
19
20
|
groupScores
|
|
@@ -56,6 +57,7 @@ function getAuditItemsData(items, data) {
|
|
|
56
57
|
const assets = rawAssets.map((asset, assetIndex) => {
|
|
57
58
|
const assetUrl = (0, _.buildFetchUrl)(asset, {
|
|
58
59
|
awsS3BaseUrl,
|
|
60
|
+
cloudfrontBaseUrl,
|
|
59
61
|
cloudinaryBaseUrl,
|
|
60
62
|
fit: true,
|
|
61
63
|
height: 400,
|
|
@@ -65,6 +67,7 @@ function getAuditItemsData(items, data) {
|
|
|
65
67
|
const link = `${awsS3BaseUrl}/${asset}`;
|
|
66
68
|
const thumbnailUrl = (0, _.buildFetchUrl)(asset, {
|
|
67
69
|
awsS3BaseUrl,
|
|
70
|
+
cloudfrontBaseUrl,
|
|
68
71
|
cloudinaryBaseUrl,
|
|
69
72
|
width: 100,
|
|
70
73
|
quality: 50
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.generateCloudFrontCookies = generateCloudFrontCookies;
|
|
7
|
+
|
|
8
|
+
const {
|
|
9
|
+
getSignedCookies
|
|
10
|
+
} = require('@aws-sdk/cloudfront-signer');
|
|
11
|
+
|
|
12
|
+
const {
|
|
13
|
+
getSecretValue
|
|
14
|
+
} = require('../../aws/secrets-manager');
|
|
15
|
+
|
|
16
|
+
const logger = require('../../logger');
|
|
17
|
+
/**
|
|
18
|
+
* Generate CloudFront signed cookies for authenticated users
|
|
19
|
+
* @param {Object} options - Configuration options
|
|
20
|
+
* @param {string} options.userId - User ID for logging purposes
|
|
21
|
+
* @param {string} options.applicationId - Application ID for resource scoping
|
|
22
|
+
* Return Type: https://docs.aws.amazon.com/AWSJavaScriptSDK/v3/latest/Package/-aws-sdk-cloudfront-signer/Interface/CloudfrontSignedCookiesOutput/
|
|
23
|
+
* @returns {Promise<{
|
|
24
|
+
* "CloudFront-Key-Pair-Id": string,
|
|
25
|
+
* "CloudFront-Signature": string,
|
|
26
|
+
* "CloudFront-Expires"?: number,
|
|
27
|
+
* "CloudFront-Policy"?: string
|
|
28
|
+
* } | null>} Signed cookies object or null if disabled/failed
|
|
29
|
+
*/
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
async function generateCloudFrontCookies({
|
|
33
|
+
userId,
|
|
34
|
+
applicationId
|
|
35
|
+
}) {
|
|
36
|
+
// Early return if CloudFront is not configured
|
|
37
|
+
if (!process.env.CLOUDFRONT_DOMAIN || !process.env.CLOUDFRONT_KEY_PAIR_ID) {
|
|
38
|
+
logger.debug('CloudFront cookie generation skipped - not configured');
|
|
39
|
+
return null;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
try {
|
|
43
|
+
// Get private key from AWS Secrets Manager
|
|
44
|
+
const privateKey = await getPrivateKey();
|
|
45
|
+
|
|
46
|
+
if (!privateKey) {
|
|
47
|
+
logger.warn('CloudFront private key not available');
|
|
48
|
+
return null;
|
|
49
|
+
} // Set expiration time (14 days from now)
|
|
50
|
+
|
|
51
|
+
|
|
52
|
+
const expiration = new Date();
|
|
53
|
+
expiration.setTime(expiration.getTime() + 14 * 24 * 60 * 60 * 1000); // Generate resource URL pattern for wildcard access
|
|
54
|
+
|
|
55
|
+
const distributionDomain = `https://${process.env.CLOUDFRONT_DOMAIN}`;
|
|
56
|
+
const resourcePath = applicationId ? `${applicationId}/*` : '*';
|
|
57
|
+
const urlPattern = `${distributionDomain}/${resourcePath}`; // Generate signed cookies
|
|
58
|
+
|
|
59
|
+
const signedCookies = getSignedCookies({
|
|
60
|
+
url: urlPattern,
|
|
61
|
+
keyPairId: process.env.CLOUDFRONT_KEY_PAIR_ID,
|
|
62
|
+
privateKey: privateKey,
|
|
63
|
+
dateLessThan: expiration.getTime() // Use epoch timestamp in milliseconds
|
|
64
|
+
|
|
65
|
+
});
|
|
66
|
+
logger.info('CloudFront cookies generated successfully', {
|
|
67
|
+
userId,
|
|
68
|
+
applicationId,
|
|
69
|
+
resourcePath,
|
|
70
|
+
expiration: expiration.toISOString()
|
|
71
|
+
});
|
|
72
|
+
return signedCookies;
|
|
73
|
+
} catch (error) {
|
|
74
|
+
logger.error('Failed to generate CloudFront cookies', {
|
|
75
|
+
userId,
|
|
76
|
+
applicationId,
|
|
77
|
+
error: {
|
|
78
|
+
message: error.message,
|
|
79
|
+
code: error.code
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
return null;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
let privateKeyCache = null;
|
|
87
|
+
let cacheExpiry = null;
|
|
88
|
+
const CACHE_TTL = 5 * 60 * 1000; // 5 minutes
|
|
89
|
+
|
|
90
|
+
async function getPrivateKey() {
|
|
91
|
+
const now = Date.now();
|
|
92
|
+
|
|
93
|
+
if (privateKeyCache && cacheExpiry && now < cacheExpiry) {
|
|
94
|
+
return privateKeyCache;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
if (!process.env.CLOUDFRONT_PRIVATE_KEY_SECRET_ID) {
|
|
98
|
+
logger.warn('CLOUDFRONT_PRIVATE_KEY_SECRET_ID not configured');
|
|
99
|
+
return null;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
try {
|
|
103
|
+
const privateKey = await getSecretValue(process.env.CLOUDFRONT_PRIVATE_KEY_SECRET_ID, 'CLOUDFRONT_PRIVATE_KEY');
|
|
104
|
+
privateKeyCache = privateKey;
|
|
105
|
+
cacheExpiry = now + CACHE_TTL;
|
|
106
|
+
logger.debug('CloudFront private key retrieved and cached');
|
|
107
|
+
return privateKey;
|
|
108
|
+
} catch (error) {
|
|
109
|
+
logger.error('Failed to retrieve CloudFront private key', {
|
|
110
|
+
secretId: process.env.CLOUDFRONT_PRIVATE_KEY_SECRET_ID,
|
|
111
|
+
error: {
|
|
112
|
+
message: error.message,
|
|
113
|
+
code: error.code
|
|
114
|
+
}
|
|
115
|
+
});
|
|
116
|
+
return null;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.default = getSecretValue;
|
|
9
|
+
|
|
10
|
+
var _commonErrors = require("@lighthouse/common-errors");
|
|
11
|
+
|
|
12
|
+
var _awsSdk = _interopRequireDefault(require("aws-sdk"));
|
|
13
|
+
|
|
14
|
+
var _lodash = require("lodash");
|
|
15
|
+
|
|
16
|
+
function getSecretValue(secretId, secretKey) {
|
|
17
|
+
if (!secretId) {
|
|
18
|
+
return Promise.reject(new _commonErrors.errors.ValidationError(`Missing required param: secretId:${secretId}`));
|
|
19
|
+
} // TODO: update these credentials to specific values for service
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
const secretsClient = new _awsSdk.default.SecretsManager({
|
|
23
|
+
accessKeyId: process.env.AWS_KEY,
|
|
24
|
+
region: process.env.AWS_SECRET_MANAGER_REGION,
|
|
25
|
+
secretAccessKey: process.env.AWS_SECRET
|
|
26
|
+
});
|
|
27
|
+
return secretsClient.getSecretValue({
|
|
28
|
+
SecretId: secretId
|
|
29
|
+
}).promise().then(payload => {
|
|
30
|
+
const secret = parseSecretString(payload); // Return early if secretKey isn't defined (we want the full set of key/values)
|
|
31
|
+
|
|
32
|
+
if (!secretKey) return secret;
|
|
33
|
+
const secretValue = secret[secretKey];
|
|
34
|
+
|
|
35
|
+
if (!secretValue) {
|
|
36
|
+
throw new _commonErrors.errors.NotFoundError('Secret value could not be found');
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
return secretValue;
|
|
40
|
+
}).catch(err => {
|
|
41
|
+
throw new _commonErrors.errors.UnknownError(`AWSSecretFetchError: ${err.code}, ${err.message}`);
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
function parseSecretString(payload) {
|
|
46
|
+
const secretString = payload.SecretString || '';
|
|
47
|
+
const parsed = (0, _lodash.attempt)(JSON.parse, secretString);
|
|
48
|
+
return (0, _lodash.isError)(parsed) ? {} : parsed;
|
|
49
|
+
}
|
|
@@ -50,7 +50,8 @@ function buildImage(options) {
|
|
|
50
50
|
} = options;
|
|
51
51
|
const {
|
|
52
52
|
awsS3BaseUrl,
|
|
53
|
-
cloudinaryBaseUrl
|
|
53
|
+
cloudinaryBaseUrl,
|
|
54
|
+
cloudfrontBaseUrl
|
|
54
55
|
} = settings;
|
|
55
56
|
const isVideoType = new RegExp('.mp4$').test(filepath);
|
|
56
57
|
const link = `${awsS3BaseUrl}/${filepath}`;
|
|
@@ -66,6 +67,7 @@ function buildImage(options) {
|
|
|
66
67
|
|
|
67
68
|
const url = (0, _helpers.buildFetchUrl)(filepath, {
|
|
68
69
|
awsS3BaseUrl,
|
|
70
|
+
cloudfrontBaseUrl,
|
|
69
71
|
cloudinaryBaseUrl,
|
|
70
72
|
fit: true,
|
|
71
73
|
height: 400,
|
|
@@ -1,10 +1,26 @@
|
|
|
1
1
|
export function buildFetchUrl(url, options) {
|
|
2
2
|
var awsS3BaseUrl = options.awsS3BaseUrl,
|
|
3
|
+
_options$cloudfrontBa = options.cloudfrontBaseUrl,
|
|
4
|
+
cloudfrontBaseUrl = _options$cloudfrontBa === void 0 ? '' : _options$cloudfrontBa,
|
|
3
5
|
cloudinaryBaseUrl = options.cloudinaryBaseUrl,
|
|
4
6
|
fit = options.fit,
|
|
5
7
|
height = options.height,
|
|
6
8
|
width = options.width,
|
|
7
9
|
quality = options.quality;
|
|
10
|
+
|
|
11
|
+
if (cloudfrontBaseUrl) {
|
|
12
|
+
var _transformations = [];
|
|
13
|
+
var _transformationsString = '';
|
|
14
|
+
if (width) _transformations.push("w_".concat(width.toString()));
|
|
15
|
+
if (height) _transformations.push("h_".concat(height.toString()));
|
|
16
|
+
if (quality) _transformations.push("q_".concat(quality.toString()));
|
|
17
|
+
if (fit) _transformations.push('c_fit');
|
|
18
|
+
|
|
19
|
+
var _fetchUrl = "".concat(cloudfrontBaseUrl, "/").concat(_transformationsString).concat(awsS3BaseUrl, "/").concat(url);
|
|
20
|
+
|
|
21
|
+
return _fetchUrl;
|
|
22
|
+
}
|
|
23
|
+
|
|
8
24
|
var transformations = [];
|
|
9
25
|
var transformationsString = '';
|
|
10
26
|
if (width) transformations.push("w_".concat(width.toString()));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/helpers/build-fetch-url/index.js"],"names":["buildFetchUrl","url","options","awsS3BaseUrl","cloudinaryBaseUrl","fit","height","width","quality","transformations","transformationsString","push","toString","
|
|
1
|
+
{"version":3,"sources":["../../../src/helpers/build-fetch-url/index.js"],"names":["buildFetchUrl","url","options","awsS3BaseUrl","cloudfrontBaseUrl","cloudinaryBaseUrl","fit","height","width","quality","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;;AAW1C,MAAIL,iBAAJ,EAAuB;AACrB,QAAMM,gBAAe,GAAG,EAAxB;AACA,QAAIC,sBAAqB,GAAG,EAA5B;AAEA,QAAIH,KAAJ,EAAWE,gBAAe,CAACE,IAAhB,aAA0BJ,KAAK,CAACK,QAAN,EAA1B;AACX,QAAIN,MAAJ,EAAYG,gBAAe,CAACE,IAAhB,aAA0BL,MAAM,CAACM,QAAP,EAA1B;AACZ,QAAIJ,OAAJ,EAAaC,gBAAe,CAACE,IAAhB,aAA0BH,OAAO,CAACI,QAAR,EAA1B;AACb,QAAIP,GAAJ,EAASI,gBAAe,CAACE,IAAhB,CAAqB,OAArB;;AAET,QAAME,SAAQ,aAAMV,iBAAN,cAA2BO,sBAA3B,SAAmDR,YAAnD,cAAmEF,GAAnE,CAAd;;AACA,WAAOa,SAAP;AACD;;AAED,MAAMJ,eAAe,GAAG,EAAxB;AACA,MAAIC,qBAAqB,GAAG,EAA5B;AAEA,MAAIH,KAAJ,EAAWE,eAAe,CAACE,IAAhB,aAA0BJ,KAAK,CAACK,QAAN,EAA1B;AACX,MAAIN,MAAJ,EAAYG,eAAe,CAACE,IAAhB,aAA0BL,MAAM,CAACM,QAAP,EAA1B;AACZ,MAAIJ,OAAJ,EAAaC,eAAe,CAACE,IAAhB,aAA0BH,OAAO,CAACI,QAAR,EAA1B;AACb,MAAIP,GAAJ,EAASI,eAAe,CAACE,IAAhB,CAAqB,OAArB;AAETD,EAAAA,qBAAqB,aAAMD,eAAe,CAACK,IAAhB,CAAqB,GAArB,CAAN,MAArB;AAEA,MAAMD,QAAQ,aAAMT,iBAAN,cAA2BM,qBAA3B,SAAmDR,YAAnD,cAAmEF,GAAnE,CAAd;AAEA,SAAOa,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 if (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,3 +1,4 @@
|
|
|
1
|
+
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
1
2
|
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
2
3
|
import _typeof from "@babel/runtime/helpers/typeof";
|
|
3
4
|
|
|
@@ -9,7 +10,8 @@ import { atob, btoa } from '@lighthouse/abab';
|
|
|
9
10
|
import fetchPonyfill from 'fetch-ponyfill';
|
|
10
11
|
import Promise from 'bluebird';
|
|
11
12
|
import { LIGHTHOUSE_LOGO_URL } from '../../constants';
|
|
12
|
-
import { imageNotFound } from '../../images';
|
|
13
|
+
import { imageNotFound } from '../../images';
|
|
14
|
+
import { generateCloudFrontCookies } from '../get-cloudfront-cookies'; // NOTE use the native fetch if it's available in the browser, because the
|
|
13
15
|
// ponyfill (which actually uses the github polyfill) does not support all the
|
|
14
16
|
// same options as native fetch
|
|
15
17
|
|
|
@@ -36,6 +38,24 @@ export function fetchImage(url) {
|
|
|
36
38
|
|
|
37
39
|
var fetchOptions = _objectSpread(_objectSpread({}, defaultOptions), options);
|
|
38
40
|
|
|
41
|
+
var applicationId = options.applicationId;
|
|
42
|
+
|
|
43
|
+
if (url.contains('.cloudfront.net')) {
|
|
44
|
+
fetchOptions.credentials = 'include'; // Ensure cookies are sent with the request
|
|
45
|
+
|
|
46
|
+
var signedCookies = generateCloudFrontCookies({
|
|
47
|
+
userId: 'anonymous',
|
|
48
|
+
applicationId: applicationId
|
|
49
|
+
});
|
|
50
|
+
fetchOptions.headers.Cookie = Object.entries(signedCookies).map(function (_ref) {
|
|
51
|
+
var _ref2 = _slicedToArray(_ref, 2),
|
|
52
|
+
key = _ref2[0],
|
|
53
|
+
value = _ref2[1];
|
|
54
|
+
|
|
55
|
+
return "".concat(key, "=").concat(value);
|
|
56
|
+
}).join('; ');
|
|
57
|
+
}
|
|
58
|
+
|
|
39
59
|
var _options$isHeader = options.isHeader,
|
|
40
60
|
isHeader = _options$isHeader === void 0 ? false : _options$isHeader;
|
|
41
61
|
return fetch(encodedUrl, fetchOptions).then(function (response) {
|
|
@@ -58,9 +78,9 @@ export function fetchImage(url) {
|
|
|
58
78
|
imageType: imageType
|
|
59
79
|
};
|
|
60
80
|
});
|
|
61
|
-
}).then(function (
|
|
62
|
-
var buffer =
|
|
63
|
-
imageType =
|
|
81
|
+
}).then(function (_ref3) {
|
|
82
|
+
var buffer = _ref3.buffer,
|
|
83
|
+
imageType = _ref3.imageType;
|
|
64
84
|
var base64Flag = "data:image/".concat(imageType, ";base64,");
|
|
65
85
|
var imageStr = arrayBufferToBase64(buffer);
|
|
66
86
|
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","fetch","self","contentTypes","defaultOptions","cache","fetchImage","url","options","encodedUrl","encodeURI","fetchOptions","isHeader","then","response","contentHeader","headers","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'\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 const { isHeader = false } = options\n\n return fetch(encodedUrl, fetchOptions)\n .then(response => {\n const contentHeader = response.headers.get('content-length')\n const contentType = response.headers.get('content-type')\n\n // NOTE: the response will be ok but we won't be able to render any\n // image meaning pdfmake will error. Raise error here and return early.\n if (contentHeader === '0') {\n return Promise.reject(\n new Error(`Failed to fetch image as no content length: ${encodedUrl}`)\n )\n }\n\n if (!response.ok) {\n return Promise.reject(new Error(`Failed to fetch image: ${encodedUrl}`))\n }\n\n const imageType = contentTypes[contentType]\n\n return response.arrayBuffer().then(buffer => ({\n buffer,\n imageType,\n }))\n })\n .then(({ buffer, imageType }) => {\n const base64Flag = `data:image/${imageType};base64,`\n const imageStr = arrayBufferToBase64(buffer)\n\n const base64 = `${base64Flag}${imageStr}`\n const isValid = validateBase64Image(base64)\n\n if (!isValid) {\n return Promise.reject(new Error('InvalidImageError'))\n }\n\n return base64\n })\n .catch(error => {\n if (isHeader) {\n // NOTE: Replace failed headers with LH logo\n console.error('FetchImageHeaderError', error)\n return fetchImage(LIGHTHOUSE_LOGO_URL, defaultOptions)\n }\n\n console.error(error)\n return imageNotFound\n })\n}\n\nfunction arrayBufferToBase64(buffer) {\n let binary = ''\n const bytes = [].slice.call(new Uint8Array(buffer))\n\n bytes.forEach(b => (binary += String.fromCharCode(b)))\n\n return btoa(binary)\n}\n\nexport function validateBase64Image(base64String) {\n const isJpeg = base64String.startsWith('data:image/jpeg;base64,')\n\n if (isJpeg) return validateJpegImage(base64String)\n\n const isPng = base64String.startsWith('data:image/png;base64,')\n\n if (isPng) return validatePngImage(base64String)\n\n return false\n}\n\n// See SO for more info: https://stackoverflow.com/a/41635312\n// Fiddle: https://jsfiddle.net/Lnyxuchw/\nexport function validateJpegImage(base64string) {\n const src = base64string\n const imageData = Uint8Array.from(\n atob(src.replace('data:image/jpeg;base64,', '')),\n c => c.charCodeAt(0)\n )\n const imageCorrupted =\n imageData[imageData.length - 1] === 217 &&\n imageData[imageData.length - 2] === 255\n\n return imageCorrupted\n}\n\n// See SO for more info: https://stackoverflow.com/a/41635312\n// Fiddle: https://jsfiddle.net/Lnyxuchw/\nexport function validatePngImage(base64string) {\n const src = base64string\n const imageData = Uint8Array.from(\n atob(src.replace('data:image/png;base64,', '')),\n c => c.charCodeAt(0)\n )\n const sequence = [0, 0, 0, 0, 73, 69, 78, 68, 174, 66, 96, 130] // 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","generateCloudFrontCookies","fetch","self","contentTypes","defaultOptions","cache","fetchImage","url","options","encodedUrl","encodeURI","fetchOptions","applicationId","contains","credentials","signedCookies","userId","headers","Cookie","Object","entries","map","key","value","join","isHeader","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 if (url.contains('.cloudfront.net')) {\n fetchOptions.credentials = 'include' // Ensure cookies are sent with the request\n\n const signedCookies = 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\n const { isHeader = false } = options\n\n return fetch(encodedUrl, fetchOptions)\n .then(response => {\n const contentHeader = response.headers.get('content-length')\n const contentType = response.headers.get('content-type')\n\n // NOTE: the response will be ok but we won't be able to render any\n // image meaning pdfmake will error. Raise error here and return early.\n if (contentHeader === '0') {\n return Promise.reject(\n new Error(`Failed to fetch image as no content length: ${encodedUrl}`)\n )\n }\n\n if (!response.ok) {\n return Promise.reject(new Error(`Failed to fetch image: ${encodedUrl}`))\n }\n\n const imageType = contentTypes[contentType]\n\n return response.arrayBuffer().then(buffer => ({\n buffer,\n imageType,\n }))\n })\n .then(({ buffer, imageType }) => {\n const base64Flag = `data:image/${imageType};base64,`\n const imageStr = arrayBufferToBase64(buffer)\n\n const base64 = `${base64Flag}${imageStr}`\n const isValid = validateBase64Image(base64)\n\n if (!isValid) {\n return Promise.reject(new Error('InvalidImageError'))\n }\n\n return base64\n })\n .catch(error => {\n if (isHeader) {\n // NOTE: Replace failed headers with LH logo\n console.error('FetchImageHeaderError', error)\n return fetchImage(LIGHTHOUSE_LOGO_URL, defaultOptions)\n }\n\n console.error(error)\n return imageNotFound\n })\n}\n\nfunction arrayBufferToBase64(buffer) {\n let binary = ''\n const bytes = [].slice.call(new Uint8Array(buffer))\n\n bytes.forEach(b => (binary += String.fromCharCode(b)))\n\n return btoa(binary)\n}\n\nexport function validateBase64Image(base64String) {\n const isJpeg = base64String.startsWith('data:image/jpeg;base64,')\n\n if (isJpeg) return validateJpegImage(base64String)\n\n const isPng = base64String.startsWith('data:image/png;base64,')\n\n if (isPng) return validatePngImage(base64String)\n\n return false\n}\n\n// See SO for more info: https://stackoverflow.com/a/41635312\n// Fiddle: https://jsfiddle.net/Lnyxuchw/\nexport function validateJpegImage(base64string) {\n const src = base64string\n const imageData = Uint8Array.from(\n atob(src.replace('data:image/jpeg;base64,', '')),\n c => c.charCodeAt(0)\n )\n const imageCorrupted =\n imageData[imageData.length - 1] === 217 &&\n imageData[imageData.length - 2] === 255\n\n return imageCorrupted\n}\n\n// See SO for more info: https://stackoverflow.com/a/41635312\n// Fiddle: https://jsfiddle.net/Lnyxuchw/\nexport function validatePngImage(base64string) {\n const src = base64string\n const imageData = Uint8Array.from(\n atob(src.replace('data:image/png;base64,', '')),\n c => c.charCodeAt(0)\n )\n const sequence = [0, 0, 0, 0, 73, 69, 78, 68, 174, 66, 96, 130] // 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"}
|
|
@@ -5,6 +5,7 @@ export function getAuditItemsData(items, data) {
|
|
|
5
5
|
_data$settings = _data$settings === void 0 ? {} : _data$settings;
|
|
6
6
|
var awsS3BaseUrl = _data$settings.awsS3BaseUrl,
|
|
7
7
|
cloudinaryBaseUrl = _data$settings.cloudinaryBaseUrl,
|
|
8
|
+
cloudfrontBaseUrl = _data$settings.cloudfrontBaseUrl,
|
|
8
9
|
_data$entity = data.entity;
|
|
9
10
|
_data$entity = _data$entity === void 0 ? {} : _data$entity;
|
|
10
11
|
var groupScores = _data$entity.groupScores;
|
|
@@ -45,6 +46,7 @@ export function getAuditItemsData(items, data) {
|
|
|
45
46
|
var assets = rawAssets.map(function (asset, assetIndex) {
|
|
46
47
|
var assetUrl = buildFetchUrl(asset, {
|
|
47
48
|
awsS3BaseUrl: awsS3BaseUrl,
|
|
49
|
+
cloudfrontBaseUrl: cloudfrontBaseUrl,
|
|
48
50
|
cloudinaryBaseUrl: cloudinaryBaseUrl,
|
|
49
51
|
fit: true,
|
|
50
52
|
height: 400,
|
|
@@ -54,6 +56,7 @@ export function getAuditItemsData(items, data) {
|
|
|
54
56
|
var link = "".concat(awsS3BaseUrl, "/").concat(asset);
|
|
55
57
|
var thumbnailUrl = buildFetchUrl(asset, {
|
|
56
58
|
awsS3BaseUrl: awsS3BaseUrl,
|
|
59
|
+
cloudfrontBaseUrl: cloudfrontBaseUrl,
|
|
57
60
|
cloudinaryBaseUrl: cloudinaryBaseUrl,
|
|
58
61
|
width: 100,
|
|
59
62
|
quality: 50
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/helpers/get-audit-items-data/index.js"],"names":["find","groupBy","map","get","round","buildFetchUrl","getAuditItemsData","items","data","settings","awsS3BaseUrl","cloudinaryBaseUrl","entity","groupScores","groupedItems","auditData","overallActualScore","overallMaximumScore","groupIndex","key","skipped","group","title","label","groupData","groupMaximumScore","groupActualScore","groupResultScore","groupPercentageResultScore","currentGroupScores","max","actual","result","percentageResult","item","itemIndex","hasScore","score","rawAssets","assets","assetCount","length","asset","assetIndex","assetUrl","fit","height","width","quality","link","thumbnailUrl","comments","matchingScore","scores","value","scoreLabel","scoreWeight","weight","questionId","_id"],"mappings":"AAAA,SAASA,IAAT,EAAeC,OAAf,EAAwBC,GAAxB,EAA6BC,GAA7B,EAAkCC,KAAlC,QAA+C,QAA/C;AAEA,SAASC,aAAT,QAA8B,KAA9B;AAEA,OAAO,SAASC,iBAAT,CAA2BC,KAA3B,EAAkCC,IAAlC,EAAwC;AAAA,uBAIzCA,IAJyC,CAE3CC,QAF2C;AAAA,+
|
|
1
|
+
{"version":3,"sources":["../../../src/helpers/get-audit-items-data/index.js"],"names":["find","groupBy","map","get","round","buildFetchUrl","getAuditItemsData","items","data","settings","awsS3BaseUrl","cloudinaryBaseUrl","cloudfrontBaseUrl","entity","groupScores","groupedItems","auditData","overallActualScore","overallMaximumScore","groupIndex","key","skipped","group","title","label","groupData","groupMaximumScore","groupActualScore","groupResultScore","groupPercentageResultScore","currentGroupScores","max","actual","result","percentageResult","item","itemIndex","hasScore","score","rawAssets","assets","assetCount","length","asset","assetIndex","assetUrl","fit","height","width","quality","link","thumbnailUrl","comments","matchingScore","scores","value","scoreLabel","scoreWeight","weight","questionId","_id"],"mappings":"AAAA,SAASA,IAAT,EAAeC,OAAf,EAAwBC,GAAxB,EAA6BC,GAA7B,EAAkCC,KAAlC,QAA+C,QAA/C;AAEA,SAASC,aAAT,QAA8B,KAA9B;AAEA,OAAO,SAASC,iBAAT,CAA2BC,KAA3B,EAAkCC,IAAlC,EAAwC;AAAA,uBAIzCA,IAJyC,CAE3CC,QAF2C;AAAA,+CAEwB,EAFxB;AAAA,MAE/BC,YAF+B,kBAE/BA,YAF+B;AAAA,MAEjBC,iBAFiB,kBAEjBA,iBAFiB;AAAA,MAEEC,iBAFF,kBAEEA,iBAFF;AAAA,qBAIzCJ,IAJyC,CAG3CK,MAH2C;AAAA,2CAGjB,EAHiB;AAAA,MAGjCC,WAHiC,gBAGjCA,WAHiC;AAM7C,MAAMC,YAAY,GAAGd,OAAO,CAACM,KAAD,EAAQ,UAAR,CAA5B;AAEA,MAAMS,SAAS,GAAG;AAChBC,IAAAA,kBAAkB,EAAE,CADJ;AAEhBC,IAAAA,mBAAmB,EAAE;AAFL,GAAlB;AAKAF,EAAAA,SAAS,CAACT,KAAV,GAAkBL,GAAG,CAACa,YAAD,EAAe,UAACR,KAAD,EAAQY,UAAR,EAAuB;AACzD,QAAMC,GAAG,GAAGD,UAAZ;AACA,QAAME,OAAO,GAAG,CAAC,CAACd,KAAK,CAAC,CAAD,CAAL,CAASe,KAAT,CAAeD,OAAjC;AACA,QAAME,KAAK,GAAGhB,KAAK,CAAC,CAAD,CAAL,CAASe,KAAT,CAAeE,KAA7B;AAEA,QAAMC,SAAS,GAAG;AAChBL,MAAAA,GAAG,EAAHA,GADgB;AAEhBM,MAAAA,iBAAiB,EAAE,CAFH;AAGhBC,MAAAA,gBAAgB,EAAE,CAHF;AAIhBC,MAAAA,gBAAgB,EAAE,CAJF;AAKhBC,MAAAA,0BAA0B,EAAE,CALZ;AAMhBR,MAAAA,OAAO,EAAPA,OANgB;AAOhBE,MAAAA,KAAK,EAALA;AAPgB,KAAlB;AAUA,QAAMO,kBAAkB,GAAG3B,GAAG,CAACW,WAAD,EAAcM,GAAd,CAA9B;;AAEA,QAAIU,kBAAJ,EAAwB;AACtBL,MAAAA,SAAS,CAACC,iBAAV,GAA8BtB,KAAK,CAAC0B,kBAAkB,CAACC,GAApB,EAAyB,CAAzB,CAAnC;AACAN,MAAAA,SAAS,CAACE,gBAAV,GAA6BvB,KAAK,CAAC0B,kBAAkB,CAACE,MAApB,EAA4B,CAA5B,CAAlC;AACAP,MAAAA,SAAS,CAACG,gBAAV,GAA6BE,kBAAkB,CAACG,MAAhD;AACAR,MAAAA,SAAS,CAACI,0BAAV,GAAuCC,kBAAkB,CAACI,gBAA1D;AACD;;AAEDT,IAAAA,SAAS,CAAClB,KAAV,GAAkBA,KAAK,CAACL,GAAN,CAAU,UAACiC,IAAD,EAAOC,SAAP,EAAqB;AAC/C;AACA;AACA;AACA,UAAMC,QAAQ,GAAGF,IAAI,CAACG,KAAL,KAAe,IAAf,IAAuBH,IAAI,CAACG,KAAL,KAAe,CAAC,CAAxD;AACA,UAAMC,SAAS,GAAGJ,IAAI,CAACK,MAAL,IAAe,EAAjC;AACA,UAAMC,UAAU,GAAGF,SAAS,CAACG,MAA7B;AAEA,UAAMF,MAAM,GAAGD,SAAS,CAACrC,GAAV,CAAc,UAACyC,KAAD,EAAQC,UAAR,EAAuB;AAClD,YAAMC,QAAQ,GAAGxC,aAAa,CAACsC,KAAD,EAAQ;AACpCjC,UAAAA,YAAY,EAAZA,YADoC;AAEpCE,UAAAA,iBAAiB,EAAjBA,iBAFoC;AAGpCD,UAAAA,iBAAiB,EAAjBA,iBAHoC;AAIpCmC,UAAAA,GAAG,EAAE,IAJ+B;AAKpCC,UAAAA,MAAM,EAAE,GAL4B;AAMpCC,UAAAA,KAAK,EAAE,GAN6B;AAOpCC,UAAAA,OAAO,EAAE;AAP2B,SAAR,CAA9B;AAUA,YAAMC,IAAI,aAAMxC,YAAN,cAAsBiC,KAAtB,CAAV;AAEA,YAAMQ,YAAY,GAAG9C,aAAa,CAACsC,KAAD,EAAQ;AACxCjC,UAAAA,YAAY,EAAZA,YADwC;AAExCE,UAAAA,iBAAiB,EAAjBA,iBAFwC;AAGxCD,UAAAA,iBAAiB,EAAjBA,iBAHwC;AAIxCqC,UAAAA,KAAK,EAAE,GAJiC;AAKxCC,UAAAA,OAAO,EAAE;AAL+B,SAAR,CAAlC;AAQA,YAAM7B,GAAG,aAAMD,UAAN,yBAA+ByB,UAA/B,CAAT;AAEA,eAAO;AACLC,UAAAA,QAAQ,EAARA,QADK;AAELzB,UAAAA,GAAG,EAAHA,GAFK;AAGL8B,UAAAA,IAAI,EAAJA,IAHK;AAILC,UAAAA,YAAY,EAAZA;AAJK,SAAP;AAMD,OA7Bc,CAAf;AA+BA,UAAMC,QAAQ,GAAGjB,IAAI,CAACiB,QAAtB;AACA,UAAM5B,KAAK,GAAGW,IAAI,CAACX,KAAnB;AACA,UAAMc,KAAK,GAAGH,IAAI,CAACG,KAAnB;AACA,UAAMlB,GAAG,aAAMD,UAAN,mBAAyBiB,SAAzB,CAAT;AACA,UAAMiB,aAAa,GAAGrD,IAAI,CAACmC,IAAI,CAACmB,MAAN,EAAc;AAAEC,QAAAA,KAAK,EAAEjB;AAAT,OAAd,CAA1B,CA3C+C,CA6C/C;;AACA,UAAMkB,UAAU,GACdnB,QAAQ,IAAIgB,aAAZ,IAA6B,CAAChC,OAA9B,GAAwCgC,aAAa,CAAC7B,KAAtD,GAA8D,GADhE;AAEA,UAAMiC,WAAW,GAAGpB,QAAQ,IAAI,CAAChB,OAAb,GAAuBc,IAAI,CAACsB,WAA5B,GAA0C,GAA9D;AACA,UAAMC,MAAM,GAAGrB,QAAQ,GAAGF,IAAI,CAACuB,MAAR,GAAiB,GAAxC;AAEA,aAAO;AACLjB,QAAAA,UAAU,EAAVA,UADK;AAELD,QAAAA,MAAM,EAANA,MAFK;AAGLY,QAAAA,QAAQ,EAARA,QAHK;AAILhC,QAAAA,GAAG,EAAHA,GAJK;AAKLI,QAAAA,KAAK,EAALA,KALK;AAMLmC,QAAAA,UAAU,EAAExB,IAAI,CAACyB,GANZ;AAOLtB,QAAAA,KAAK,EAALA,KAPK;AAQLkB,QAAAA,UAAU,EAAVA,UARK;AASLC,QAAAA,WAAW,EAAXA,WATK;AAULC,QAAAA,MAAM,EAANA;AAVK,OAAP;AAYD,KA/DiB,CAAlB;AAiEA,WAAOjC,SAAP;AACD,GA1FoB,CAArB;AA4FA,SAAOT,SAAP;AACD","sourcesContent":["import { find, groupBy, map, get, round } from 'lodash'\n\nimport { buildFetchUrl } from '../'\n\nexport function getAuditItemsData(items, data) {\n const {\n settings: { awsS3BaseUrl, cloudinaryBaseUrl, cloudfrontBaseUrl } = {},\n entity: { groupScores } = {},\n } = data\n\n const groupedItems = groupBy(items, 'group.id')\n\n const auditData = {\n overallActualScore: 0,\n overallMaximumScore: 0,\n }\n\n auditData.items = map(groupedItems, (items, groupIndex) => {\n const key = groupIndex\n const skipped = !!items[0].group.skipped\n const title = items[0].group.label\n\n const groupData = {\n key,\n groupMaximumScore: 0,\n groupActualScore: 0,\n groupResultScore: 0,\n groupPercentageResultScore: 0,\n skipped,\n title,\n }\n\n const currentGroupScores = get(groupScores, key)\n\n if (currentGroupScores) {\n groupData.groupMaximumScore = round(currentGroupScores.max, 2)\n groupData.groupActualScore = round(currentGroupScores.actual, 2)\n groupData.groupResultScore = currentGroupScores.result\n groupData.groupPercentageResultScore = currentGroupScores.percentageResult\n }\n\n groupData.items = items.map((item, itemIndex) => {\n // NOTE: we handle scores of -1, 0 and 1\n // -1 scores are skipped from group max and actual score\n // 0 and 1 must be included in the final scores\n const hasScore = item.score !== null && item.score !== -1\n const rawAssets = item.assets || []\n const assetCount = rawAssets.length\n\n const assets = rawAssets.map((asset, assetIndex) => {\n const assetUrl = buildFetchUrl(asset, {\n awsS3BaseUrl,\n cloudfrontBaseUrl,\n cloudinaryBaseUrl,\n fit: true,\n height: 400,\n width: 600,\n quality: 50,\n })\n\n const link = `${awsS3BaseUrl}/${asset}`\n\n const thumbnailUrl = buildFetchUrl(asset, {\n awsS3BaseUrl,\n cloudfrontBaseUrl,\n cloudinaryBaseUrl,\n width: 100,\n quality: 50,\n })\n\n const key = `${groupIndex}-item-asset-${assetIndex}`\n\n return {\n assetUrl,\n key,\n link,\n thumbnailUrl,\n }\n })\n\n const comments = item.comments\n const label = item.label\n const score = item.score\n const key = `${groupIndex}-item-${itemIndex}`\n const matchingScore = find(item.scores, { value: score })\n\n // NOTE: ensure we have a score otherwise fallback to - value\n const scoreLabel =\n hasScore && matchingScore && !skipped ? matchingScore.label : '-'\n const scoreWeight = hasScore && !skipped ? item.scoreWeight : '-'\n const weight = hasScore ? item.weight : '-'\n\n return {\n assetCount,\n assets,\n comments,\n key,\n label,\n questionId: item._id,\n score,\n scoreLabel,\n scoreWeight,\n weight,\n }\n })\n\n return groupData\n })\n\n return auditData\n}\n"],"file":"index.js"}
|
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
import _regeneratorRuntime from "@babel/runtime/regenerator";
|
|
2
|
+
import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
|
|
3
|
+
|
|
4
|
+
var _require = require('@aws-sdk/cloudfront-signer'),
|
|
5
|
+
getSignedCookies = _require.getSignedCookies;
|
|
6
|
+
|
|
7
|
+
var _require2 = require('../../aws/secrets-manager'),
|
|
8
|
+
getSecretValue = _require2.getSecretValue;
|
|
9
|
+
|
|
10
|
+
var logger = require('../../logger');
|
|
11
|
+
/**
|
|
12
|
+
* Generate CloudFront signed cookies for authenticated users
|
|
13
|
+
* @param {Object} options - Configuration options
|
|
14
|
+
* @param {string} options.userId - User ID for logging purposes
|
|
15
|
+
* @param {string} options.applicationId - Application ID for resource scoping
|
|
16
|
+
* Return Type: https://docs.aws.amazon.com/AWSJavaScriptSDK/v3/latest/Package/-aws-sdk-cloudfront-signer/Interface/CloudfrontSignedCookiesOutput/
|
|
17
|
+
* @returns {Promise<{
|
|
18
|
+
* "CloudFront-Key-Pair-Id": string,
|
|
19
|
+
* "CloudFront-Signature": string,
|
|
20
|
+
* "CloudFront-Expires"?: number,
|
|
21
|
+
* "CloudFront-Policy"?: string
|
|
22
|
+
* } | null>} Signed cookies object or null if disabled/failed
|
|
23
|
+
*/
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
export function generateCloudFrontCookies(_x) {
|
|
27
|
+
return _generateCloudFrontCookies.apply(this, arguments);
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
function _generateCloudFrontCookies() {
|
|
31
|
+
_generateCloudFrontCookies = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(_ref) {
|
|
32
|
+
var userId, applicationId, privateKey, expiration, distributionDomain, resourcePath, urlPattern, signedCookies;
|
|
33
|
+
return _regeneratorRuntime.wrap(function _callee$(_context) {
|
|
34
|
+
while (1) {
|
|
35
|
+
switch (_context.prev = _context.next) {
|
|
36
|
+
case 0:
|
|
37
|
+
userId = _ref.userId, applicationId = _ref.applicationId;
|
|
38
|
+
|
|
39
|
+
if (!(!process.env.CLOUDFRONT_DOMAIN || !process.env.CLOUDFRONT_KEY_PAIR_ID)) {
|
|
40
|
+
_context.next = 4;
|
|
41
|
+
break;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
logger.debug('CloudFront cookie generation skipped - not configured');
|
|
45
|
+
return _context.abrupt("return", null);
|
|
46
|
+
|
|
47
|
+
case 4:
|
|
48
|
+
_context.prev = 4;
|
|
49
|
+
_context.next = 7;
|
|
50
|
+
return getPrivateKey();
|
|
51
|
+
|
|
52
|
+
case 7:
|
|
53
|
+
privateKey = _context.sent;
|
|
54
|
+
|
|
55
|
+
if (privateKey) {
|
|
56
|
+
_context.next = 11;
|
|
57
|
+
break;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
logger.warn('CloudFront private key not available');
|
|
61
|
+
return _context.abrupt("return", null);
|
|
62
|
+
|
|
63
|
+
case 11:
|
|
64
|
+
// Set expiration time (14 days from now)
|
|
65
|
+
expiration = new Date();
|
|
66
|
+
expiration.setTime(expiration.getTime() + 14 * 24 * 60 * 60 * 1000); // Generate resource URL pattern for wildcard access
|
|
67
|
+
|
|
68
|
+
distributionDomain = "https://".concat(process.env.CLOUDFRONT_DOMAIN);
|
|
69
|
+
resourcePath = applicationId ? "".concat(applicationId, "/*") : '*';
|
|
70
|
+
urlPattern = "".concat(distributionDomain, "/").concat(resourcePath); // Generate signed cookies
|
|
71
|
+
|
|
72
|
+
signedCookies = getSignedCookies({
|
|
73
|
+
url: urlPattern,
|
|
74
|
+
keyPairId: process.env.CLOUDFRONT_KEY_PAIR_ID,
|
|
75
|
+
privateKey: privateKey,
|
|
76
|
+
dateLessThan: expiration.getTime() // Use epoch timestamp in milliseconds
|
|
77
|
+
|
|
78
|
+
});
|
|
79
|
+
logger.info('CloudFront cookies generated successfully', {
|
|
80
|
+
userId: userId,
|
|
81
|
+
applicationId: applicationId,
|
|
82
|
+
resourcePath: resourcePath,
|
|
83
|
+
expiration: expiration.toISOString()
|
|
84
|
+
});
|
|
85
|
+
return _context.abrupt("return", signedCookies);
|
|
86
|
+
|
|
87
|
+
case 21:
|
|
88
|
+
_context.prev = 21;
|
|
89
|
+
_context.t0 = _context["catch"](4);
|
|
90
|
+
logger.error('Failed to generate CloudFront cookies', {
|
|
91
|
+
userId: userId,
|
|
92
|
+
applicationId: applicationId,
|
|
93
|
+
error: {
|
|
94
|
+
message: _context.t0.message,
|
|
95
|
+
code: _context.t0.code
|
|
96
|
+
}
|
|
97
|
+
});
|
|
98
|
+
return _context.abrupt("return", null);
|
|
99
|
+
|
|
100
|
+
case 25:
|
|
101
|
+
case "end":
|
|
102
|
+
return _context.stop();
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}, _callee, null, [[4, 21]]);
|
|
106
|
+
}));
|
|
107
|
+
return _generateCloudFrontCookies.apply(this, arguments);
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
var privateKeyCache = null;
|
|
111
|
+
var cacheExpiry = null;
|
|
112
|
+
var CACHE_TTL = 5 * 60 * 1000; // 5 minutes
|
|
113
|
+
|
|
114
|
+
function getPrivateKey() {
|
|
115
|
+
return _getPrivateKey.apply(this, arguments);
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
function _getPrivateKey() {
|
|
119
|
+
_getPrivateKey = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2() {
|
|
120
|
+
var now, privateKey;
|
|
121
|
+
return _regeneratorRuntime.wrap(function _callee2$(_context2) {
|
|
122
|
+
while (1) {
|
|
123
|
+
switch (_context2.prev = _context2.next) {
|
|
124
|
+
case 0:
|
|
125
|
+
now = Date.now();
|
|
126
|
+
|
|
127
|
+
if (!(privateKeyCache && cacheExpiry && now < cacheExpiry)) {
|
|
128
|
+
_context2.next = 3;
|
|
129
|
+
break;
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
return _context2.abrupt("return", privateKeyCache);
|
|
133
|
+
|
|
134
|
+
case 3:
|
|
135
|
+
if (process.env.CLOUDFRONT_PRIVATE_KEY_SECRET_ID) {
|
|
136
|
+
_context2.next = 6;
|
|
137
|
+
break;
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
logger.warn('CLOUDFRONT_PRIVATE_KEY_SECRET_ID not configured');
|
|
141
|
+
return _context2.abrupt("return", null);
|
|
142
|
+
|
|
143
|
+
case 6:
|
|
144
|
+
_context2.prev = 6;
|
|
145
|
+
_context2.next = 9;
|
|
146
|
+
return getSecretValue(process.env.CLOUDFRONT_PRIVATE_KEY_SECRET_ID, 'CLOUDFRONT_PRIVATE_KEY');
|
|
147
|
+
|
|
148
|
+
case 9:
|
|
149
|
+
privateKey = _context2.sent;
|
|
150
|
+
privateKeyCache = privateKey;
|
|
151
|
+
cacheExpiry = now + CACHE_TTL;
|
|
152
|
+
logger.debug('CloudFront private key retrieved and cached');
|
|
153
|
+
return _context2.abrupt("return", privateKey);
|
|
154
|
+
|
|
155
|
+
case 16:
|
|
156
|
+
_context2.prev = 16;
|
|
157
|
+
_context2.t0 = _context2["catch"](6);
|
|
158
|
+
logger.error('Failed to retrieve CloudFront private key', {
|
|
159
|
+
secretId: process.env.CLOUDFRONT_PRIVATE_KEY_SECRET_ID,
|
|
160
|
+
error: {
|
|
161
|
+
message: _context2.t0.message,
|
|
162
|
+
code: _context2.t0.code
|
|
163
|
+
}
|
|
164
|
+
});
|
|
165
|
+
return _context2.abrupt("return", null);
|
|
166
|
+
|
|
167
|
+
case 20:
|
|
168
|
+
case "end":
|
|
169
|
+
return _context2.stop();
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
}, _callee2, null, [[6, 16]]);
|
|
173
|
+
}));
|
|
174
|
+
return _getPrivateKey.apply(this, arguments);
|
|
175
|
+
}
|
|
176
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/helpers/get-cloudfront-cookies/index.js"],"names":["require","getSignedCookies","getSecretValue","logger","generateCloudFrontCookies","userId","applicationId","process","env","CLOUDFRONT_DOMAIN","CLOUDFRONT_KEY_PAIR_ID","debug","getPrivateKey","privateKey","warn","expiration","Date","setTime","getTime","distributionDomain","resourcePath","urlPattern","signedCookies","url","keyPairId","dateLessThan","info","toISOString","error","message","code","privateKeyCache","cacheExpiry","CACHE_TTL","now","CLOUDFRONT_PRIVATE_KEY_SECRET_ID","secretId"],"mappings":"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","sourcesContent":["const { getSignedCookies } = require('@aws-sdk/cloudfront-signer')\nconst { getSecretValue } = require('../../aws/secrets-manager')\nconst logger = require('../../logger')\n\n/**\n * Generate CloudFront signed cookies for authenticated users\n * @param {Object} options - Configuration options\n * @param {string} options.userId - User ID for logging purposes\n * @param {string} options.applicationId - Application ID for resource scoping\n * Return Type: https://docs.aws.amazon.com/AWSJavaScriptSDK/v3/latest/Package/-aws-sdk-cloudfront-signer/Interface/CloudfrontSignedCookiesOutput/\n * @returns {Promise<{\n * \"CloudFront-Key-Pair-Id\": string,\n * \"CloudFront-Signature\": string,\n * \"CloudFront-Expires\"?: number,\n * \"CloudFront-Policy\"?: string\n * } | null>} Signed cookies object or null if disabled/failed\n */\n\nexport async function generateCloudFrontCookies({ userId, applicationId }) {\n // Early return if CloudFront is not configured\n if (!process.env.CLOUDFRONT_DOMAIN || !process.env.CLOUDFRONT_KEY_PAIR_ID) {\n logger.debug('CloudFront cookie generation skipped - not configured')\n return null\n }\n\n try {\n // Get private key from AWS Secrets Manager\n const privateKey = await getPrivateKey()\n if (!privateKey) {\n logger.warn('CloudFront private key not available')\n return null\n }\n\n // Set expiration time (14 days from now)\n const expiration = new Date()\n expiration.setTime(expiration.getTime() + 14 * 24 * 60 * 60 * 1000)\n\n // Generate resource URL pattern for wildcard access\n const distributionDomain = `https://${process.env.CLOUDFRONT_DOMAIN}`\n const resourcePath = applicationId ? `${applicationId}/*` : '*'\n const urlPattern = `${distributionDomain}/${resourcePath}`\n\n // Generate signed cookies\n const signedCookies = getSignedCookies({\n url: urlPattern,\n keyPairId: process.env.CLOUDFRONT_KEY_PAIR_ID,\n privateKey: privateKey,\n dateLessThan: expiration.getTime(), // Use epoch timestamp in milliseconds\n })\n\n logger.info('CloudFront cookies generated successfully', {\n userId,\n applicationId,\n resourcePath,\n expiration: expiration.toISOString(),\n })\n\n return signedCookies\n } catch (error) {\n logger.error('Failed to generate CloudFront cookies', {\n userId,\n applicationId,\n error: {\n message: error.message,\n code: error.code,\n },\n })\n return null\n }\n}\n\nlet privateKeyCache = null\nlet cacheExpiry = null\nconst CACHE_TTL = 5 * 60 * 1000 // 5 minutes\n\nasync function getPrivateKey() {\n const now = Date.now()\n\n if (privateKeyCache && cacheExpiry && now < cacheExpiry) {\n return privateKeyCache\n }\n\n if (!process.env.CLOUDFRONT_PRIVATE_KEY_SECRET_ID) {\n logger.warn('CLOUDFRONT_PRIVATE_KEY_SECRET_ID not configured')\n return null\n }\n\n try {\n const privateKey = await getSecretValue(\n process.env.CLOUDFRONT_PRIVATE_KEY_SECRET_ID,\n 'CLOUDFRONT_PRIVATE_KEY'\n )\n\n privateKeyCache = privateKey\n cacheExpiry = now + CACHE_TTL\n\n logger.debug('CloudFront private key retrieved and cached')\n return privateKey\n } catch (error) {\n logger.error('Failed to retrieve CloudFront private key', {\n secretId: process.env.CLOUDFRONT_PRIVATE_KEY_SECRET_ID,\n error: {\n message: error.message,\n code: error.code,\n },\n })\n return null\n }\n}\n"],"file":"index.js"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { errors } from '@lighthouse/common-errors';
|
|
2
|
+
import AWS from 'aws-sdk';
|
|
3
|
+
import { attempt, isError } from 'lodash';
|
|
4
|
+
export default function getSecretValue(secretId, secretKey) {
|
|
5
|
+
if (!secretId) {
|
|
6
|
+
return Promise.reject(new errors.ValidationError("Missing required param: secretId:".concat(secretId)));
|
|
7
|
+
} // TODO: update these credentials to specific values for service
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
var secretsClient = new AWS.SecretsManager({
|
|
11
|
+
accessKeyId: process.env.AWS_KEY,
|
|
12
|
+
region: process.env.AWS_SECRET_MANAGER_REGION,
|
|
13
|
+
secretAccessKey: process.env.AWS_SECRET
|
|
14
|
+
});
|
|
15
|
+
return secretsClient.getSecretValue({
|
|
16
|
+
SecretId: secretId
|
|
17
|
+
}).promise().then(function (payload) {
|
|
18
|
+
var secret = parseSecretString(payload); // Return early if secretKey isn't defined (we want the full set of key/values)
|
|
19
|
+
|
|
20
|
+
if (!secretKey) return secret;
|
|
21
|
+
var secretValue = secret[secretKey];
|
|
22
|
+
|
|
23
|
+
if (!secretValue) {
|
|
24
|
+
throw new errors.NotFoundError('Secret value could not be found');
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
return secretValue;
|
|
28
|
+
}).catch(function (err) {
|
|
29
|
+
throw new errors.UnknownError("AWSSecretFetchError: ".concat(err.code, ", ").concat(err.message));
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
function parseSecretString(payload) {
|
|
34
|
+
var secretString = payload.SecretString || '';
|
|
35
|
+
var parsed = attempt(JSON.parse, secretString);
|
|
36
|
+
return isError(parsed) ? {} : parsed;
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/helpers/get-secret-value/index.js"],"names":["errors","AWS","attempt","isError","getSecretValue","secretId","secretKey","Promise","reject","ValidationError","secretsClient","SecretsManager","accessKeyId","process","env","AWS_KEY","region","AWS_SECRET_MANAGER_REGION","secretAccessKey","AWS_SECRET","SecretId","promise","then","payload","secret","parseSecretString","secretValue","NotFoundError","catch","err","UnknownError","code","message","secretString","SecretString","parsed","JSON","parse"],"mappings":"AAAA,SAASA,MAAT,QAAuB,2BAAvB;AACA,OAAOC,GAAP,MAAgB,SAAhB;AACA,SAASC,OAAT,EAAkBC,OAAlB,QAAiC,QAAjC;AAEA,eAAe,SAASC,cAAT,CAAwBC,QAAxB,EAAkCC,SAAlC,EAA6C;AAC1D,MAAI,CAACD,QAAL,EAAe;AACb,WAAOE,OAAO,CAACC,MAAR,CACL,IAAIR,MAAM,CAACS,eAAX,4CAA+DJ,QAA/D,EADK,CAAP;AAGD,GALyD,CAO1D;;;AACA,MAAMK,aAAa,GAAG,IAAIT,GAAG,CAACU,cAAR,CAAuB;AAC3CC,IAAAA,WAAW,EAAEC,OAAO,CAACC,GAAR,CAAYC,OADkB;AAE3CC,IAAAA,MAAM,EAAEH,OAAO,CAACC,GAAR,CAAYG,yBAFuB;AAG3CC,IAAAA,eAAe,EAAEL,OAAO,CAACC,GAAR,CAAYK;AAHc,GAAvB,CAAtB;AAMA,SAAOT,aAAa,CACjBN,cADI,CACW;AAAEgB,IAAAA,QAAQ,EAAEf;AAAZ,GADX,EAEJgB,OAFI,GAGJC,IAHI,CAGC,UAAAC,OAAO,EAAI;AACf,QAAMC,MAAM,GAAGC,iBAAiB,CAACF,OAAD,CAAhC,CADe,CAGf;;AACA,QAAI,CAACjB,SAAL,EAAgB,OAAOkB,MAAP;AAEhB,QAAME,WAAW,GAAGF,MAAM,CAAClB,SAAD,CAA1B;;AAEA,QAAI,CAACoB,WAAL,EAAkB;AAChB,YAAM,IAAI1B,MAAM,CAAC2B,aAAX,CAAyB,iCAAzB,CAAN;AACD;;AAED,WAAOD,WAAP;AACD,GAhBI,EAiBJE,KAjBI,CAiBE,UAAAC,GAAG,EAAI;AACZ,UAAM,IAAI7B,MAAM,CAAC8B,YAAX,gCACoBD,GAAG,CAACE,IADxB,eACiCF,GAAG,CAACG,OADrC,EAAN;AAGD,GArBI,CAAP;AAsBD;;AAED,SAASP,iBAAT,CAA2BF,OAA3B,EAAoC;AAClC,MAAMU,YAAY,GAAGV,OAAO,CAACW,YAAR,IAAwB,EAA7C;AAEA,MAAMC,MAAM,GAAGjC,OAAO,CAACkC,IAAI,CAACC,KAAN,EAAaJ,YAAb,CAAtB;AAEA,SAAO9B,OAAO,CAACgC,MAAD,CAAP,GAAkB,EAAlB,GAAuBA,MAA9B;AACD","sourcesContent":["import { errors } from '@lighthouse/common-errors'\nimport AWS from 'aws-sdk'\nimport { attempt, isError } from 'lodash'\n\nexport default function getSecretValue(secretId, secretKey) {\n if (!secretId) {\n return Promise.reject(\n new errors.ValidationError(`Missing required param: secretId:${secretId}`)\n )\n }\n\n // TODO: update these credentials to specific values for service\n const secretsClient = new AWS.SecretsManager({\n accessKeyId: process.env.AWS_KEY,\n region: process.env.AWS_SECRET_MANAGER_REGION,\n secretAccessKey: process.env.AWS_SECRET,\n })\n\n return secretsClient\n .getSecretValue({ SecretId: secretId })\n .promise()\n .then(payload => {\n const secret = parseSecretString(payload)\n\n // Return early if secretKey isn't defined (we want the full set of key/values)\n if (!secretKey) return secret\n\n const secretValue = secret[secretKey]\n\n if (!secretValue) {\n throw new errors.NotFoundError('Secret value could not be found')\n }\n\n return secretValue\n })\n .catch(err => {\n throw new errors.UnknownError(\n `AWSSecretFetchError: ${err.code}, ${err.message}`\n )\n })\n}\n\nfunction parseSecretString(payload) {\n const secretString = payload.SecretString || ''\n\n const parsed = attempt(JSON.parse, secretString)\n\n return isError(parsed) ? {} : parsed\n}\n"],"file":"index.js"}
|
|
@@ -29,7 +29,8 @@ function buildImage(options) {
|
|
|
29
29
|
_options$width = options.width,
|
|
30
30
|
width = _options$width === void 0 ? 210 : _options$width;
|
|
31
31
|
var awsS3BaseUrl = settings.awsS3BaseUrl,
|
|
32
|
-
cloudinaryBaseUrl = settings.cloudinaryBaseUrl
|
|
32
|
+
cloudinaryBaseUrl = settings.cloudinaryBaseUrl,
|
|
33
|
+
cloudfrontBaseUrl = settings.cloudfrontBaseUrl;
|
|
33
34
|
var isVideoType = new RegExp('.mp4$').test(filepath);
|
|
34
35
|
var link = "".concat(awsS3BaseUrl, "/").concat(filepath);
|
|
35
36
|
|
|
@@ -44,6 +45,7 @@ function buildImage(options) {
|
|
|
44
45
|
|
|
45
46
|
var url = buildFetchUrl(filepath, {
|
|
46
47
|
awsS3BaseUrl: awsS3BaseUrl,
|
|
48
|
+
cloudfrontBaseUrl: cloudfrontBaseUrl,
|
|
47
49
|
cloudinaryBaseUrl: cloudinaryBaseUrl,
|
|
48
50
|
fit: true,
|
|
49
51
|
height: 400,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/pdf/helpers/fields/index.js"],"names":["isArray","isEmpty","join","first","map","startsWith","Promise","moment","buildFetchUrl","fetchImage","videoIcon","imageTables","parseValue","text","toPdf","buildFile","file","settings","extension","name","path","awsS3BaseUrl","link","margin","buildImage","options","alignment","filepath","height","width","cloudinaryBaseUrl","isVideoType","RegExp","test","fit","image","url","quality","then","base64String","buildSummaryField","field","timezone","fieldtype","value","isDayFirstDateField","format","isMonthFirstDateField","isFileField","isHtmlField","type","isNumberField","isPhotoField","isReferenceField","isSelectField","isSignatureField","isStarField","isSwitchField","isTextField","is12HourTimeField","is24HourTimeField","isDataImage","fileList","ol","parsedValue","displayValue","fontSize","filter","val","label","tz","buildTemplateFieldRow","skipped","showOnRead","isDisplayImageField","labelText","parsed","replace","values","fieldImages","tables","imagesRow","colSpan","layout","hLineWidth","paddingLeft","paddingRight","paddingTop","paddingBottom","vLineWidth","table","body","widths","string"],"mappings":"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","sourcesContent":["import { isArray, isEmpty, join, first, map, startsWith } from 'lodash'\nimport Promise from 'bluebird'\nimport moment from 'moment-timezone'\n\nimport { buildFetchUrl, fetchImage } from '../../../helpers'\nimport { videoIcon } from '../../../images'\nimport { imageTables, parseValue, text, toPdf } from '../'\n\nexport function buildFile({ file, settings }) {\n const { extension, name, path } = file\n const { awsS3BaseUrl } = settings\n\n const link = `${awsS3BaseUrl}/${path}`\n return text(`${name}.${extension}`, { link, margin: [0, 0, 0, 10] })\n}\n\nfunction buildImage(options) {\n const {\n alignment = 'center',\n filepath,\n height = 210,\n settings,\n width = 210,\n } = options\n const { awsS3BaseUrl, cloudinaryBaseUrl } = settings\n\n const isVideoType = new RegExp('.mp4$').test(filepath)\n const link = `${awsS3BaseUrl}/${filepath}`\n\n if (isVideoType) {\n return {\n alignment,\n fit: [width, height],\n image: videoIcon,\n link,\n }\n }\n\n const url = buildFetchUrl(filepath, {\n awsS3BaseUrl,\n cloudinaryBaseUrl,\n fit: true,\n height: 400,\n width: 600,\n quality: 50,\n })\n\n return fetchImage(url).then(base64String => ({\n alignment,\n fit: [width, height],\n image: base64String,\n link,\n }))\n}\n\nexport function buildSummaryField({ field, settings, timezone }) {\n const { fieldtype, options = {}, value } = field\n\n const isDayFirstDateField =\n fieldtype === 'date' && options.format === 'DD/MM/YY'\n const isMonthFirstDateField =\n fieldtype === 'date' && options.format === 'MM/DD/YY'\n const isFileField = fieldtype === 'file'\n const isHtmlField = fieldtype === 'text' && options.type === 'html'\n const isNumberField = fieldtype === 'number'\n const isPhotoField = fieldtype === 'list' && options.type === 'media'\n const isReferenceField = fieldtype === 'reference'\n const isSelectField = fieldtype === 'select' && options.type !== 'stars'\n const isSignatureField = fieldtype === 'text' && options.type === 'signature'\n const isStarField = fieldtype === 'select' && options.type === 'stars'\n const isSwitchField = fieldtype === 'switch'\n const isTextField = fieldtype === 'text'\n const is12HourTimeField = fieldtype === 'time' && options.format === 'h:mm a'\n const is24HourTimeField = fieldtype === 'time' && options.format === 'HH:mm'\n\n // NOTE: html field is not supported for the summary fields but adding\n // logic to catch this and return empty text for completeness\n if (isHtmlField) {\n return { text: '' }\n }\n\n if (isSignatureField) {\n if (!value) return ''\n\n if (isDataImage(value)) {\n return { alignment: 'left', image: value, width: 140 }\n }\n\n return fetchImage(value).then(base64String => {\n return {\n alignment: 'left',\n image: base64String,\n width: 140,\n }\n })\n }\n\n if (isPhotoField) {\n const filepath = first(value)\n\n // NOTE: if no filepath return empty text as user has not uploaded an image\n // for this field\n if (!filepath) {\n return { text: '' }\n }\n\n const image = buildImage({\n alignment: 'left',\n filepath,\n height: 140,\n width: 140,\n settings,\n })\n\n return image\n }\n\n if (isFileField) {\n const fileList = map(value, file => buildFile({ file, settings }))\n return { ol: fileList }\n }\n\n if (isNumberField || isSelectField || isSwitchField || isTextField) {\n const parsedValue = parseValue(value)\n const displayValue = isArray(parsedValue)\n ? { text: join(parsedValue, ', '), fontSize: 7 }\n : { text: parsedValue, fontSize: 7 }\n\n return displayValue\n }\n\n if (isReferenceField) {\n const parsedValue = parseValue(value)\n const displayValue = isArray(parsedValue)\n ? {\n text: parsedValue\n .filter(val => val && val.label)\n .map(val => val.label)\n .join(', '),\n fontSize: 7,\n }\n : { text: parsedValue.label, fontSize: 7 }\n\n return displayValue\n }\n\n if (isStarField) {\n if (!value) return ''\n const displayValue = value === '1' ? `${value} star` : `${value} stars`\n return displayValue\n }\n\n if (\n isDayFirstDateField ||\n isMonthFirstDateField ||\n is12HourTimeField ||\n is24HourTimeField\n ) {\n const format = options.format\n const displayValue = moment(value)\n .tz(timezone)\n .format(format)\n\n return displayValue\n }\n\n // NOTE: return empty text fallback value when no match\n return { text: '' }\n}\n\nexport function buildTemplateFieldRow({ field, settings, timezone, skipped }) {\n const { fieldtype, label, options = {}, value } = field\n const { showOnRead = true } = options\n\n const isDayFirstDateField =\n fieldtype === 'date' && options.format === 'DD/MM/YY'\n const isMonthFirstDateField =\n fieldtype === 'date' && options.format === 'MM/DD/YY'\n const isFileField = fieldtype === 'file'\n const isHtmlField = fieldtype === 'text' && options.type === 'html'\n const isNumberField = fieldtype === 'number'\n const isPhotoField = fieldtype === 'list' && options.type === 'media'\n const isSelectField = fieldtype === 'select' && options.type !== 'stars'\n const isSignatureField = fieldtype === 'text' && options.type === 'signature'\n const isStarField = fieldtype === 'select' && options.type === 'stars'\n const isSwitchField = fieldtype === 'switch'\n const isTextField = fieldtype === 'text'\n const is12HourTimeField = fieldtype === 'time' && options.format === 'h:mm a'\n const is24HourTimeField = fieldtype === 'time' && options.format === 'HH:mm'\n const isDisplayImageField = fieldtype === 'image-display' && showOnRead\n const isReferenceField = fieldtype === 'reference'\n\n // NOTE: only show field when show on read is true\n if (!showOnRead) return null\n\n const labelText = [{ text: label }]\n\n if (skipped) {\n return [labelText, [{ text: '-' }]]\n }\n\n if (isHtmlField) {\n const parsed = value.replace(/<p><\\/p>/g, '')\n return [labelText, toPdf(parsed)]\n }\n\n if (isSignatureField) {\n if (!value) return [labelText, '']\n\n return fetchImage(value).then(base64String => {\n const values = {\n alignment: 'left',\n image: base64String,\n width: 140,\n }\n return [labelText, values]\n })\n }\n\n if (isDisplayImageField) {\n return Promise.map([value], filepath =>\n buildImage({ filepath, settings })\n ).then(fieldImages => [fieldImages, {}])\n }\n\n if (isPhotoField) {\n return Promise.map(value, filepath =>\n buildImage({ filepath, settings })\n ).then(fieldImages => {\n const tables = !isEmpty(fieldImages) ? imageTables(fieldImages) : []\n\n const imagesRow = {\n colSpan: 2,\n layout: {\n hLineWidth: () => 0,\n paddingLeft: () => 0,\n paddingRight: () => 0,\n paddingTop: () => 0,\n paddingBottom: () => 0,\n vLineWidth: () => 0,\n },\n table: {\n body: [labelText, ...tables],\n widths: ['*'],\n },\n }\n\n // NOTE: pass empty value here as otherwise\n // we can accidentally hide content below\n // this row. Please see the following issue:\n // https://github.com/bpampuch/pdfmake/issues/1598\n return [imagesRow, {}]\n })\n }\n\n if (isFileField) {\n const fileList = map(value, file => buildFile({ file, settings }))\n return [labelText, { ol: fileList }]\n }\n\n if (isNumberField || isSelectField || isSwitchField || isTextField) {\n const parsedValue = parseValue(value)\n const displayValue = isArray(parsedValue)\n ? { text: join(parsedValue, ', ') }\n : { text: parsedValue }\n\n return [labelText, displayValue]\n }\n\n if (isReferenceField) {\n const parsedValue = parseValue(value)\n const displayValue = isArray(parsedValue)\n ? {\n text: parsedValue\n .filter(val => val && val.label)\n .map(val => val.label)\n .join(', '),\n fontSize: 7,\n }\n : { text: parsedValue.label, fontSize: 7 }\n\n return [labelText, displayValue]\n }\n\n if (isStarField) {\n if (!value) return [labelText, '']\n const displayValue = value === '1' ? `${value} star` : `${value} stars`\n return [labelText, displayValue]\n }\n\n if (\n isDayFirstDateField ||\n isMonthFirstDateField ||\n is12HourTimeField ||\n is24HourTimeField\n ) {\n const format = options.format\n const displayValue = value\n ? moment(value)\n .tz(timezone)\n .format(format)\n : ''\n\n return [labelText, displayValue]\n }\n\n // NOTE: if no match above null values will be stripped within calling fn\n return null\n}\n\nfunction isDataImage(string) {\n return startsWith(string, 'data:image/png;')\n}\n"],"file":"index.js"}
|
|
1
|
+
{"version":3,"sources":["../../../../src/pdf/helpers/fields/index.js"],"names":["isArray","isEmpty","join","first","map","startsWith","Promise","moment","buildFetchUrl","fetchImage","videoIcon","imageTables","parseValue","text","toPdf","buildFile","file","settings","extension","name","path","awsS3BaseUrl","link","margin","buildImage","options","alignment","filepath","height","width","cloudinaryBaseUrl","cloudfrontBaseUrl","isVideoType","RegExp","test","fit","image","url","quality","then","base64String","buildSummaryField","field","timezone","fieldtype","value","isDayFirstDateField","format","isMonthFirstDateField","isFileField","isHtmlField","type","isNumberField","isPhotoField","isReferenceField","isSelectField","isSignatureField","isStarField","isSwitchField","isTextField","is12HourTimeField","is24HourTimeField","isDataImage","fileList","ol","parsedValue","displayValue","fontSize","filter","val","label","tz","buildTemplateFieldRow","skipped","showOnRead","isDisplayImageField","labelText","parsed","replace","values","fieldImages","tables","imagesRow","colSpan","layout","hLineWidth","paddingLeft","paddingRight","paddingTop","paddingBottom","vLineWidth","table","body","widths","string"],"mappings":"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","sourcesContent":["import { isArray, isEmpty, join, first, map, startsWith } from 'lodash'\nimport Promise from 'bluebird'\nimport moment from 'moment-timezone'\n\nimport { buildFetchUrl, fetchImage } from '../../../helpers'\nimport { videoIcon } from '../../../images'\nimport { imageTables, parseValue, text, toPdf } from '../'\n\nexport function buildFile({ file, settings }) {\n const { extension, name, path } = file\n const { awsS3BaseUrl } = settings\n\n const link = `${awsS3BaseUrl}/${path}`\n return text(`${name}.${extension}`, { link, margin: [0, 0, 0, 10] })\n}\n\nfunction buildImage(options) {\n const {\n alignment = 'center',\n filepath,\n height = 210,\n settings,\n width = 210,\n } = options\n const { awsS3BaseUrl, cloudinaryBaseUrl, cloudfrontBaseUrl } = settings\n\n const isVideoType = new RegExp('.mp4$').test(filepath)\n const link = `${awsS3BaseUrl}/${filepath}`\n\n if (isVideoType) {\n return {\n alignment,\n fit: [width, height],\n image: videoIcon,\n link,\n }\n }\n\n const url = buildFetchUrl(filepath, {\n awsS3BaseUrl,\n cloudfrontBaseUrl,\n cloudinaryBaseUrl,\n fit: true,\n height: 400,\n width: 600,\n quality: 50,\n })\n\n return fetchImage(url).then(base64String => ({\n alignment,\n fit: [width, height],\n image: base64String,\n link,\n }))\n}\n\nexport function buildSummaryField({ field, settings, timezone }) {\n const { fieldtype, options = {}, value } = field\n\n const isDayFirstDateField =\n fieldtype === 'date' && options.format === 'DD/MM/YY'\n const isMonthFirstDateField =\n fieldtype === 'date' && options.format === 'MM/DD/YY'\n const isFileField = fieldtype === 'file'\n const isHtmlField = fieldtype === 'text' && options.type === 'html'\n const isNumberField = fieldtype === 'number'\n const isPhotoField = fieldtype === 'list' && options.type === 'media'\n const isReferenceField = fieldtype === 'reference'\n const isSelectField = fieldtype === 'select' && options.type !== 'stars'\n const isSignatureField = fieldtype === 'text' && options.type === 'signature'\n const isStarField = fieldtype === 'select' && options.type === 'stars'\n const isSwitchField = fieldtype === 'switch'\n const isTextField = fieldtype === 'text'\n const is12HourTimeField = fieldtype === 'time' && options.format === 'h:mm a'\n const is24HourTimeField = fieldtype === 'time' && options.format === 'HH:mm'\n\n // NOTE: html field is not supported for the summary fields but adding\n // logic to catch this and return empty text for completeness\n if (isHtmlField) {\n return { text: '' }\n }\n\n if (isSignatureField) {\n if (!value) return ''\n\n if (isDataImage(value)) {\n return { alignment: 'left', image: value, width: 140 }\n }\n\n return fetchImage(value).then(base64String => {\n return {\n alignment: 'left',\n image: base64String,\n width: 140,\n }\n })\n }\n\n if (isPhotoField) {\n const filepath = first(value)\n\n // NOTE: if no filepath return empty text as user has not uploaded an image\n // for this field\n if (!filepath) {\n return { text: '' }\n }\n\n const image = buildImage({\n alignment: 'left',\n filepath,\n height: 140,\n width: 140,\n settings,\n })\n\n return image\n }\n\n if (isFileField) {\n const fileList = map(value, file => buildFile({ file, settings }))\n return { ol: fileList }\n }\n\n if (isNumberField || isSelectField || isSwitchField || isTextField) {\n const parsedValue = parseValue(value)\n const displayValue = isArray(parsedValue)\n ? { text: join(parsedValue, ', '), fontSize: 7 }\n : { text: parsedValue, fontSize: 7 }\n\n return displayValue\n }\n\n if (isReferenceField) {\n const parsedValue = parseValue(value)\n const displayValue = isArray(parsedValue)\n ? {\n text: parsedValue\n .filter(val => val && val.label)\n .map(val => val.label)\n .join(', '),\n fontSize: 7,\n }\n : { text: parsedValue.label, fontSize: 7 }\n\n return displayValue\n }\n\n if (isStarField) {\n if (!value) return ''\n const displayValue = value === '1' ? `${value} star` : `${value} stars`\n return displayValue\n }\n\n if (\n isDayFirstDateField ||\n isMonthFirstDateField ||\n is12HourTimeField ||\n is24HourTimeField\n ) {\n const format = options.format\n const displayValue = moment(value)\n .tz(timezone)\n .format(format)\n\n return displayValue\n }\n\n // NOTE: return empty text fallback value when no match\n return { text: '' }\n}\n\nexport function buildTemplateFieldRow({ field, settings, timezone, skipped }) {\n const { fieldtype, label, options = {}, value } = field\n const { showOnRead = true } = options\n\n const isDayFirstDateField =\n fieldtype === 'date' && options.format === 'DD/MM/YY'\n const isMonthFirstDateField =\n fieldtype === 'date' && options.format === 'MM/DD/YY'\n const isFileField = fieldtype === 'file'\n const isHtmlField = fieldtype === 'text' && options.type === 'html'\n const isNumberField = fieldtype === 'number'\n const isPhotoField = fieldtype === 'list' && options.type === 'media'\n const isSelectField = fieldtype === 'select' && options.type !== 'stars'\n const isSignatureField = fieldtype === 'text' && options.type === 'signature'\n const isStarField = fieldtype === 'select' && options.type === 'stars'\n const isSwitchField = fieldtype === 'switch'\n const isTextField = fieldtype === 'text'\n const is12HourTimeField = fieldtype === 'time' && options.format === 'h:mm a'\n const is24HourTimeField = fieldtype === 'time' && options.format === 'HH:mm'\n const isDisplayImageField = fieldtype === 'image-display' && showOnRead\n const isReferenceField = fieldtype === 'reference'\n\n // NOTE: only show field when show on read is true\n if (!showOnRead) return null\n\n const labelText = [{ text: label }]\n\n if (skipped) {\n return [labelText, [{ text: '-' }]]\n }\n\n if (isHtmlField) {\n const parsed = value.replace(/<p><\\/p>/g, '')\n return [labelText, toPdf(parsed)]\n }\n\n if (isSignatureField) {\n if (!value) return [labelText, '']\n\n return fetchImage(value).then(base64String => {\n const values = {\n alignment: 'left',\n image: base64String,\n width: 140,\n }\n return [labelText, values]\n })\n }\n\n if (isDisplayImageField) {\n return Promise.map([value], filepath =>\n buildImage({ filepath, settings })\n ).then(fieldImages => [fieldImages, {}])\n }\n\n if (isPhotoField) {\n return Promise.map(value, filepath =>\n buildImage({ filepath, settings })\n ).then(fieldImages => {\n const tables = !isEmpty(fieldImages) ? imageTables(fieldImages) : []\n\n const imagesRow = {\n colSpan: 2,\n layout: {\n hLineWidth: () => 0,\n paddingLeft: () => 0,\n paddingRight: () => 0,\n paddingTop: () => 0,\n paddingBottom: () => 0,\n vLineWidth: () => 0,\n },\n table: {\n body: [labelText, ...tables],\n widths: ['*'],\n },\n }\n\n // NOTE: pass empty value here as otherwise\n // we can accidentally hide content below\n // this row. Please see the following issue:\n // https://github.com/bpampuch/pdfmake/issues/1598\n return [imagesRow, {}]\n })\n }\n\n if (isFileField) {\n const fileList = map(value, file => buildFile({ file, settings }))\n return [labelText, { ol: fileList }]\n }\n\n if (isNumberField || isSelectField || isSwitchField || isTextField) {\n const parsedValue = parseValue(value)\n const displayValue = isArray(parsedValue)\n ? { text: join(parsedValue, ', ') }\n : { text: parsedValue }\n\n return [labelText, displayValue]\n }\n\n if (isReferenceField) {\n const parsedValue = parseValue(value)\n const displayValue = isArray(parsedValue)\n ? {\n text: parsedValue\n .filter(val => val && val.label)\n .map(val => val.label)\n .join(', '),\n fontSize: 7,\n }\n : { text: parsedValue.label, fontSize: 7 }\n\n return [labelText, displayValue]\n }\n\n if (isStarField) {\n if (!value) return [labelText, '']\n const displayValue = value === '1' ? `${value} star` : `${value} stars`\n return [labelText, displayValue]\n }\n\n if (\n isDayFirstDateField ||\n isMonthFirstDateField ||\n is12HourTimeField ||\n is24HourTimeField\n ) {\n const format = options.format\n const displayValue = value\n ? moment(value)\n .tz(timezone)\n .format(format)\n : ''\n\n return [labelText, displayValue]\n }\n\n // NOTE: if no match above null values will be stripped within calling fn\n return null\n}\n\nfunction isDataImage(string) {\n return startsWith(string, 'data:image/png;')\n}\n"],"file":"index.js"}
|
package/mise.toml
ADDED
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@lighthouse/common",
|
|
3
|
-
"version": "4.
|
|
3
|
+
"version": "4.37.0-canary-2",
|
|
4
4
|
"description": "",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"module": "lib/index.js",
|
|
@@ -38,6 +38,7 @@
|
|
|
38
38
|
},
|
|
39
39
|
"homepage": "https://github.com/Lighthouse-io/common#readme",
|
|
40
40
|
"dependencies": {
|
|
41
|
+
"@aws-sdk/cloudfront-signer": "^3.862.0",
|
|
41
42
|
"@lighthouse/abab": "^0.0.6",
|
|
42
43
|
"bluebird": "^3.7.2",
|
|
43
44
|
"fetch-ponyfill": "^6.1.0",
|