From 76f2d38b544b403240bbff2d32de09aba7351181 Mon Sep 17 00:00:00 2001 From: Alexey Lunin <alexey.lunin@vereign.com> Date: Fri, 10 May 2024 10:11:02 +0300 Subject: [PATCH] remove not used packages in native --- dist/index.d.ts | 1 - dist/index.js | 4 +- dist/utils/getMerkleTreeRootHash.d.ts | 2 +- dist/utils/qrCodeTemplateUtils.d.ts | 21 -- dist/utils/qrCodeTemplateUtils.js | 299 --------------- package.json | 4 - src/index.ts | 1 - src/utils/qrCodeTemplateUtils.ts | 467 ----------------------- yarn.lock | 521 +------------------------- 9 files changed, 9 insertions(+), 1311 deletions(-) delete mode 100644 dist/utils/qrCodeTemplateUtils.d.ts delete mode 100644 dist/utils/qrCodeTemplateUtils.js delete mode 100644 src/utils/qrCodeTemplateUtils.ts diff --git a/dist/index.d.ts b/dist/index.d.ts index ec88b41..b7234bd 100644 --- a/dist/index.d.ts +++ b/dist/index.d.ts @@ -9,4 +9,3 @@ export { default as QrCodeDataService } from "./services/QrCodeDataService"; export { default as IPFSService } from "./services/IPFSService"; export { default as CryptoService } from "./services/CryptoService"; export { default as VerificationError } from "./services/VerificationService/VerificationError"; -export { default as QrCodeTemplate } from "./utils/qrCodeTemplateUtils"; diff --git a/dist/index.js b/dist/index.js index b6c5f47..0d9cde3 100644 --- a/dist/index.js +++ b/dist/index.js @@ -13,7 +13,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); -exports.QrCodeTemplate = exports.VerificationError = exports.CryptoService = exports.IPFSService = exports.QrCodeDataService = exports.CommonUtils = exports.StatusesService = exports.VerificationService = exports.CloudflareService = exports.getMerkleTreeRootHash = void 0; +exports.VerificationError = exports.CryptoService = exports.IPFSService = exports.QrCodeDataService = exports.CommonUtils = exports.StatusesService = exports.VerificationService = exports.CloudflareService = exports.getMerkleTreeRootHash = void 0; __exportStar(require("./types"), exports); __exportStar(require("./utils/common"), exports); var getMerkleTreeRootHash_1 = require("./utils/getMerkleTreeRootHash"); @@ -34,5 +34,3 @@ var CryptoService_1 = require("./services/CryptoService"); Object.defineProperty(exports, "CryptoService", { enumerable: true, get: function () { return __importDefault(CryptoService_1).default; } }); var VerificationError_1 = require("./services/VerificationService/VerificationError"); Object.defineProperty(exports, "VerificationError", { enumerable: true, get: function () { return __importDefault(VerificationError_1).default; } }); -var qrCodeTemplateUtils_1 = require("./utils/qrCodeTemplateUtils"); -Object.defineProperty(exports, "QrCodeTemplate", { enumerable: true, get: function () { return __importDefault(qrCodeTemplateUtils_1).default; } }); diff --git a/dist/utils/getMerkleTreeRootHash.d.ts b/dist/utils/getMerkleTreeRootHash.d.ts index 09d4db3..998cb76 100644 --- a/dist/utils/getMerkleTreeRootHash.d.ts +++ b/dist/utils/getMerkleTreeRootHash.d.ts @@ -1,3 +1,3 @@ -import { Buffer } from 'buffer'; +import { Buffer } from "buffer"; declare const getMerkleTreeRootHash: (leaves: Buffer[]) => Promise<Buffer>; export default getMerkleTreeRootHash; diff --git a/dist/utils/qrCodeTemplateUtils.d.ts b/dist/utils/qrCodeTemplateUtils.d.ts deleted file mode 100644 index e3e8c4f..0000000 --- a/dist/utils/qrCodeTemplateUtils.d.ts +++ /dev/null @@ -1,21 +0,0 @@ -interface TemplateOptions { - src: string; - placeholderSize: number; -} -/** - * https://www.qrcode.com/en/about/error_correction.html#:~:text=QR%20Code%20has%20error%20correction,of%20data%20QR%20Code%20size. - */ -declare type CorrectionLevels = "L" | "M" | "Q" | "H"; -interface QrCodeOptions { - width?: number; - height?: number; - logoSrc?: string; - logoWidth?: number; - logoHeight?: number; - correctionLevel?: CorrectionLevels; -} -declare const _default: { - putQrCodeOnChromakeyTemplate: (qrCodeImageBase64: string, templateImageBase64: string, placeholderWidth: number, placeholderHeight: number, scale?: number) => Promise<string>; - generateQrCode: (text: string, qrCodeOptions?: QrCodeOptions, templateOptions?: TemplateOptions) => Promise<string>; -}; -export default _default; diff --git a/dist/utils/qrCodeTemplateUtils.js b/dist/utils/qrCodeTemplateUtils.js deleted file mode 100644 index 3b29f8f..0000000 --- a/dist/utils/qrCodeTemplateUtils.js +++ /dev/null @@ -1,299 +0,0 @@ -"use strict"; -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); -}) : function(o, v) { - o["default"] = v; -}); -var __importStar = (this && this.__importStar) || function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; -}; -var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { - function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } - return new (P || (P = Promise))(function (resolve, reject) { - function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } - function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } - function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } - step((generator = generator.apply(thisArg, _arguments || [])).next()); - }); -}; -var __importDefault = (this && this.__importDefault) || function (mod) { - return (mod && mod.__esModule) ? mod : { "default": mod }; -}; -Object.defineProperty(exports, "__esModule", { value: true }); -const easyqrcodejs_1 = __importDefault(require("easyqrcodejs")); -const common_1 = require("./common"); -const DEFAULT_TEMPLATE = ""; -const DEFAULT_LOGO = ""; -const findChromakeyBoundaries = (width, height, imageData, chromakeyWidth, chromakeyHeight) => { - const maskSizeX = chromakeyWidth; - const maskSizeY = chromakeyHeight; - const totalSum = maskSizeX * maskSizeY * 255; - const matrixR = []; - const matrixG = []; - const matrixB = []; - for (let i = 0; i < width; i++) { - matrixR[i] = []; - matrixG[i] = []; - matrixB[i] = []; - for (let j = 0; j < height; j++) { - matrixR[i][j] = 0; - matrixG[i][j] = 0; - matrixB[i][j] = 0; - } - } - const maxDistance = Math.sqrt(3 * totalSum * totalSum); - const suitableSimilarity = 0.6; - let bestSimilarity = 0; - let bestX = -1; - let bestY = -1; - for (let x = 0; x < width; x++) { - for (let y = 0; y < height; y++) { - const index = (y * width + x) * 4; - const r = imageData.data[index]; - const g = imageData.data[index + 1]; - const b = imageData.data[index + 2]; - matrixR[x][y] += r; - matrixG[x][y] += g; - matrixB[x][y] += b; - if (x - 1 >= 0) { - matrixR[x][y] += matrixR[x - 1][y]; - matrixG[x][y] += matrixG[x - 1][y]; - matrixB[x][y] += matrixB[x - 1][y]; - } - if (y - 1 >= 0) { - matrixR[x][y] += matrixR[x][y - 1]; - matrixG[x][y] += matrixG[x][y - 1]; - matrixB[x][y] += matrixB[x][y - 1]; - } - if (x - 1 >= 0 && y - 1 >= 0) { - matrixR[x][y] -= matrixR[x - 1][y - 1]; - matrixG[x][y] -= matrixG[x - 1][y - 1]; - matrixB[x][y] -= matrixB[x - 1][y - 1]; - } - if (x >= maskSizeX && y >= maskSizeY) { - const tempSumR = matrixR[x][y] + - matrixR[x - maskSizeX][y - maskSizeY] - - (matrixR[x - maskSizeX][y] + matrixR[x][y - maskSizeY]); - const tempSumG = matrixG[x][y] + - matrixG[x - maskSizeX][y - maskSizeY] - - (matrixG[x - maskSizeX][y] + matrixG[x][y - maskSizeY]); - const tempSumB = matrixB[x][y] + - matrixB[x - maskSizeX][y - maskSizeY] - - (matrixB[x - maskSizeX][y] + matrixB[x][y - maskSizeY]); - const distance = Math.sqrt(Math.pow(0 - tempSumR, 2) + - Math.pow(totalSum - tempSumG, 2) + - Math.pow(0 - tempSumB, 2)); - const similarity = 1 - distance / maxDistance; - if (similarity > bestSimilarity) { - bestX = x; - bestY = y; - bestSimilarity = similarity; - } - } - } - } - if (bestX >= 0 && bestY >= 0 && bestSimilarity > suitableSimilarity) { - return { - fromL: bestX - maskSizeX, - fromT: bestY - maskSizeY, - toL: bestX - maskSizeX + chromakeyWidth, - toT: bestY - maskSizeY + chromakeyHeight, - }; - } - return { fromL: -1, fromT: -1, toL: -1, toT: -1 }; -}; -const defaultOptions = { - width: 256, - height: 256, - logoSrc: DEFAULT_LOGO, - logoWidth: 75, - logoHeight: 66, - // Use "L" level as we don't need a redundancy - correctionLevel: "L", -}; -const defaultTemplateOptions = { - placeholderSize: 260, - src: DEFAULT_TEMPLATE, -}; -/** - * Generates QR Code based of the context - Browser or NodeJs. - * IMPORTANT: In case of NodeJS it uses the JSDON and Canvas libraries to mimic the DOM behaviour - * - * @param text - * @param qrCodeOptions - * @param templateOptions - * @returns - */ -const generateQrCode = (text, qrCodeOptions, templateOptions) => { - qrCodeOptions = qrCodeOptions - ? Object.assign(defaultOptions, qrCodeOptions) - : defaultOptions; - templateOptions = templateOptions - ? Object.assign(defaultTemplateOptions, templateOptions) - : defaultTemplateOptions; - const options = { - text, - width: qrCodeOptions.width, - height: qrCodeOptions.height, - colorDark: "#000000", - colorLight: "#ffffff", - dotScale: 1, - }; - if (qrCodeOptions.logoSrc) { - Object.assign(options, { - logo: qrCodeOptions.logoSrc, - logoBackgroundTransparent: true, - logoWidth: qrCodeOptions.logoWidth, - logoHeight: qrCodeOptions.logoHeight, - }); - } - if (common_1.isNode) { - return generateNodeJSQrCode(options, qrCodeOptions, templateOptions); - } - options["correctLevel"] = easyqrcodejs_1.default.CorrectLevel[qrCodeOptions.correctionLevel]; // L, M, Q, H - return generateBrowserQrCode(options, templateOptions); -}; -/** - * Nodejs impl for generation of qr code. Uses JSDOM and Canvas libs to mimic the DOM. - * - * @param defaultOptions - * @param qrCodeOptions - * @param templateOptions - * @returns - */ -const generateNodeJSQrCode = (defaultOptions, qrCodeOptions, templateOptions) => __awaiter(void 0, void 0, void 0, function* () { - const QRCodeNodeJS = yield Promise.resolve().then(() => __importStar(require("easyqrcodejs-nodejs"))); - defaultOptions["correctLevel"] = - QRCodeNodeJS.CorrectLevel[qrCodeOptions.correctionLevel]; // L, M, Q, H - const qrcode = new QRCodeNodeJS.default(defaultOptions); - const dataUrl = yield qrcode.toDataURL(); - yield new Promise((resolve) => setTimeout(resolve, 10)); - return yield putQrCodeOnChromakeyTemplateNodeJS(dataUrl, templateOptions.src, templateOptions.placeholderSize, templateOptions.placeholderSize); -}); -const generateBrowserQrCode = (qrCodeOptions, templateOptions) => __awaiter(void 0, void 0, void 0, function* () { - const container = document.createElement("div"); - new easyqrcodejs_1.default(container, qrCodeOptions); - const canvas = container.getElementsByTagName("canvas")[0]; - // Add short async action because of the bug with logo not appearing in the resulting image. - yield new Promise((resolve) => setTimeout(resolve, 10)); - return yield putQrCodeOnChromakeyTemplate(canvas.toDataURL(), templateOptions.src, templateOptions.placeholderSize, templateOptions.placeholderSize); -}); -/** - * Nodejs impl for template generation - * - * @param qrCodeImageBase64 - * @param templateImageBase64 - * @param placeholderWidth - * @param placeholderHeight - * @param scale - * @returns - */ -const putQrCodeOnChromakeyTemplateNodeJS = (qrCodeImageBase64, templateImageBase64, placeholderWidth, placeholderHeight, scale = 1) => __awaiter(void 0, void 0, void 0, function* () { - const jsdom = yield Promise.resolve().then(() => __importStar(require("jsdom"))); - const { JSDOM } = jsdom; - const dom = new JSDOM("", { resources: "usable" }); - const document = dom.window.document; - let qrCodeImage; - try { - qrCodeImage = yield loadImageNode(qrCodeImageBase64, document); - } - catch (e) { - throw new Error("NodeJS cannot load qr code image"); - } - const templateImage = yield loadImageNode(templateImageBase64, document); - if (templateImage.width < placeholderWidth || - templateImage.height < placeholderHeight) { - throw new Error("Placeholder is bigger than image"); - } - const templateCanvas = document.createElement("canvas"); - templateCanvas.width = templateImage.width; - templateCanvas.height = templateImage.height; - const templateCtx = templateCanvas.getContext("2d"); - templateCtx.drawImage(templateImage, 0, 0, templateImage.width, templateImage.height); - const templateImgData = templateCtx.getImageData(0, 0, templateCanvas.width, templateCanvas.height); - const placeholderCoordinates = findChromakeyBoundaries(templateImage.width, templateImage.height, templateImgData, placeholderWidth, placeholderHeight); - // -2 is for QR to slightly cover borders. To avoid green mask bulging out - const scaleX = ((qrCodeImage.width - 2) / placeholderWidth) * scale; - const scaleY = ((qrCodeImage.height - 2) / placeholderHeight) * scale; - qrCodeImage.width *= scale; - qrCodeImage.height *= scale; - const bannerCanvas = document.createElement("canvas"); - const scaledTemplateW = Math.floor(templateImage.width * scaleX); - const scaledTemplateH = Math.floor(templateImage.height * scaleY); - bannerCanvas.width = scaledTemplateW; - bannerCanvas.height = scaledTemplateH; - const bannerCtx = bannerCanvas.getContext("2d"); - // bannerCtx - bannerCtx.drawImage(templateImage, 0, 0, templateImage.width, templateImage.height, 0, 0, scaledTemplateW, scaledTemplateH); - // +1 hides green border - bannerCtx.drawImage(qrCodeImage, placeholderCoordinates.fromL * scaleX, placeholderCoordinates.fromT * scaleY, qrCodeImage.width, qrCodeImage.height); - return bannerCanvas.toDataURL(); -}); -const putQrCodeOnChromakeyTemplate = (qrCodeImageBase64, templateImageBase64, placeholderWidth, placeholderHeight, scale = 1) => __awaiter(void 0, void 0, void 0, function* () { - const qrCodeImage = yield loadImage(qrCodeImageBase64); - const templateImage = yield loadImage(templateImageBase64); - if (templateImage.width < placeholderWidth || - templateImage.height < placeholderHeight) { - throw new Error("Placeholder is bigger than image"); - } - const templateCanvas = document.createElement("canvas"); - templateCanvas.width = templateImage.width; - templateCanvas.height = templateImage.height; - const templateCtx = templateCanvas.getContext("2d"); - templateCtx.drawImage(templateImage, 0, 0, templateImage.width, templateImage.height); - const templateImgData = templateCtx.getImageData(0, 0, templateCanvas.width, templateCanvas.height); - const placeholderCoordinates = findChromakeyBoundaries(templateImage.width, templateImage.height, templateImgData, placeholderWidth, placeholderHeight); - // -2 is for QR to slightly cover borders. To avoid green mask bulging out - const scaleX = ((qrCodeImage.width - 2) / placeholderWidth) * scale; - const scaleY = ((qrCodeImage.height - 2) / placeholderHeight) * scale; - qrCodeImage.width *= scale; - qrCodeImage.height *= scale; - const bannerCanvas = document.createElement("canvas"); - const scaledTemplateW = Math.floor(templateImage.width * scaleX); - const scaledTemplateH = Math.floor(templateImage.height * scaleY); - bannerCanvas.width = scaledTemplateW; - bannerCanvas.height = scaledTemplateH; - const bannerCtx = bannerCanvas.getContext("2d"); - // bannerCtx - bannerCtx.drawImage(templateImage, 0, 0, templateImage.width, templateImage.height, 0, 0, scaledTemplateW, scaledTemplateH); - // +1 hides green border - bannerCtx.drawImage(qrCodeImage, placeholderCoordinates.fromL * scaleX, placeholderCoordinates.fromT * scaleY, qrCodeImage.width, qrCodeImage.height); - return bannerCanvas.toDataURL(); -}); -const loadImage = (imageSrc) => { - return new Promise((resolve, reject) => { - const templateImg = document.createElement("img"); - templateImg.src = imageSrc; - templateImg.onload = () => resolve(templateImg); - templateImg.onerror = (error) => reject(error); - }); -}; -/** - * Duplicates the load img for browser - * - * @param imageSrc - * @returns - */ -const loadImageNode = (imageSrc, document) => { - return new Promise((resolve, reject) => { - const templateImg = document.createElement("img"); - templateImg.src = imageSrc; - templateImg.onload = () => resolve(templateImg); - templateImg.onerror = (error) => reject(error); - }); -}; -exports.default = { - putQrCodeOnChromakeyTemplate, - generateQrCode, -}; diff --git a/package.json b/package.json index 119f0aa..17ffdfb 100644 --- a/package.json +++ b/package.json @@ -38,14 +38,10 @@ "dependencies": { "axios": "^0.20.0", "buffer": "^6.0.3", - "canvas": "^2.8.0", - "easyqrcodejs": "^4.3.1", - "easyqrcodejs-nodejs": "^4.4.2", "eventemitter2": "^6.4.3", "fflate": "^0.7.3", "google-protobuf": "^3.13.0", "js-md5": "^0.7.3", - "penpal": "^5.3.0", "protobufjs": "^6.10.1", "url-parse": "^1.4.7" }, diff --git a/src/index.ts b/src/index.ts index ec88b41..b7234bd 100644 --- a/src/index.ts +++ b/src/index.ts @@ -9,4 +9,3 @@ export { default as QrCodeDataService } from "./services/QrCodeDataService"; export { default as IPFSService } from "./services/IPFSService"; export { default as CryptoService } from "./services/CryptoService"; export { default as VerificationError } from "./services/VerificationService/VerificationError"; -export { default as QrCodeTemplate } from "./utils/qrCodeTemplateUtils"; diff --git a/src/utils/qrCodeTemplateUtils.ts b/src/utils/qrCodeTemplateUtils.ts deleted file mode 100644 index 7cfc925..0000000 --- a/src/utils/qrCodeTemplateUtils.ts +++ /dev/null @@ -1,467 +0,0 @@ -import QRCode from "easyqrcodejs"; -import { isNode } from "./common"; - -const DEFAULT_TEMPLATE = - ""; -const DEFAULT_LOGO = - ""; - -interface ChromakeyBoundaries { - fromL: number; - fromT: number; - toL: number; - toT: number; -} - -const findChromakeyBoundaries = ( - width: number, - height: number, - imageData: ImageData, - chromakeyWidth: number, - chromakeyHeight: number -): ChromakeyBoundaries => { - const maskSizeX = chromakeyWidth; - const maskSizeY = chromakeyHeight; - - const totalSum = maskSizeX * maskSizeY * 255; - - const matrixR = []; - const matrixG = []; - const matrixB = []; - - for (let i = 0; i < width; i++) { - matrixR[i] = []; - matrixG[i] = []; - matrixB[i] = []; - for (let j = 0; j < height; j++) { - matrixR[i][j] = 0; - matrixG[i][j] = 0; - matrixB[i][j] = 0; - } - } - - const maxDistance = Math.sqrt(3 * totalSum * totalSum); - const suitableSimilarity = 0.6; - - let bestSimilarity = 0; - let bestX = -1; - let bestY = -1; - for (let x = 0; x < width; x++) { - for (let y = 0; y < height; y++) { - const index = (y * width + x) * 4; - const r = imageData.data[index]; - const g = imageData.data[index + 1]; - const b = imageData.data[index + 2]; - - matrixR[x][y] += r; - matrixG[x][y] += g; - matrixB[x][y] += b; - - if (x - 1 >= 0) { - matrixR[x][y] += matrixR[x - 1][y]; - matrixG[x][y] += matrixG[x - 1][y]; - matrixB[x][y] += matrixB[x - 1][y]; - } - - if (y - 1 >= 0) { - matrixR[x][y] += matrixR[x][y - 1]; - matrixG[x][y] += matrixG[x][y - 1]; - matrixB[x][y] += matrixB[x][y - 1]; - } - - if (x - 1 >= 0 && y - 1 >= 0) { - matrixR[x][y] -= matrixR[x - 1][y - 1]; - matrixG[x][y] -= matrixG[x - 1][y - 1]; - matrixB[x][y] -= matrixB[x - 1][y - 1]; - } - if (x >= maskSizeX && y >= maskSizeY) { - const tempSumR = - matrixR[x][y] + - matrixR[x - maskSizeX][y - maskSizeY] - - (matrixR[x - maskSizeX][y] + matrixR[x][y - maskSizeY]); - const tempSumG = - matrixG[x][y] + - matrixG[x - maskSizeX][y - maskSizeY] - - (matrixG[x - maskSizeX][y] + matrixG[x][y - maskSizeY]); - const tempSumB = - matrixB[x][y] + - matrixB[x - maskSizeX][y - maskSizeY] - - (matrixB[x - maskSizeX][y] + matrixB[x][y - maskSizeY]); - - const distance = Math.sqrt( - Math.pow(0 - tempSumR, 2) + - Math.pow(totalSum - tempSumG, 2) + - Math.pow(0 - tempSumB, 2) - ); - const similarity = 1 - distance / maxDistance; - - if (similarity > bestSimilarity) { - bestX = x; - bestY = y; - bestSimilarity = similarity; - } - } - } - } - - if (bestX >= 0 && bestY >= 0 && bestSimilarity > suitableSimilarity) { - return { - fromL: bestX - maskSizeX, - fromT: bestY - maskSizeY, - toL: bestX - maskSizeX + chromakeyWidth, - toT: bestY - maskSizeY + chromakeyHeight, - }; - } - - return { fromL: -1, fromT: -1, toL: -1, toT: -1 }; -}; - -interface TemplateOptions { - src: string; - placeholderSize: number; -} - -/** - * https://www.qrcode.com/en/about/error_correction.html#:~:text=QR%20Code%20has%20error%20correction,of%20data%20QR%20Code%20size. - */ -type CorrectionLevels = "L" | "M" | "Q" | "H"; - -interface QrCodeOptions { - width?: number; - height?: number; - logoSrc?: string; - logoWidth?: number; - logoHeight?: number; - correctionLevel?: CorrectionLevels; -} - -const defaultOptions: QrCodeOptions = { - width: 256, - height: 256, - logoSrc: DEFAULT_LOGO, - logoWidth: 75, - logoHeight: 66, - // Use "L" level as we don't need a redundancy - correctionLevel: "L", -}; - -const defaultTemplateOptions: TemplateOptions = { - placeholderSize: 260, - src: DEFAULT_TEMPLATE, -}; - -/** - * Generates QR Code based of the context - Browser or NodeJs. - * IMPORTANT: In case of NodeJS it uses the JSDON and Canvas libraries to mimic the DOM behaviour - * - * @param text - * @param qrCodeOptions - * @param templateOptions - * @returns - */ -const generateQrCode = ( - text: string, - qrCodeOptions?: QrCodeOptions, - templateOptions?: TemplateOptions -): Promise<string> => { - qrCodeOptions = qrCodeOptions - ? Object.assign(defaultOptions, qrCodeOptions) - : defaultOptions; - - templateOptions = templateOptions - ? Object.assign(defaultTemplateOptions, templateOptions) - : defaultTemplateOptions; - - const options = { - text, - width: qrCodeOptions.width, - height: qrCodeOptions.height, - colorDark: "#000000", - colorLight: "#ffffff", - dotScale: 1, - }; - - if (qrCodeOptions.logoSrc) { - Object.assign(options, { - logo: qrCodeOptions.logoSrc, - logoBackgroundTransparent: true, - logoWidth: qrCodeOptions.logoWidth, - logoHeight: qrCodeOptions.logoHeight, - }); - } - - if (isNode) { - return generateNodeJSQrCode(options, qrCodeOptions, templateOptions); - } - options["correctLevel"] = QRCode.CorrectLevel[qrCodeOptions.correctionLevel]; // L, M, Q, H - return generateBrowserQrCode(options, templateOptions); -}; - -/** - * Nodejs impl for generation of qr code. Uses JSDOM and Canvas libs to mimic the DOM. - * - * @param defaultOptions - * @param qrCodeOptions - * @param templateOptions - * @returns - */ -const generateNodeJSQrCode = async ( - defaultOptions: QrCodeOptions, - qrCodeOptions: QrCodeOptions, - templateOptions: TemplateOptions -): Promise<string> => { - const QRCodeNodeJS = await import("easyqrcodejs-nodejs"); - - defaultOptions["correctLevel"] = - QRCodeNodeJS.CorrectLevel[qrCodeOptions.correctionLevel]; // L, M, Q, H - - const qrcode = new QRCodeNodeJS.default(defaultOptions); - const dataUrl = await qrcode.toDataURL(); - - await new Promise((resolve) => setTimeout(resolve, 10)); - - return await putQrCodeOnChromakeyTemplateNodeJS( - dataUrl, - templateOptions.src, - templateOptions.placeholderSize, - templateOptions.placeholderSize - ); -}; - -const generateBrowserQrCode = async ( - qrCodeOptions: QrCodeOptions, - templateOptions: TemplateOptions -): Promise<string> => { - const container = document.createElement("div"); - new QRCode(container, qrCodeOptions); - const canvas = container.getElementsByTagName("canvas")[0]; - - // Add short async action because of the bug with logo not appearing in the resulting image. - await new Promise((resolve) => setTimeout(resolve, 10)); - - return await putQrCodeOnChromakeyTemplate( - canvas.toDataURL(), - templateOptions.src, - templateOptions.placeholderSize, - templateOptions.placeholderSize - ); -}; - -/** - * Nodejs impl for template generation - * - * @param qrCodeImageBase64 - * @param templateImageBase64 - * @param placeholderWidth - * @param placeholderHeight - * @param scale - * @returns - */ -const putQrCodeOnChromakeyTemplateNodeJS = async ( - qrCodeImageBase64: string, - templateImageBase64: string, - placeholderWidth: number, - placeholderHeight: number, - scale = 1 -): Promise<string> => { - const jsdom = await import("jsdom"); - - const { JSDOM } = jsdom; - const dom = new JSDOM("", { resources: "usable" }); - const document = dom.window.document; - let qrCodeImage; - - try { - qrCodeImage = await loadImageNode(qrCodeImageBase64, document); - } catch (e) { - throw new Error("NodeJS cannot load qr code image"); - } - const templateImage = await loadImageNode(templateImageBase64, document); - - if ( - templateImage.width < placeholderWidth || - templateImage.height < placeholderHeight - ) { - throw new Error("Placeholder is bigger than image"); - } - - const templateCanvas = document.createElement("canvas"); - templateCanvas.width = templateImage.width; - templateCanvas.height = templateImage.height; - - const templateCtx = templateCanvas.getContext("2d"); - templateCtx.drawImage( - templateImage, - 0, - 0, - templateImage.width, - templateImage.height - ); - - const templateImgData = templateCtx.getImageData( - 0, - 0, - templateCanvas.width, - templateCanvas.height - ); - - const placeholderCoordinates = findChromakeyBoundaries( - templateImage.width, - templateImage.height, - templateImgData, - placeholderWidth, - placeholderHeight - ); - // -2 is for QR to slightly cover borders. To avoid green mask bulging out - const scaleX = ((qrCodeImage.width - 2) / placeholderWidth) * scale; - const scaleY = ((qrCodeImage.height - 2) / placeholderHeight) * scale; - qrCodeImage.width *= scale; - qrCodeImage.height *= scale; - - const bannerCanvas = document.createElement("canvas"); - const scaledTemplateW = Math.floor(templateImage.width * scaleX); - const scaledTemplateH = Math.floor(templateImage.height * scaleY); - - bannerCanvas.width = scaledTemplateW; - bannerCanvas.height = scaledTemplateH; - - const bannerCtx = bannerCanvas.getContext("2d"); - // bannerCtx - - bannerCtx.drawImage( - templateImage, - 0, - 0, - templateImage.width, - templateImage.height, - 0, - 0, - scaledTemplateW, - scaledTemplateH - ); - // +1 hides green border - bannerCtx.drawImage( - qrCodeImage, - placeholderCoordinates.fromL * scaleX, - placeholderCoordinates.fromT * scaleY, - qrCodeImage.width, - qrCodeImage.height - ); - return bannerCanvas.toDataURL(); -}; - -const putQrCodeOnChromakeyTemplate = async ( - qrCodeImageBase64: string, - templateImageBase64: string, - placeholderWidth: number, - placeholderHeight: number, - scale = 1 -): Promise<string> => { - const qrCodeImage = await loadImage(qrCodeImageBase64); - const templateImage = await loadImage(templateImageBase64); - - if ( - templateImage.width < placeholderWidth || - templateImage.height < placeholderHeight - ) { - throw new Error("Placeholder is bigger than image"); - } - - const templateCanvas = document.createElement("canvas"); - templateCanvas.width = templateImage.width; - templateCanvas.height = templateImage.height; - - const templateCtx = templateCanvas.getContext("2d"); - templateCtx.drawImage( - templateImage, - 0, - 0, - templateImage.width, - templateImage.height - ); - - const templateImgData = templateCtx.getImageData( - 0, - 0, - templateCanvas.width, - templateCanvas.height - ); - - const placeholderCoordinates = findChromakeyBoundaries( - templateImage.width, - templateImage.height, - templateImgData, - placeholderWidth, - placeholderHeight - ); - - // -2 is for QR to slightly cover borders. To avoid green mask bulging out - const scaleX = ((qrCodeImage.width - 2) / placeholderWidth) * scale; - const scaleY = ((qrCodeImage.height - 2) / placeholderHeight) * scale; - qrCodeImage.width *= scale; - qrCodeImage.height *= scale; - - const bannerCanvas = document.createElement("canvas"); - const scaledTemplateW = Math.floor(templateImage.width * scaleX); - const scaledTemplateH = Math.floor(templateImage.height * scaleY); - - bannerCanvas.width = scaledTemplateW; - bannerCanvas.height = scaledTemplateH; - - const bannerCtx = bannerCanvas.getContext("2d"); - // bannerCtx - - bannerCtx.drawImage( - templateImage, - 0, - 0, - templateImage.width, - templateImage.height, - 0, - 0, - scaledTemplateW, - scaledTemplateH - ); - - // +1 hides green border - bannerCtx.drawImage( - qrCodeImage, - placeholderCoordinates.fromL * scaleX, - placeholderCoordinates.fromT * scaleY, - qrCodeImage.width, - qrCodeImage.height - ); - return bannerCanvas.toDataURL(); -}; - -const loadImage = (imageSrc: string): Promise<HTMLImageElement> => { - return new Promise((resolve, reject) => { - const templateImg = document.createElement("img"); - templateImg.src = imageSrc; - templateImg.onload = () => resolve(templateImg); - templateImg.onerror = (error) => reject(error); - }); -}; - -/** - * Duplicates the load img for browser - * - * @param imageSrc - * @returns - */ -const loadImageNode = ( - imageSrc: string, - document -): Promise<HTMLImageElement> => { - return new Promise((resolve, reject) => { - const templateImg = document.createElement("img"); - templateImg.src = imageSrc; - templateImg.onload = () => resolve(templateImg); - templateImg.onerror = (error) => reject(error); - }); -}; - -export default { - putQrCodeOnChromakeyTemplate, - generateQrCode, -}; diff --git a/yarn.lock b/yarn.lock index ec1738e..b988d6a 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1163,21 +1163,6 @@ "@types/yargs" "^15.0.0" chalk "^4.0.0" -"@mapbox/node-pre-gyp@^1.0.0": - version "1.0.8" - resolved "https://registry.yarnpkg.com/@mapbox/node-pre-gyp/-/node-pre-gyp-1.0.8.tgz#32abc8a5c624bc4e46c43d84dfb8b26d33a96f58" - integrity sha512-CMGKi28CF+qlbXh26hDe6NxCd7amqeAzEqnS6IHeO6LoaKyM/n+Xw3HT1COdq8cuioOdlKdqn/hCmqPUOMOywg== - dependencies: - detect-libc "^1.0.3" - https-proxy-agent "^5.0.0" - make-dir "^3.1.0" - node-fetch "^2.6.5" - nopt "^5.0.0" - npmlog "^5.0.1" - rimraf "^3.0.2" - semver "^7.3.5" - tar "^6.1.11" - "@protobufjs/aspromise@^1.1.1", "@protobufjs/aspromise@^1.1.2": version "1.1.2" resolved "https://registry.yarnpkg.com/@protobufjs/aspromise/-/aspromise-1.1.2.tgz#9b8b0cc663d669a7d8f6f5d0893a14d348f30fbf" @@ -1250,16 +1235,6 @@ resolved "https://registry.yarnpkg.com/@tootallnate/once/-/once-1.1.2.tgz#ccb91445360179a04e7fe6aff78c00ffc1eeaf82" integrity sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw== -"@tootallnate/once@2": - version "2.0.0" - resolved "https://registry.yarnpkg.com/@tootallnate/once/-/once-2.0.0.tgz#f544a148d3ab35801c1f633a7441fd87c2e484bf" - integrity sha512-XCuKFP5PS55gnMVu3dty8KPatLqUoy/ZYzDzAGCQ8JNFCkLXzmI7vNHCR+XpbZaMWQK/vQubr7PkYq8g470J/A== - -"@trysound/sax@0.2.0": - version "0.2.0" - resolved "https://registry.yarnpkg.com/@trysound/sax/-/sax-0.2.0.tgz#cccaab758af56761eb7bf37af6f03f326dd798ad" - integrity sha512-L7z9BgrNEcYyUYtF+HaEfiS5ebkh9jXqbszz7pC0hRBPaatV0XjSD3+eHrpqFemQfgwiFF0QPIarnIihIDn7OA== - "@types/babel__core@^7.0.0", "@types/babel__core@^7.1.7": version "7.1.18" resolved "https://registry.yarnpkg.com/@types/babel__core/-/babel__core-7.1.18.tgz#1a29abcc411a9c05e2094c98f9a1b7da6cdf49f8" @@ -1455,11 +1430,6 @@ abab@^2.0.3, abab@^2.0.5: resolved "https://registry.yarnpkg.com/abab/-/abab-2.0.5.tgz#c0b678fb32d60fc1219c784d6a826fe385aeb79a" integrity sha512-9IK9EadsbHo6jLWIpxpR6pL0sazTXV6+SQv25ZB+F7Bj9mJNaOc4nCRabwd5M/JwmUa8idz6Eci6eKfJryPs6Q== -abbrev@1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/abbrev/-/abbrev-1.1.1.tgz#f8f2c887ad10bf67f634f005b6987fed3179aac8" - integrity sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q== - acorn-globals@^6.0.0: version "6.0.0" resolved "https://registry.yarnpkg.com/acorn-globals/-/acorn-globals-6.0.0.tgz#46cdd39f0f8ff08a876619b55f5ac8a6dc770b45" @@ -1483,7 +1453,7 @@ acorn@^7.1.1, acorn@^7.4.0: resolved "https://registry.yarnpkg.com/acorn/-/acorn-7.4.1.tgz#feaed255973d2e77555b83dbc08851a6c63520fa" integrity sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A== -acorn@^8.2.4, acorn@^8.5.0: +acorn@^8.2.4: version "8.7.0" resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.7.0.tgz#90951fde0f8f09df93549481e5fc141445b791cf" integrity sha512-V/LGr1APy+PXIwKebEWrkZPwoeoF+w1jiOBUmuxuiUIaOHtob8Qc9BTrYo7VuI5fR8tqsy+buA2WFooR5olqvQ== @@ -1570,19 +1540,6 @@ anymatch@^3.0.3: normalize-path "^3.0.0" picomatch "^2.0.4" -"aproba@^1.0.3 || ^2.0.0": - version "2.0.0" - resolved "https://registry.yarnpkg.com/aproba/-/aproba-2.0.0.tgz#52520b8ae5b569215b354efc0caa3fe1e45a8adc" - integrity sha512-lYe4Gx7QT+MKGbDsA+Z+he/Wtef0BiwDOlK/XkBrdfsh9J/jPPXbX0tE9x9cl27Tmu5gg3QUbUrQYa/y+KOHPQ== - -are-we-there-yet@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/are-we-there-yet/-/are-we-there-yet-2.0.0.tgz#372e0e7bd279d8e94c653aaa1f67200884bf3e1c" - integrity sha512-Ci/qENmwHnsYo9xKIcUJN5LeDKdJ6R1Z1j9V/J5wyq8nh/mYPEpIKJbBZXtZjG04HiK7zV/p6Vs9952MrMeUIw== - dependencies: - delegates "^1.0.0" - readable-stream "^3.6.0" - argparse@^1.0.7: version "1.0.10" resolved "https://registry.yarnpkg.com/argparse/-/argparse-1.0.10.tgz#bcd6791ea5ae09725e17e5ad988134cd40b3d911" @@ -1764,11 +1721,6 @@ base@^0.11.1: mixin-deep "^1.2.0" pascalcase "^0.1.1" -boolbase@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/boolbase/-/boolbase-1.0.0.tgz#68dff5fbe60c51eb37725ea9e3ed310dcc1e776e" - integrity sha1-aN/1++YMUes3cl6p4+0xDcwed24= - brace-expansion@^1.1.7: version "1.1.11" resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" @@ -1884,15 +1836,6 @@ caniuse-lite@^1.0.30001286: resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001296.tgz#d99f0f3bee66544800b93d261c4be55a35f1cec8" integrity sha512-WfrtPEoNSoeATDlf4y3QvkwiELl9GyPLISV5GejTbbQRtQx4LhsXmc9IQ6XCL2d7UxCyEzToEZNMeqR79OUw8Q== -canvas@^2.8.0: - version "2.8.0" - resolved "https://registry.yarnpkg.com/canvas/-/canvas-2.8.0.tgz#f99ca7f25e6e26686661ffa4fec1239bbef74461" - integrity sha512-gLTi17X8WY9Cf5GZ2Yns8T5lfBOcGgFehDFb+JQwDqdOoBOcECS9ZWMEAqMSVcMYwXD659J8NyzjRY/2aE+C2Q== - dependencies: - "@mapbox/node-pre-gyp" "^1.0.0" - nan "^2.14.0" - simple-get "^3.0.3" - capture-exit@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/capture-exit/-/capture-exit-2.0.0.tgz#fb953bfaebeb781f62898239dabb426d08a509a4" @@ -1922,11 +1865,6 @@ char-regex@^1.0.2: resolved "https://registry.yarnpkg.com/char-regex/-/char-regex-1.0.2.tgz#d744358226217f981ed58f479b1d6bcc29545dcf" integrity sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw== -chownr@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/chownr/-/chownr-2.0.0.tgz#15bfbe53d2eab4cf70f18a8cd68ebe5b3cb1dece" - integrity sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ== - ci-info@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-2.0.0.tgz#67a9e964be31a51e15e5010d58e6f12834002f46" @@ -2018,11 +1956,6 @@ color-name@~1.1.4: resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== -color-support@^1.1.2: - version "1.1.3" - resolved "https://registry.yarnpkg.com/color-support/-/color-support-1.1.3.tgz#93834379a1cc9a0c61f82f52f0d04322251bd5a2" - integrity sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg== - colorette@^2.0.16: version "2.0.16" resolved "https://registry.yarnpkg.com/colorette/-/colorette-2.0.16.tgz#713b9af84fdb000139f04546bd4a93f62a5085da" @@ -2045,11 +1978,6 @@ commander@^6.2.0: resolved "https://registry.yarnpkg.com/commander/-/commander-6.2.1.tgz#0792eb682dfbc325999bb2b84fddddba110ac73c" integrity sha512-U7VdrJFnJgo4xjrHpTzu0yrHPGImdsmD95ZlgYSEajAn2JKzDhDTPG9kBTefmObL2w/ngeZnilk+OV9CG3d7UA== -commander@^7.2.0: - version "7.2.0" - resolved "https://registry.yarnpkg.com/commander/-/commander-7.2.0.tgz#a36cb57d0b501ce108e4d20559a150a391d97ab7" - integrity sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw== - compare-versions@^3.6.0: version "3.6.0" resolved "https://registry.yarnpkg.com/compare-versions/-/compare-versions-3.6.0.tgz#1a5689913685e5a87637b8d3ffca75514ec41d62" @@ -2065,11 +1993,6 @@ concat-map@0.0.1: resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" integrity sha1-2Klr13/Wjfd5OnMDajug1UBdR3s= -console-control-strings@^1.0.0, console-control-strings@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/console-control-strings/-/console-control-strings-1.1.0.tgz#3d7cf4464db6446ea644bf4b39507f9851008e8e" - integrity sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4= - convert-source-map@^1.4.0, convert-source-map@^1.6.0, convert-source-map@^1.7.0: version "1.8.0" resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-1.8.0.tgz#f3373c32d21b4d780dd8004514684fb791ca4369" @@ -2121,47 +2044,11 @@ cross-spawn@^7.0.0, cross-spawn@^7.0.2: shebang-command "^2.0.0" which "^2.0.1" -css-select@^4.1.3: - version "4.2.1" - resolved "https://registry.yarnpkg.com/css-select/-/css-select-4.2.1.tgz#9e665d6ae4c7f9d65dbe69d0316e3221fb274cdd" - integrity sha512-/aUslKhzkTNCQUB2qTX84lVmfia9NyjP3WpDGtj/WxhwBzWBYUV3DgUpurHTme8UTPcPlAD1DJ+b0nN/t50zDQ== - dependencies: - boolbase "^1.0.0" - css-what "^5.1.0" - domhandler "^4.3.0" - domutils "^2.8.0" - nth-check "^2.0.1" - -css-tree@^1.1.2, css-tree@^1.1.3: - version "1.1.3" - resolved "https://registry.yarnpkg.com/css-tree/-/css-tree-1.1.3.tgz#eb4870fb6fd7707327ec95c2ff2ab09b5e8db91d" - integrity sha512-tRpdppF7TRazZrjJ6v3stzv93qxRcSsFmW6cX0Zm2NVKpxE1WV1HblnghVv9TreireHkqI/VDEsfolRF1p6y7Q== - dependencies: - mdn-data "2.0.14" - source-map "^0.6.1" - -css-what@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/css-what/-/css-what-5.1.0.tgz#3f7b707aadf633baf62c2ceb8579b545bb40f7fe" - integrity sha512-arSMRWIIFY0hV8pIxZMEfmMI47Wj3R/aWpZDDxWYCPEiOMv6tfOrnpDtgxBYPEQD4V0Y/958+1TdC3iWTFcUPw== - -csso@^4.2.0: - version "4.2.0" - resolved "https://registry.yarnpkg.com/csso/-/csso-4.2.0.tgz#ea3a561346e8dc9f546d6febedd50187cf389529" - integrity sha512-wvlcdIbf6pwKEk7vHj8/Bkc0B4ylXZruLvOgs9doS5eOsOpuodOV2zJChSpkp+pRpYQLQMeF04nr3Z68Sta9jA== - dependencies: - css-tree "^1.1.2" - cssom@^0.4.4: version "0.4.4" resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.4.4.tgz#5a66cf93d2d0b661d80bf6a44fb65f5c2e4e0a10" integrity sha512-p3pvU7r1MyyqbTk+WbNJIgJjG2VmTIaB10rI93LzVPrmDJKkzKYMtxxyAvQXR/NS6otuzveI7+7BBq3SjBS2mw== -cssom@^0.5.0: - version "0.5.0" - resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.5.0.tgz#d254fa92cd8b6fbd83811b9fbaed34663cc17c36" - integrity sha512-iKuQcq+NdHqlAcwUY0o/HL69XQrUaQdMjmStJ8JFmUaiiQErlhrmuigkg/CU4E2J0IyUKUrMAgl36TvN67MqTw== - cssom@~0.3.6: version "0.3.8" resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.3.8.tgz#9f1276f5b2b463f2114d3f2c75250af8c1a36f4a" @@ -2183,15 +2070,6 @@ data-urls@^2.0.0: whatwg-mimetype "^2.3.0" whatwg-url "^8.0.0" -data-urls@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/data-urls/-/data-urls-3.0.1.tgz#597fc2ae30f8bc4dbcf731fcd1b1954353afc6f8" - integrity sha512-Ds554NeT5Gennfoo9KN50Vh6tpgtvYEwraYjejXnyTpu1C7oXKxdFk75REooENHE8ndTVOJuv+BEs4/J/xcozw== - dependencies: - abab "^2.0.3" - whatwg-mimetype "^3.0.0" - whatwg-url "^10.0.0" - debug@4, debug@^4.0.1, debug@^4.1.0, debug@^4.1.1, debug@^4.2.0: version "4.3.3" resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.3.tgz#04266e0b70a98d4462e6e288e38259213332b664" @@ -2211,7 +2089,7 @@ decamelize@^1.2.0: resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290" integrity sha1-9lNNFRSCabIDUue+4m9QH5oZEpA= -decimal.js@^10.2.1, decimal.js@^10.3.1: +decimal.js@^10.2.1: version "10.3.1" resolved "https://registry.yarnpkg.com/decimal.js/-/decimal.js-10.3.1.tgz#d8c3a444a9c6774ba60ca6ad7261c3a94fd5e783" integrity sha512-V0pfhfr8suzyPGOx3nmq4aHqabehUZn6Ch9kyFpV79TGDTWFmHqUqXdabR7QHqxzrYolF4+tVmJhUG4OURg5dQ== @@ -2221,13 +2099,6 @@ decode-uri-component@^0.2.0: resolved "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.0.tgz#eb3913333458775cb84cd1a1fae062106bb87545" integrity sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU= -decompress-response@^4.2.0: - version "4.2.1" - resolved "https://registry.yarnpkg.com/decompress-response/-/decompress-response-4.2.1.tgz#414023cc7a302da25ce2ec82d0d5238ccafd8986" - integrity sha512-jOSne2qbyE+/r8G1VU+G/82LBs2Fs4LAsTiLSHOCOMZQl2OKZ6i8i4IyHemTe+/yIXOtTcRQMzPcgyhoFlqPkw== - dependencies: - mimic-response "^2.0.0" - dedent@^0.7.0: version "0.7.0" resolved "https://registry.yarnpkg.com/dedent/-/dedent-0.7.0.tgz#2495ddbaf6eb874abb0e1be9df22d2e5a544326c" @@ -2277,16 +2148,6 @@ delayed-stream@~1.0.0: resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" integrity sha1-3zrhmayt+31ECqrgsp4icrJOxhk= -delegates@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/delegates/-/delegates-1.0.0.tgz#84c6e159b81904fdca59a0ef44cd870d31250f9a" - integrity sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o= - -detect-libc@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/detect-libc/-/detect-libc-1.0.3.tgz#fa137c4bd698edf55cd5cd02ac559f91a4c4ba9b" - integrity sha1-+hN8S9aY7fVc1c0CrFWfkaTEups= - detect-newline@^3.0.0: version "3.1.0" resolved "https://registry.yarnpkg.com/detect-newline/-/detect-newline-3.1.0.tgz#576f5dfc63ae1a192ff192d8ad3af6308991b651" @@ -2304,20 +2165,6 @@ doctrine@^3.0.0: dependencies: esutils "^2.0.2" -dom-serializer@^1.0.1: - version "1.3.2" - resolved "https://registry.yarnpkg.com/dom-serializer/-/dom-serializer-1.3.2.tgz#6206437d32ceefaec7161803230c7a20bc1b4d91" - integrity sha512-5c54Bk5Dw4qAxNOI1pFEizPSjVsx5+bpJKmL2kPn8JhBUq2q09tTCa3mjijun2NfK78NMouDYNMBkOrPZiS+ig== - dependencies: - domelementtype "^2.0.1" - domhandler "^4.2.0" - entities "^2.0.0" - -domelementtype@^2.0.1, domelementtype@^2.2.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-2.2.0.tgz#9a0b6c2782ed6a1c7323d42267183df9bd8b1d57" - integrity sha512-DtBMo82pv1dFtUmHyr48beiuq792Sxohr+8Hm9zoxklYPfa6n0Z3Byjj2IV7bmr2IyqClnqEQhfgHJJ5QF0R5A== - domexception@^2.0.1: version "2.0.1" resolved "https://registry.yarnpkg.com/domexception/-/domexception-2.0.1.tgz#fb44aefba793e1574b0af6aed2801d057529f304" @@ -2325,43 +2172,6 @@ domexception@^2.0.1: dependencies: webidl-conversions "^5.0.0" -domexception@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/domexception/-/domexception-4.0.0.tgz#4ad1be56ccadc86fc76d033353999a8037d03673" - integrity sha512-A2is4PLG+eeSfoTMA95/s4pvAoSo2mKtiM5jlHkAVewmiO8ISFTFKZjH7UAM1Atli/OT/7JHOrJRJiMKUZKYBw== - dependencies: - webidl-conversions "^7.0.0" - -domhandler@^4.2.0, domhandler@^4.3.0: - version "4.3.0" - resolved "https://registry.yarnpkg.com/domhandler/-/domhandler-4.3.0.tgz#16c658c626cf966967e306f966b431f77d4a5626" - integrity sha512-fC0aXNQXqKSFTr2wDNZDhsEYjCiYsDWl3D01kwt25hm1YIPyDGHvvi3rw+PLqHAl/m71MaiF7d5zvBr0p5UB2g== - dependencies: - domelementtype "^2.2.0" - -domutils@^2.8.0: - version "2.8.0" - resolved "https://registry.yarnpkg.com/domutils/-/domutils-2.8.0.tgz#4437def5db6e2d1f5d6ee859bd95ca7d02048135" - integrity sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A== - dependencies: - dom-serializer "^1.0.1" - domelementtype "^2.2.0" - domhandler "^4.2.0" - -easyqrcodejs-nodejs@^4.4.2: - version "4.4.3" - resolved "https://registry.yarnpkg.com/easyqrcodejs-nodejs/-/easyqrcodejs-nodejs-4.4.3.tgz#52bdbdfaf3449a0fddb0f56c99e365b30b244fdb" - integrity sha512-hKHG3v5UX1aADze2NSqyws9N+Xw8bfXNfTkFvbZxvmzbwCFGPvQ7rQF+95jM2BkJdWjHCJ7/BtRT5dhGWMmdaQ== - dependencies: - canvas "^2.8.0" - jsdom "^18.1.0" - svgo "^2.8.0" - -easyqrcodejs@^4.3.1: - version "4.4.10" - resolved "https://registry.yarnpkg.com/easyqrcodejs/-/easyqrcodejs-4.4.10.tgz#38e84f2002e94b30415fc1232861465e9ce1c5c6" - integrity sha512-DEr/Txdyfo0RsKuC0tX6t72GF5oqNFbnKVL9dTLatL5yiLJaId65BSfa5HKl4FaJt71yRX3DF1sf977FwynWtw== - electron-to-chromium@^1.4.17: version "1.4.34" resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.4.34.tgz#7d87dc0e95c2c65cbd0687ae23146a662506d1ef" @@ -2391,11 +2201,6 @@ enquirer@^2.3.5, enquirer@^2.3.6: dependencies: ansi-colors "^4.1.1" -entities@^2.0.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/entities/-/entities-2.2.0.tgz#098dc90ebb83d8dffa089d55256b351d34c4da55" - integrity sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A== - error-ex@^1.3.1: version "1.3.2" resolved "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.2.tgz#b4ac40648107fdcdcfae242f428bea8a14d4f1bf" @@ -2759,15 +2564,6 @@ form-data@^3.0.0: combined-stream "^1.0.8" mime-types "^2.1.12" -form-data@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/form-data/-/form-data-4.0.0.tgz#93919daeaf361ee529584b9b31664dc12c9fa452" - integrity sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww== - dependencies: - asynckit "^0.4.0" - combined-stream "^1.0.8" - mime-types "^2.1.12" - fragment-cache@^0.2.1: version "0.2.1" resolved "https://registry.yarnpkg.com/fragment-cache/-/fragment-cache-0.2.1.tgz#4290fad27f13e89be7f33799c6bc5a0abfff0d19" @@ -2775,13 +2571,6 @@ fragment-cache@^0.2.1: dependencies: map-cache "^0.2.2" -fs-minipass@^2.0.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/fs-minipass/-/fs-minipass-2.1.0.tgz#7f5036fdbf12c63c169190cbe4199c852271f9fb" - integrity sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg== - dependencies: - minipass "^3.0.0" - fs.realpath@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" @@ -2809,21 +2598,6 @@ functional-red-black-tree@^1.0.1: resolved "https://registry.yarnpkg.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz#1b0ab3bd553b2a0d6399d29c0e3ea0b252078327" integrity sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc= -gauge@^3.0.0: - version "3.0.2" - resolved "https://registry.yarnpkg.com/gauge/-/gauge-3.0.2.tgz#03bf4441c044383908bcfa0656ad91803259b395" - integrity sha512-+5J6MS/5XksCuXq++uFRsnUd7Ovu1XenbeuIuNRJxYWjgQbPuFhT14lAvsWfqfAmnwluf1OwMjz39HjfLPci0Q== - dependencies: - aproba "^1.0.3 || ^2.0.0" - color-support "^1.1.2" - console-control-strings "^1.0.0" - has-unicode "^2.0.1" - object-assign "^4.1.1" - signal-exit "^3.0.0" - string-width "^4.2.3" - strip-ansi "^6.0.1" - wide-align "^1.1.2" - gensync@^1.0.0-beta.2: version "1.0.0-beta.2" resolved "https://registry.yarnpkg.com/gensync/-/gensync-1.0.0-beta.2.tgz#32a6ee76c3d7f52d46b2b1ae5d93fea8580a25e0" @@ -2933,11 +2707,6 @@ has-symbols@^1.0.1: resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.2.tgz#165d3070c00309752a1236a479331e3ac56f1423" integrity sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw== -has-unicode@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/has-unicode/-/has-unicode-2.0.1.tgz#e0e6fe6a28cf51138855e086d1691e771de2a8b9" - integrity sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk= - has-value@^0.3.1: version "0.3.1" resolved "https://registry.yarnpkg.com/has-value/-/has-value-0.3.1.tgz#7b1f58bada62ca827ec0a2078025654845995e1f" @@ -2988,13 +2757,6 @@ html-encoding-sniffer@^2.0.1: dependencies: whatwg-encoding "^1.0.5" -html-encoding-sniffer@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/html-encoding-sniffer/-/html-encoding-sniffer-3.0.0.tgz#2cb1a8cf0db52414776e5b2a7a04d5dd98158de9" - integrity sha512-oWv4T4yJ52iKrufjnyZPkrN0CH3QnrUqdB6In1g5Fe1mia8GmF36gnfNySxoZtxD5+NmYw1EElVXiBk93UeskA== - dependencies: - whatwg-encoding "^2.0.0" - html-escaper@^2.0.0: version "2.0.2" resolved "https://registry.yarnpkg.com/html-escaper/-/html-escaper-2.0.2.tgz#dfd60027da36a36dfcbe236262c00a5822681453" @@ -3009,15 +2771,6 @@ http-proxy-agent@^4.0.1: agent-base "6" debug "4" -http-proxy-agent@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/http-proxy-agent/-/http-proxy-agent-5.0.0.tgz#5129800203520d434f142bc78ff3c170800f2b43" - integrity sha512-n2hY8YdoRE1i7r6M0w9DIw5GgZN0G25P8zLCRQ8rjXtTU3vsNFBI/vWK/UIeE6g5MUUz6avwAPXmL6Fy9D/90w== - dependencies: - "@tootallnate/once" "2" - agent-base "6" - debug "4" - https-proxy-agent@^5.0.0: version "5.0.0" resolved "https://registry.yarnpkg.com/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz#e2a90542abb68a762e0a0850f6c9edadfd8506b2" @@ -3054,13 +2807,6 @@ iconv-lite@0.4.24: dependencies: safer-buffer ">= 2.1.2 < 3" -iconv-lite@0.6.3: - version "0.6.3" - resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.6.3.tgz#a52f80bf38da1952eb5c681790719871a1a72501" - integrity sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw== - dependencies: - safer-buffer ">= 2.1.2 < 3.0.0" - ieee754@^1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.2.1.tgz#8eb7a10a63fff25d15a57b001586d177d1b0d352" @@ -3105,7 +2851,7 @@ inflight@^1.0.4: once "^1.3.0" wrappy "1" -inherits@2, inherits@^2.0.3: +inherits@2: version "2.0.4" resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== @@ -3783,39 +3529,6 @@ jsdom@^16.4.0, jsdom@^16.5.3: ws "^7.4.6" xml-name-validator "^3.0.0" -jsdom@^18.1.0: - version "18.1.1" - resolved "https://registry.yarnpkg.com/jsdom/-/jsdom-18.1.1.tgz#15ec896f5ab7df9669a62375606f47c8c09551aa" - integrity sha512-NmJQbjQ/gpS/1at/ce3nCx89HbXL/f5OcenBe8wU1Eik0ROhyUc3LtmG3567dEHAGXkN8rmILW/qtCOPxPHQJw== - dependencies: - abab "^2.0.5" - acorn "^8.5.0" - acorn-globals "^6.0.0" - cssom "^0.5.0" - cssstyle "^2.3.0" - data-urls "^3.0.1" - decimal.js "^10.3.1" - domexception "^4.0.0" - escodegen "^2.0.0" - form-data "^4.0.0" - html-encoding-sniffer "^3.0.0" - http-proxy-agent "^5.0.0" - https-proxy-agent "^5.0.0" - is-potential-custom-element-name "^1.0.1" - nwsapi "^2.2.0" - parse5 "6.0.1" - saxes "^5.0.1" - symbol-tree "^3.2.4" - tough-cookie "^4.0.0" - w3c-hr-time "^1.0.2" - w3c-xmlserializer "^3.0.0" - webidl-conversions "^7.0.0" - whatwg-encoding "^2.0.0" - whatwg-mimetype "^3.0.0" - whatwg-url "^10.0.0" - ws "^8.2.3" - xml-name-validator "^4.0.0" - jsesc@^2.5.1: version "2.5.2" resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-2.5.2.tgz#80564d2e483dacf6e8ef209650a67df3f0c283a4" @@ -4007,7 +3720,7 @@ lru-cache@^6.0.0: dependencies: yallist "^4.0.0" -make-dir@^3.0.0, make-dir@^3.1.0: +make-dir@^3.0.0: version "3.1.0" resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-3.1.0.tgz#415e967046b3a7f1d185277d84aa58203726a13f" integrity sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw== @@ -4033,11 +3746,6 @@ map-visit@^1.0.0: dependencies: object-visit "^1.0.0" -mdn-data@2.0.14: - version "2.0.14" - resolved "https://registry.yarnpkg.com/mdn-data/-/mdn-data-2.0.14.tgz#7113fc4281917d63ce29b43446f701e68c25ba50" - integrity sha512-dn6wd0uw5GsdswPFfsgMp5NSB0/aDe6fK94YJV/AJDYXL6HVLWBsxeq7js7Ad+mU2K9LAlwpk6kN2D5mwCPVow== - merge-stream@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-2.0.0.tgz#52823629a14dd00c9770fb6ad47dc6310f2c1f60" @@ -4087,11 +3795,6 @@ mimic-fn@^2.1.0: resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== -mimic-response@^2.0.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/mimic-response/-/mimic-response-2.1.0.tgz#d13763d35f613d09ec37ebb30bac0469c0ee8f43" - integrity sha512-wXqjST+SLt7R009ySCglWBCFpjUygmCIfD790/kVbiGmUgfYGuB14PiTd5DwVxSV4NcYHjzMkoj5LjQZwTQLEA== - minimatch@^3.0.4: version "3.0.4" resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" @@ -4104,21 +3807,6 @@ minimist@^1.1.1, minimist@^1.2.0, minimist@^1.2.5: resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.5.tgz#67d66014b66a6a8aaa0c083c5fd58df4e4e97602" integrity sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw== -minipass@^3.0.0: - version "3.1.6" - resolved "https://registry.yarnpkg.com/minipass/-/minipass-3.1.6.tgz#3b8150aa688a711a1521af5e8779c1d3bb4f45ee" - integrity sha512-rty5kpw9/z8SX9dmxblFA6edItUmwJgMeYDZRrwlIVN27i8gysGbznJwUggw2V/FVqFSDdWy040ZPS811DYAqQ== - dependencies: - yallist "^4.0.0" - -minizlib@^2.1.1: - version "2.1.2" - resolved "https://registry.yarnpkg.com/minizlib/-/minizlib-2.1.2.tgz#e90d3466ba209b932451508a11ce3d3632145931" - integrity sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg== - dependencies: - minipass "^3.0.0" - yallist "^4.0.0" - mixin-deep@^1.2.0: version "1.3.2" resolved "https://registry.yarnpkg.com/mixin-deep/-/mixin-deep-1.3.2.tgz#1120b43dc359a785dce65b55b82e257ccf479566" @@ -4127,11 +3815,6 @@ mixin-deep@^1.2.0: for-in "^1.0.2" is-extendable "^1.0.1" -mkdirp@^1.0.3: - version "1.0.4" - resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-1.0.4.tgz#3eb5ed62622756d79a5f0e2a221dfebad75c2f7e" - integrity sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw== - ms@2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" @@ -4142,11 +3825,6 @@ ms@2.1.2: resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== -nan@^2.14.0: - version "2.15.0" - resolved "https://registry.yarnpkg.com/nan/-/nan-2.15.0.tgz#3f34a473ff18e15c1b5626b62903b5ad6e665fee" - integrity sha512-8ZtvEnA2c5aYCZYd1cvgdnU6cqwixRoYg70xPLWUws5ORTa/lnw+u4amixRS/Ac5U5mQVgp9pnlSUnbNWFaWZQ== - nanomatch@^1.2.9: version "1.2.13" resolved "https://registry.yarnpkg.com/nanomatch/-/nanomatch-1.2.13.tgz#b87a8aa4fc0de8fe6be88895b38983ff265bd119" @@ -4174,13 +3852,6 @@ nice-try@^1.0.4: resolved "https://registry.yarnpkg.com/nice-try/-/nice-try-1.0.5.tgz#a3378a7696ce7d223e88fc9b764bd7ef1089e366" integrity sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ== -node-fetch@^2.6.5: - version "2.6.6" - resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.6.tgz#1751a7c01834e8e1697758732e9efb6eeadfaf89" - integrity sha512-Z8/6vRlTUChSdIgMa51jxQ4lrw/Jy5SOW10ObaA47/RElsAN2c5Pn8bTgFGWn/ibwzXTE8qwr1Yzx28vsecXEA== - dependencies: - whatwg-url "^5.0.0" - node-int64@^0.4.0: version "0.4.0" resolved "https://registry.yarnpkg.com/node-int64/-/node-int64-0.4.0.tgz#87a9065cdb355d3182d8f94ce11188b825c68a3b" @@ -4203,13 +3874,6 @@ node-releases@^2.0.1: resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.1.tgz#3d1d395f204f1f2f29a54358b9fb678765ad2fc5" integrity sha512-CqyzN6z7Q6aMeF/ktcMVTzhAHCEpf8SOarwpzpf8pNBY2k5/oM34UHldUwp8VKI7uxct2HxSRdJjBaZeESzcxA== -nopt@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/nopt/-/nopt-5.0.0.tgz#530942bb58a512fccafe53fe210f13a25355dc88" - integrity sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ== - dependencies: - abbrev "1" - normalize-package-data@^2.5.0: version "2.5.0" resolved "https://registry.yarnpkg.com/normalize-package-data/-/normalize-package-data-2.5.0.tgz#e66db1838b200c1dfc233225d12cb36520e234a8" @@ -4246,33 +3910,11 @@ npm-run-path@^4.0.0: dependencies: path-key "^3.0.0" -npmlog@^5.0.1: - version "5.0.1" - resolved "https://registry.yarnpkg.com/npmlog/-/npmlog-5.0.1.tgz#f06678e80e29419ad67ab964e0fa69959c1eb8b0" - integrity sha512-AqZtDUWOMKs1G/8lwylVjrdYgqA4d9nu8hc+0gzRxlDb1I10+FHBGMXs6aiQHFdCUUlqH99MUMuLfzWDNDtfxw== - dependencies: - are-we-there-yet "^2.0.0" - console-control-strings "^1.1.0" - gauge "^3.0.0" - set-blocking "^2.0.0" - -nth-check@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/nth-check/-/nth-check-2.0.1.tgz#2efe162f5c3da06a28959fbd3db75dbeea9f0fc2" - integrity sha512-it1vE95zF6dTT9lBsYbxvqh0Soy4SPowchj0UBGj/V6cTPnXXtQOPUbhZ6CmGzAD/rW22LQK6E96pcdJXk4A4w== - dependencies: - boolbase "^1.0.0" - nwsapi@^2.2.0: version "2.2.0" resolved "https://registry.yarnpkg.com/nwsapi/-/nwsapi-2.2.0.tgz#204879a9e3d068ff2a55139c2c772780681a38b7" integrity sha512-h2AatdwYH+JHiZpv7pt/gSX1XoRGb7L/qSIeuqA6GwYoF9w1vP1cw42TO0aI2pNyshRK5893hNSl+1//vHK7hQ== -object-assign@^4.1.1: - version "4.1.1" - resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" - integrity sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM= - object-copy@^0.1.0: version "0.1.0" resolved "https://registry.yarnpkg.com/object-copy/-/object-copy-0.1.0.tgz#7e7d858b781bd7c991a41ba975ed3812754e998c" @@ -4474,11 +4116,6 @@ pend@~1.2.0: resolved "https://registry.yarnpkg.com/pend/-/pend-1.2.0.tgz#7a57eb550a6783f9115331fcf4663d5c8e007a50" integrity sha1-elfrVQpng/kRUzH89GY9XI4AelA= -penpal@^5.3.0: - version "5.3.0" - resolved "https://registry.yarnpkg.com/penpal/-/penpal-5.3.0.tgz#1a6afc56d6f257189e3d99650f58651a913db3ce" - integrity sha512-ezGckenx66j3RShl4nZiswjgDxyoDaJJ9tLBp46UvVxlA9MlIPF6hWfuppw1AzaDKgUULU1i44QFOuI4SXY/mg== - picocolors@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" @@ -4629,15 +4266,6 @@ read-pkg@^5.2.0: parse-json "^5.0.0" type-fest "^0.6.0" -readable-stream@^3.6.0: - version "3.6.0" - resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.0.tgz#337bbda3adc0706bd3e024426a286d4b4b2c9198" - integrity sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA== - dependencies: - inherits "^2.0.3" - string_decoder "^1.1.1" - util-deprecate "^1.0.1" - regenerate-unicode-properties@^9.0.0: version "9.0.0" resolved "https://registry.yarnpkg.com/regenerate-unicode-properties/-/regenerate-unicode-properties-9.0.0.tgz#54d09c7115e1f53dc2314a974b32c1c344efe326" @@ -4807,11 +4435,6 @@ safe-buffer@~5.1.1: resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== -safe-buffer@~5.2.0: - version "5.2.1" - resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" - integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== - safe-regex@^1.1.0: version "1.1.0" resolved "https://registry.yarnpkg.com/safe-regex/-/safe-regex-1.1.0.tgz#40a3669f3b077d1e943d44629e157dd48023bf2e" @@ -4819,7 +4442,7 @@ safe-regex@^1.1.0: dependencies: ret "~0.1.10" -"safer-buffer@>= 2.1.2 < 3", "safer-buffer@>= 2.1.2 < 3.0.0": +"safer-buffer@>= 2.1.2 < 3": version "2.1.2" resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== @@ -4871,7 +4494,7 @@ semver@^6.0.0, semver@^6.1.1, semver@^6.1.2, semver@^6.3.0: resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.0.tgz#ee0a64c8af5e8ceea67687b133761e1becbd1d3d" integrity sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw== -semver@^7.2.1, semver@^7.3.2, semver@^7.3.5: +semver@^7.2.1, semver@^7.3.2: version "7.3.5" resolved "https://registry.yarnpkg.com/semver/-/semver-7.3.5.tgz#0b621c879348d8998e4b0e4be94b3f12e6018ef7" integrity sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ== @@ -4927,20 +4550,6 @@ signal-exit@^3.0.0, signal-exit@^3.0.2: resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.6.tgz#24e630c4b0f03fea446a2bd299e62b4a6ca8d0af" integrity sha512-sDl4qMFpijcGw22U5w63KmD3cZJfBuFlVNbVMKje2keoKML7X2UzWbc4XrmEbDwg0NXJc3yv4/ox7b+JWb57kQ== -simple-concat@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/simple-concat/-/simple-concat-1.0.1.tgz#f46976082ba35c2263f1c8ab5edfe26c41c9552f" - integrity sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q== - -simple-get@^3.0.3: - version "3.1.0" - resolved "https://registry.yarnpkg.com/simple-get/-/simple-get-3.1.0.tgz#b45be062435e50d159540b576202ceec40b9c6b3" - integrity sha512-bCR6cP+aTdScaQCnQKbPKtJOKDp/hj9EDLJo3Nw4y1QksqaovlW/bnptB6/c1e+qmNIDHRK+oXFDdEqBT8WzUA== - dependencies: - decompress-response "^4.2.0" - once "^1.3.1" - simple-concat "^1.0.0" - sisteransi@^1.0.5: version "1.0.5" resolved "https://registry.yarnpkg.com/sisteransi/-/sisteransi-1.0.5.tgz#134d681297756437cc05ca01370d3a7a571075ed" @@ -5076,11 +4685,6 @@ sprintf-js@~1.0.2: resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c" integrity sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw= -stable@^0.1.8: - version "0.1.8" - resolved "https://registry.yarnpkg.com/stable/-/stable-0.1.8.tgz#836eb3c8382fe2936feaf544631017ce7d47a3cf" - integrity sha512-ji9qxRnOVfcuLDySj9qzhGSEFVobyt1kIOSkj1qZzYLzq7Tos/oUUWvotUPQLlrsidqsK6tBH89Bc9kL5zHA6w== - stack-utils@^2.0.2: version "2.0.5" resolved "https://registry.yarnpkg.com/stack-utils/-/stack-utils-2.0.5.tgz#d25265fca995154659dbbfba3b49254778d2fdd5" @@ -5109,7 +4713,7 @@ string-length@^4.0.1: char-regex "^1.0.2" strip-ansi "^6.0.0" -"string-width@^1.0.2 || 2 || 3 || 4", string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: +string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: version "4.2.3" resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== @@ -5118,13 +4722,6 @@ string-length@^4.0.1: is-fullwidth-code-point "^3.0.0" strip-ansi "^6.0.1" -string_decoder@^1.1.1: - version "1.3.0" - resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e" - integrity sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA== - dependencies: - safe-buffer "~5.2.0" - stringify-object@^3.3.0: version "3.3.0" resolved "https://registry.yarnpkg.com/stringify-object/-/stringify-object-3.3.0.tgz#703065aefca19300d3ce88af4f5b3956d7556629" @@ -5188,19 +4785,6 @@ supports-preserve-symlinks-flag@^1.0.0: resolved "https://registry.yarnpkg.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09" integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w== -svgo@^2.8.0: - version "2.8.0" - resolved "https://registry.yarnpkg.com/svgo/-/svgo-2.8.0.tgz#4ff80cce6710dc2795f0c7c74101e6764cfccd24" - integrity sha512-+N/Q9kV1+F+UeWYoSiULYo4xYSDQlTgb+ayMobAXPwMnLvop7oxKMo9OzIrX5x3eS4L4f2UHhc9axXwY8DpChg== - dependencies: - "@trysound/sax" "0.2.0" - commander "^7.2.0" - css-select "^4.1.3" - css-tree "^1.1.3" - csso "^4.2.0" - picocolors "^1.0.0" - stable "^0.1.8" - symbol-tree@^3.2.4: version "3.2.4" resolved "https://registry.yarnpkg.com/symbol-tree/-/symbol-tree-3.2.4.tgz#430637d248ba77e078883951fb9aa0eed7c63fa2" @@ -5217,18 +4801,6 @@ table@^6.0.9: string-width "^4.2.3" strip-ansi "^6.0.1" -tar@^6.1.11: - version "6.1.11" - resolved "https://registry.yarnpkg.com/tar/-/tar-6.1.11.tgz#6760a38f003afa1b2ffd0ffe9e9abbd0eab3d621" - integrity sha512-an/KZQzQUkZCkuoAA64hM92X0Urb6VpRhAFllDzz44U2mcD5scmT3zBc4VgVpkugF580+DQn8eAFSyoQt0tznA== - dependencies: - chownr "^2.0.0" - fs-minipass "^2.0.0" - minipass "^3.0.0" - minizlib "^2.1.1" - mkdirp "^1.0.3" - yallist "^4.0.0" - terminal-link@^2.0.0: version "2.1.1" resolved "https://registry.yarnpkg.com/terminal-link/-/terminal-link-2.1.1.tgz#14a64a27ab3c0df933ea546fba55f2d078edc994" @@ -5319,18 +4891,6 @@ tr46@^2.1.0: dependencies: punycode "^2.1.1" -tr46@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/tr46/-/tr46-3.0.0.tgz#555c4e297a950617e8eeddef633c87d4d9d6cbf9" - integrity sha512-l7FvfAHlcmulp8kr+flpQZmVwtu7nfRV7NZujtN0OqES8EL4O4e0qqzL0DC5gAvx/ZC/9lk6rhcUwYvkBnBnYA== - dependencies: - punycode "^2.1.1" - -tr46@~0.0.3: - version "0.0.3" - resolved "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a" - integrity sha1-gYT9NH2snNwYWZLzpmIuFLnZq2o= - tslib@^1.8.1: version "1.14.1" resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.14.1.tgz#cf2d38bdc34a134bcaf1091c41f6619e2f672d00" @@ -5470,11 +5030,6 @@ use@^3.1.0: resolved "https://registry.yarnpkg.com/use/-/use-3.1.1.tgz#d50c8cac79a19fbc20f2911f56eb973f4e10070f" integrity sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ== -util-deprecate@^1.0.1: - version "1.0.2" - resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" - integrity sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8= - uuid@^8.3.0: version "8.3.2" resolved "https://registry.yarnpkg.com/uuid/-/uuid-8.3.2.tgz#80d5b5ced271bb9af6c445f21a1a04c606cefbe2" @@ -5516,13 +5071,6 @@ w3c-xmlserializer@^2.0.0: dependencies: xml-name-validator "^3.0.0" -w3c-xmlserializer@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/w3c-xmlserializer/-/w3c-xmlserializer-3.0.0.tgz#06cdc3eefb7e4d0b20a560a5a3aeb0d2d9a65923" - integrity sha512-3WFqGEgSXIyGhOmAFtlicJNMjEps8b1MG31NCA0/vOF9+nKMUW1ckhi9cnNHmf88Rzw5V+dwIwsm2C7X8k9aQg== - dependencies: - xml-name-validator "^4.0.0" - walker@^1.0.7, walker@~1.0.5: version "1.0.8" resolved "https://registry.yarnpkg.com/walker/-/walker-1.0.8.tgz#bd498db477afe573dc04185f011d3ab8a8d7653f" @@ -5530,11 +5078,6 @@ walker@^1.0.7, walker@~1.0.5: dependencies: makeerror "1.0.12" -webidl-conversions@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-3.0.1.tgz#24534275e2a7bc6be7bc86611cc16ae0a5654871" - integrity sha1-JFNCdeKnvGvnvIZhHMFq4KVlSHE= - webidl-conversions@^5.0.0: version "5.0.0" resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-5.0.0.tgz#ae59c8a00b121543a2acc65c0434f57b0fc11aff" @@ -5545,11 +5088,6 @@ webidl-conversions@^6.1.0: resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-6.1.0.tgz#9111b4d7ea80acd40f5270d666621afa78b69514" integrity sha512-qBIvFLGiBpLjfwmYAaHPXsn+ho5xZnGvyGvsarywGNc8VyQJUMHJ8OBKGGrPER0okBeMDaan4mNBlgBROxuI8w== -webidl-conversions@^7.0.0: - version "7.0.0" - resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-7.0.0.tgz#256b4e1882be7debbf01d05f0aa2039778ea080a" - integrity sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g== - whatwg-encoding@^1.0.5: version "1.0.5" resolved "https://registry.yarnpkg.com/whatwg-encoding/-/whatwg-encoding-1.0.5.tgz#5abacf777c32166a51d085d6b4f3e7d27113ddb0" @@ -5557,39 +5095,11 @@ whatwg-encoding@^1.0.5: dependencies: iconv-lite "0.4.24" -whatwg-encoding@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/whatwg-encoding/-/whatwg-encoding-2.0.0.tgz#e7635f597fd87020858626805a2729fa7698ac53" - integrity sha512-p41ogyeMUrw3jWclHWTQg1k05DSVXPLcVxRTYsXUk+ZooOCZLcoYgPZ/HL/D/N+uQPOtcp1me1WhBEaX02mhWg== - dependencies: - iconv-lite "0.6.3" - whatwg-mimetype@^2.3.0: version "2.3.0" resolved "https://registry.yarnpkg.com/whatwg-mimetype/-/whatwg-mimetype-2.3.0.tgz#3d4b1e0312d2079879f826aff18dbeeca5960fbf" integrity sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g== -whatwg-mimetype@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/whatwg-mimetype/-/whatwg-mimetype-3.0.0.tgz#5fa1a7623867ff1af6ca3dc72ad6b8a4208beba7" - integrity sha512-nt+N2dzIutVRxARx1nghPKGv1xHikU7HKdfafKkLNLindmPU/ch3U31NOCGGA/dmPcmb1VlofO0vnKAcsm0o/Q== - -whatwg-url@^10.0.0: - version "10.0.0" - resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-10.0.0.tgz#37264f720b575b4a311bd4094ed8c760caaa05da" - integrity sha512-CLxxCmdUby142H5FZzn4D8ikO1cmypvXVQktsgosNy4a4BHrDHeciBBGZhb0bNoR5/MltoCatso+vFjjGx8t0w== - dependencies: - tr46 "^3.0.0" - webidl-conversions "^7.0.0" - -whatwg-url@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-5.0.0.tgz#966454e8765462e37644d3626f6742ce8b70965d" - integrity sha1-lmRU6HZUYuN2RNNib2dCzotwll0= - dependencies: - tr46 "~0.0.3" - webidl-conversions "^3.0.0" - whatwg-url@^8.0.0, whatwg-url@^8.5.0: version "8.7.0" resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-8.7.0.tgz#656a78e510ff8f3937bc0bcbe9f5c0ac35941b77" @@ -5623,13 +5133,6 @@ which@^2.0.1, which@^2.0.2: dependencies: isexe "^2.0.0" -wide-align@^1.1.2: - version "1.1.5" - resolved "https://registry.yarnpkg.com/wide-align/-/wide-align-1.1.5.tgz#df1d4c206854369ecf3c9a4898f1b23fbd9d15d3" - integrity sha512-eDMORYaPNZ4sQIuuYPDHdQvf4gyCF9rEEV/yPxGfwPkRodwEgiMUUXTx/dex+Me0wxx53S+NgUHaP7y3MGlDmg== - dependencies: - string-width "^1.0.2 || 2 || 3 || 4" - word-wrap@^1.2.3, word-wrap@~1.2.3: version "1.2.3" resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.3.tgz#610636f6b1f703891bd34771ccb17fb93b47079c" @@ -5673,21 +5176,11 @@ ws@^7.4.6: resolved "https://registry.yarnpkg.com/ws/-/ws-7.5.6.tgz#e59fc509fb15ddfb65487ee9765c5a51dec5fe7b" integrity sha512-6GLgCqo2cy2A2rjCNFlxQS6ZljG/coZfZXclldI8FB/1G3CCI36Zd8xy2HrFVACi8tfk5XrgLQEk+P0Tnz9UcA== -ws@^8.2.3: - version "8.4.0" - resolved "https://registry.yarnpkg.com/ws/-/ws-8.4.0.tgz#f05e982a0a88c604080e8581576e2a063802bed6" - integrity sha512-IHVsKe2pjajSUIl4KYMQOdlyliovpEPquKkqbwswulszzI7r0SfQrxnXdWAEqOlDCLrVSJzo+O1hAwdog2sKSQ== - xml-name-validator@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/xml-name-validator/-/xml-name-validator-3.0.0.tgz#6ae73e06de4d8c6e47f9fb181f78d648ad457c6a" integrity sha512-A5CUptxDsvxKJEU3yO6DuWBSJz/qizqzJKOMIfUJHETbBw/sFaDxgd6fxm1ewUaM0jZ444Fc5vC5ROYurg/4Pw== -xml-name-validator@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/xml-name-validator/-/xml-name-validator-4.0.0.tgz#79a006e2e63149a8600f15430f0a4725d1524835" - integrity sha512-ICP2e+jsHvAj2E2lIHxa5tjXRlKDJo4IdvPvCXbXQGdzSfmSpNVyIKMvoZHjDY9DP0zV17iI85o90vRFXNccRw== - xmlchars@^2.2.0: version "2.2.0" resolved "https://registry.yarnpkg.com/xmlchars/-/xmlchars-2.2.0.tgz#060fe1bcb7f9c76fe2a17db86a9bc3ab894210cb" -- GitLab