Compare commits
	
		
			15 Commits
		
	
	
		
			2ef8b2deec
			...
			cq-config
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 7314c18ca4 | |||
| 7761d12bc8 | |||
| d09a3d43b2 | |||
| 5e809bc053 | |||
| 2168bc72d0 | |||
| 0b066aaa3a | |||
| a91b8b2a9a | |||
| d2bacfdb9c | |||
| 27ce7b5659 | |||
| 17eafa8872 | |||
| d82f43cea5 | |||
| 1e39ac631d | |||
| 3339d58a93 | |||
| fcc8ecb3ee | |||
| 5a20d190b1 | 
							
								
								
									
										179
									
								
								dist/main.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										179
									
								
								dist/main.js
									
									
									
									
										vendored
									
									
								
							| @ -5,7 +5,11 @@ let logger; | ||||
| let transcodingManager; | ||||
| const DEFAULT_HARDWARE_DECODE = false; | ||||
| const DEFAULT_VOD_QUALITY = "p7"; | ||||
| const DEFAULT_HEVC_PROFILE = "main10"; | ||||
| const DEFAULT_LIVE_QUALITY = "hq"; | ||||
| const DEFAULT_HEVC_ENABLED = false; | ||||
| const DEFAULT_CQ_H264 = 26; | ||||
| const DEFAULT_CQ_HEVC = 28; | ||||
| const DEFAULT_BITRATES = new Map([ | ||||
|     [0, 64 * 1000], | ||||
|     [144, 320 * 1000], | ||||
| @ -20,6 +24,10 @@ let pluginSettings = { | ||||
|     hardwareDecode: DEFAULT_HARDWARE_DECODE, | ||||
|     vodQuality: DEFAULT_VOD_QUALITY, | ||||
|     liveQuality: DEFAULT_LIVE_QUALITY, | ||||
|     hevcEnabled: DEFAULT_HEVC_ENABLED, | ||||
|     hevcProfile: DEFAULT_HEVC_PROFILE, | ||||
|     cqH264: DEFAULT_CQ_H264, | ||||
|     cqHEVC: DEFAULT_CQ_HEVC, | ||||
|     baseBitrate: new Map(DEFAULT_BITRATES) | ||||
| }; | ||||
| let latestStreamNum = 9999; | ||||
| @ -28,11 +36,20 @@ async function register({ settingsManager, peertubeHelpers, transcodingManager: | ||||
|     transcodingManager = transcode; | ||||
|     logger.info("Registering peertube-plugin-nctv-hardware-encode"); | ||||
|     const encoder = 'h264_nvenc'; | ||||
|     const hevc = 'hevc_nvenc'; | ||||
|     const profileName = 'nctv-nvenc'; | ||||
|     const hevcProfile = 'nctv-hevc'; | ||||
|     transcodingManager.addVODProfile(encoder, profileName, vodBuilder); | ||||
|     transcodingManager.addVODEncoderPriority('video', encoder, 1000); | ||||
|  | ||||
|     transcodingManager.addLiveProfile(encoder, profileName, liveBuilder); | ||||
|     transcodingManager.addLiveEncoderPriority('video', encoder, 1000); | ||||
|      | ||||
|     transcodingManager.addVODProfile(hevc, hevcProfile, hevcVODBuilder); | ||||
|     transcodingManager.addVODEncoderPriority('video', hevc, 900); | ||||
|      | ||||
|     transcodingManager.addLiveProfile(hevc, hevcProfile, hevcLiveBuilder); | ||||
|     transcodingManager.addLiveEncoderPriority('video', hevc, 900); | ||||
|     await loadSettings(settingsManager); | ||||
|     registerSetting({ | ||||
|         name: 'hardware-decode', | ||||
| @ -42,6 +59,30 @@ async function register({ settingsManager, peertubeHelpers, transcodingManager: | ||||
|         default: DEFAULT_HARDWARE_DECODE, | ||||
|         private: false | ||||
|     }); | ||||
|     registerSetting({ | ||||
|         name: 'hevc-enabled', | ||||
|         label: 'Enable H265 NVENC', | ||||
|         type: 'input-checkbox', | ||||
|         descriptionHTML: 'Enables H265 NVENC (experimental)', | ||||
|         default: DEFAULT_HEVC_ENABLED, | ||||
|         private: false | ||||
|     }); | ||||
|     registerSetting({ | ||||
|         name: 'cq-h264', | ||||
|         label: 'CQ Value for H264_nvenc', | ||||
|         type: 'input', | ||||
|         descriptionHTML: 'Sets the -cq value for h264_nvenc encoder. Valid values are between 0 and 51 (lossess and AIDS, respectively)', | ||||
|         default: DEFAULT_CQ_H264, | ||||
|         private: false | ||||
|     }); | ||||
|     registerSetting({ | ||||
|         name: 'cq-hevc', | ||||
|         label: 'CQ Value for hevc_nvenc', | ||||
|         type: 'input', | ||||
|         descriptionHTML: 'Sets the -cq value for hevc_nvenc encoder. Valid values are between 0 and 51 (lossess and AIDS, respectively)', | ||||
|         default: DEFAULT_CQ_HEVC, | ||||
|         private: false | ||||
|     }); | ||||
|     registerSetting({ | ||||
|         name: 'vod-quality', | ||||
|         label: 'VOD Quality', | ||||
| @ -59,6 +100,19 @@ async function register({ settingsManager, peertubeHelpers, transcodingManager: | ||||
|         default: DEFAULT_VOD_QUALITY.toString(), | ||||
|         private: false | ||||
|     }); | ||||
|     registerSetting({ | ||||
|         name: 'hevc-profile', | ||||
|         label: 'HEVC Profile', | ||||
|         type: 'select', | ||||
|         options: [ | ||||
|             { label: 'main', value: 'main' }, | ||||
|             { label: 'main10 (default)', value: 'main10' }, | ||||
|             { label: 'rext', value: 'rext' } | ||||
|         ], | ||||
|         descriptionHTML: 'Set the HEVC profile', | ||||
|         default: DEFAULT_HEVC_PROFILE.toString(), | ||||
|         private: false | ||||
|     }); | ||||
|     registerSetting({ | ||||
|         name: 'live-quality', | ||||
|         label: 'Live Quality', | ||||
| @ -103,9 +157,14 @@ async function unregister() { | ||||
| } | ||||
| exports.unregister = unregister; | ||||
| async function loadSettings(settingsManager) { | ||||
|     pluginSettings.hardwareDecode = await settingsManager.getSetting('hardware-decode') == "true"; | ||||
|     pluginSettings.hardwareDecode = await settingsManager.getSetting('hardware-decode') || DEFAULT_HARDWARE_DECODE; | ||||
|     pluginSettings.vodQuality = parseInt(await settingsManager.getSetting('vod-quality')) || DEFAULT_VOD_QUALITY; | ||||
|     pluginSettings.liveQuality = parseInt(await settingsManager.getSetting('live-quality')) || DEFAULT_LIVE_QUALITY; | ||||
|     pluginSettings.hevcProfile = parseInt(await settingsManager.getSetting('hevc-profile')) || DEFAULT_HEVC_PROFILE; | ||||
|     pluginSettings.hevcEnabled = await settingsManager.getSetting('hevc-enabled') || DEFAULT_HEVC_ENABLED; | ||||
|     pluginSettings.cqH264 = parseInt(await settingsManager.getSetting('cq-h264')) || DEFAULT_CQ_H264; | ||||
|     pluginSettings.cqHEVC = parseInt(await settingsManager.getSetting('cq-hevc')) || DEFAULT_CQ_HEVC; | ||||
|  | ||||
|     for (const [resolution, bitrate] of DEFAULT_BITRATES) { | ||||
|         const key = `base-bitrate-${resolution}`; | ||||
|         const storedValue = await settingsManager.getSetting(key); | ||||
| @ -115,6 +174,8 @@ async function loadSettings(settingsManager) { | ||||
|     logger.info(`Hardware decode: ${pluginSettings.hardwareDecode}`); | ||||
|     logger.info(`VOD Quality: ${pluginSettings.vodQuality}`); | ||||
|     logger.info(`Live Quality: ${pluginSettings.liveQuality}`); | ||||
|     logger.info(`HEVC enabled: ${pluginSettings.hevcEnabled}`); | ||||
|     logger.info(`HEVC profile: ${pluginSettings.hevcProfile}`); | ||||
| } | ||||
| function printResolution(resolution) { | ||||
|     switch (resolution) { | ||||
| @ -143,16 +204,19 @@ function buildInitOptions() { | ||||
|         ]; | ||||
|     } | ||||
| } | ||||
|  | ||||
| //H264_NVENC VOD BUILDER | ||||
|  | ||||
| async function vodBuilder(params) { | ||||
|     const { resolution, fps, streamNum, inputBitrate } = params; | ||||
|     const streamSuffix = streamNum == undefined ? '' : `:${streamNum}`; | ||||
|     //let targetBitrate = getTargetBitrate(resolution, fps); | ||||
|     let targetBitrate = inputBitrate; | ||||
|     let targetBitrate = getTargetBitrate(resolution, fps); | ||||
|     // let targetBitrate = inputBitrate; | ||||
|     let shouldInitVaapi = (streamNum == undefined || streamNum <= latestStreamNum); | ||||
|     //if (targetBitrate > inputBitrate) { | ||||
|     //    targetBitrate = inputBitrate; | ||||
|     //} | ||||
|     logger.info(`Building encoder options, received ${JSON.stringify(params)}`); | ||||
|     if (targetBitrate > inputBitrate) { | ||||
|         targetBitrate = inputBitrate; | ||||
|     } | ||||
|     logger.info(`Building encoder options, received ${JSON.stringify(params)}, HEVC: ${pluginSettings.hevcEnabled}`); | ||||
|     if (shouldInitVaapi && streamNum != undefined) { | ||||
|         latestStreamNum = streamNum; | ||||
|     } | ||||
| @ -164,32 +228,103 @@ async function vodBuilder(params) { | ||||
|             outputOptions: [ | ||||
|                 `-preset ${pluginSettings.vodQuality}`, | ||||
|                 `-b:v${streamSuffix} ${targetBitrate}`, | ||||
|             //`-b:v${streamSuffix} 0`, | ||||
|                 `-bufsize ${targetBitrate * 2}`, | ||||
|                 `-profile:v${streamSuffix} high`, | ||||
|             `-cq 21`, | ||||
|             `-rc:v vbr`, | ||||
|             `-c:v${streamSuffix} h264_nvenc`, | ||||
|                 `-cq ${pluginSettings.cqH264}`, | ||||
|                 `-bf 4` | ||||
|             ] | ||||
|         }; | ||||
|  | ||||
|     logger.info(`EncoderOptions: ${JSON.stringify(options)}`); | ||||
|     return options; | ||||
| } | ||||
| async function liveBuilder(params) { | ||||
|  | ||||
| //HEVC VOD builder | ||||
| async function hevcVODBuilder(params) { | ||||
|     const { resolution, fps, streamNum, inputBitrate } = params; | ||||
|     const streamSuffix = streamNum == undefined ? '' : `:${streamNum}`; | ||||
|     // let targetBitrate = getTargetBitrate(resolution, fps); | ||||
|     let targetBitrate = inputBitrate; | ||||
|     let targetBitrate = getTargetBitrate(resolution, fps); | ||||
|     // let targetBitrate = inputBitrate; | ||||
|     let shouldInitVaapi = (streamNum == undefined || streamNum <= latestStreamNum); | ||||
|     //if (targetBitrate > inputBitrate) { | ||||
|     //     targetBitrate = inputBitrate; | ||||
|     //} | ||||
|     logger.info(`Building encoder options, received ${JSON.stringify(params)}`); | ||||
|     if (targetBitrate > inputBitrate) { | ||||
|         targetBitrate = inputBitrate; | ||||
|     } | ||||
|     logger.info(`Building encoder options, received ${JSON.stringify(params)}, HEVC: ${pluginSettings.hevcEnabled}`); | ||||
|     if (shouldInitVaapi && streamNum != undefined) { | ||||
|         latestStreamNum = streamNum; | ||||
|     } | ||||
|     const options = { | ||||
|     let options = { | ||||
|         scaleFilter: { | ||||
|             name: 'scale' | ||||
|         }, | ||||
|         inputOptions: shouldInitVaapi ? buildInitOptions() : [], | ||||
|         outputOptions: [ | ||||
|             `-preset ${pluginSettings.vodQuality}`, | ||||
|             `-b:v${streamSuffix} ${targetBitrate}`, | ||||
|             `-bufsize ${targetBitrate * 2}`, | ||||
|             `-profile:v${streamSuffix} ${pluginSettings.hevcProfile}`, | ||||
|             `-cq ${pluginSettings.cqHEVC}` | ||||
|         ] | ||||
|     }; | ||||
|  | ||||
|     logger.info(`EncoderOptions: ${JSON.stringify(options)}`); | ||||
|     return options; | ||||
|  | ||||
| } | ||||
|  | ||||
| //HEVC Live builder | ||||
|  | ||||
| async function hevcLiveBuilder(params) { | ||||
|     const { resolution, fps, streamNum, inputBitrate } = params; | ||||
|     const streamSuffix = streamNum == undefined ? '' : `:${streamNum}`; | ||||
|     let targetBitrate = getTargetBitrate(resolution, fps); | ||||
|     // let targetBitrate = inputBitrate; | ||||
|     let shouldInitVaapi = (streamNum == undefined || streamNum <= latestStreamNum); | ||||
|     if (targetBitrate > inputBitrate) { | ||||
|         targetBitrate = inputBitrate; | ||||
|     } | ||||
|     logger.info(`Building encoder options, received ${JSON.stringify(params)}, HEVC: ${pluginSettings.hevcEnabled}`); | ||||
|     if (shouldInitVaapi && streamNum != undefined) { | ||||
|         latestStreamNum = streamNum; | ||||
|     } | ||||
|  | ||||
|     let options = { | ||||
|         scaleFilter: { | ||||
|             name: 'scale' | ||||
|         }, | ||||
|         inputOptions: shouldInitVaapi ? buildInitOptions() : [], | ||||
|         outputOptions: [ | ||||
|             `-tune ${pluginSettings.liveQuality}`, | ||||
|             `-r:v${streamSuffix} ${fps}`, | ||||
|             `-profile:v${streamSuffix} ${pluginSettings.hevcProfile}`, | ||||
|             `-g:v${streamSuffix} ${fps * 2}`, | ||||
|             `-b:v${streamSuffix} ${targetBitrate}`, | ||||
|             `-cq ${pluginSettings.cqHEVC}`, | ||||
|             `-bufsize ${targetBitrate * 2}` | ||||
|         ] | ||||
|     }; | ||||
|  | ||||
|     logger.info(`EncoderOptions: ${JSON.stringify(options)}`); | ||||
|     return options; | ||||
| } | ||||
|  | ||||
| //H264 Live builder | ||||
|  | ||||
| async function liveBuilder(params) { | ||||
|     const { resolution, fps, streamNum, inputBitrate } = params; | ||||
|     const streamSuffix = streamNum == undefined ? '' : `:${streamNum}`; | ||||
|     let targetBitrate = getTargetBitrate(resolution, fps); | ||||
|     // let targetBitrate = inputBitrate; | ||||
|     let shouldInitVaapi = (streamNum == undefined || streamNum <= latestStreamNum); | ||||
|     if (targetBitrate > inputBitrate) { | ||||
|         targetBitrate = inputBitrate; | ||||
|     } | ||||
|     logger.info(`Building encoder options, received ${JSON.stringify(params)}, HEVC: ${pluginSettings.hevcEnabled}`); | ||||
|     if (shouldInitVaapi && streamNum != undefined) { | ||||
|         latestStreamNum = streamNum; | ||||
|     } | ||||
|  | ||||
|     let options = { | ||||
|         scaleFilter: { | ||||
|             name: 'scale' | ||||
|         }, | ||||
| @ -198,16 +333,14 @@ async function liveBuilder(params) { | ||||
|             `-tune ${pluginSettings.liveQuality}`, | ||||
|             `-r:v${streamSuffix} ${fps}`, | ||||
|             `-profile:v${streamSuffix} high`, | ||||
|             `-c:v${streamSuffix} h264_nvenc`, | ||||
|             `-cq 21`, | ||||
|             `-cq ${pluginSettings.cqH264}`, | ||||
|             `-g:v${streamSuffix} ${fps * 2}`, | ||||
|             `-b:v${streamSuffix} ${targetBitrate}`, | ||||
|             //`-b:v${streamSuffix} 0`, | ||||
|             `-bufsize ${targetBitrate * 2}`, | ||||
|             `-rc:v vbr`, | ||||
|             `-bf 4` | ||||
|         ] | ||||
|     }; | ||||
|  | ||||
|     logger.info(`EncoderOptions: ${JSON.stringify(options)}`); | ||||
|     return options; | ||||
| } | ||||
|  | ||||
| @ -11,7 +11,7 @@ | ||||
|         "plugin" | ||||
|     ], | ||||
|     "homepage": "https://gitea.nicecrew.digital/matty/peertube-plugin-nctv-nvenc-transcode", | ||||
|     "author": "ryanho", | ||||
|     "author": "matty", | ||||
|     "bugs": "https://gitea.nicecrew.digital/matty/peertube-plugin-nctv-nvenc-transcode/issues", | ||||
|     "library": "./dist/main.js", | ||||
|     "files": [ | ||||
|  | ||||
							
								
								
									
										190
									
								
								yarn.lock
									
									
									
									
									
								
							
							
						
						
									
										190
									
								
								yarn.lock
									
									
									
									
									
								
							| @ -54,7 +54,7 @@ | ||||
|     "@aws-sdk/util-utf8-browser" "^3.0.0" | ||||
|     tslib "^1.11.1" | ||||
|  | ||||
| "@aws-crypto/sha256-js@^3.0.0", "@aws-crypto/sha256-js@3.0.0": | ||||
| "@aws-crypto/sha256-js@3.0.0", "@aws-crypto/sha256-js@^3.0.0": | ||||
|   version "3.0.0" | ||||
|   resolved "https://registry.npmjs.org/@aws-crypto/sha256-js/-/sha256-js-3.0.0.tgz" | ||||
|   integrity sha512-PnNN7os0+yd1XvXAy23CFOmTbMaDxgxXtTKHybrJ39Y8kGzBATgBFibWJKH6BhytLI/Zyszs87xCOBNyBig6vQ== | ||||
| @ -330,7 +330,7 @@ | ||||
|     "@smithy/types" "^2.10.1" | ||||
|     tslib "^2.5.0" | ||||
|  | ||||
| "@aws-sdk/credential-provider-node@^3.529.1", "@aws-sdk/credential-provider-node@3.529.1": | ||||
| "@aws-sdk/credential-provider-node@3.529.1": | ||||
|   version "3.529.1" | ||||
|   resolved "https://registry.npmjs.org/@aws-sdk/credential-provider-node/-/credential-provider-node-3.529.1.tgz" | ||||
|   integrity sha512-mvY7F3dMmk/0dZOCfl5sUI1bG0osureBjxhELGCF0KkJqhWI0hIzh8UnPkYytSg3vdc97CMv7pTcozxrdA3b0g== | ||||
| @ -542,7 +542,7 @@ | ||||
|     "@smithy/types" "^2.10.1" | ||||
|     tslib "^2.5.0" | ||||
|  | ||||
| "@aws-sdk/types@^3.222.0", "@aws-sdk/types@3.523.0": | ||||
| "@aws-sdk/types@3.523.0", "@aws-sdk/types@^3.222.0": | ||||
|   version "3.523.0" | ||||
|   resolved "https://registry.npmjs.org/@aws-sdk/types/-/types-3.523.0.tgz" | ||||
|   integrity sha512-AqGIu4u+SxPiUuNBp2acCVcq80KDUFjxe6e3cMTvKWTzCbrVk1AXv0dAaJnCmdkWIha6zJDWxpIk/aL4EGhZ9A== | ||||
| @ -643,16 +643,16 @@ | ||||
|   resolved "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-darwin-x64/-/msgpackr-extract-darwin-x64-3.0.2.tgz" | ||||
|   integrity sha512-lwriRAHm1Yg4iDf23Oxm9n/t5Zpw1lVnxYU3HnJPTi2lJRkKTrps1KVgvL6m7WvmhYVt/FIsssWay+k45QHeuw== | ||||
|  | ||||
| "@msgpackr-extract/msgpackr-extract-linux-arm@3.0.2": | ||||
|   version "3.0.2" | ||||
|   resolved "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-linux-arm/-/msgpackr-extract-linux-arm-3.0.2.tgz" | ||||
|   integrity sha512-MOI9Dlfrpi2Cuc7i5dXdxPbFIgbDBGgKR5F2yWEa6FVEtSWncfVNKW5AKjImAQ6CZlBK9tympdsZJ2xThBiWWA== | ||||
|  | ||||
| "@msgpackr-extract/msgpackr-extract-linux-arm64@3.0.2": | ||||
|   version "3.0.2" | ||||
|   resolved "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-linux-arm64/-/msgpackr-extract-linux-arm64-3.0.2.tgz" | ||||
|   integrity sha512-FU20Bo66/f7He9Fp9sP2zaJ1Q8L9uLPZQDub/WlUip78JlPeMbVL8546HbZfcW9LNciEXc8d+tThSJjSC+tmsg== | ||||
|  | ||||
| "@msgpackr-extract/msgpackr-extract-linux-arm@3.0.2": | ||||
|   version "3.0.2" | ||||
|   resolved "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-linux-arm/-/msgpackr-extract-linux-arm-3.0.2.tgz" | ||||
|   integrity sha512-MOI9Dlfrpi2Cuc7i5dXdxPbFIgbDBGgKR5F2yWEa6FVEtSWncfVNKW5AKjImAQ6CZlBK9tympdsZJ2xThBiWWA== | ||||
|  | ||||
| "@msgpackr-extract/msgpackr-extract-linux-x64@3.0.2": | ||||
|   version "3.0.2" | ||||
|   resolved "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-linux-x64/-/msgpackr-extract-linux-x64-3.0.2.tgz" | ||||
| @ -679,7 +679,7 @@ | ||||
|     promisify-any "2.0.1" | ||||
|     type-is "1.6.18" | ||||
|  | ||||
| "@opentelemetry/api@^1.1.0", "@opentelemetry/api@>=1.0.0 <1.9.0", "@opentelemetry/api@>=1.3.0 <1.9.0": | ||||
| "@opentelemetry/api@^1.1.0": | ||||
|   version "1.8.0" | ||||
|   resolved "https://registry.npmjs.org/@opentelemetry/api/-/api-1.8.0.tgz" | ||||
|   integrity sha512-I/s6F7yKUDdtMsoBWXJe8Qz40Tui5vsuKCWJEWVL+5q9sSWRzzx6v2KeNsOBEwd94j0eWkpWCH4yB6rZg9Mf0w== | ||||
| @ -1378,7 +1378,7 @@ | ||||
|   dependencies: | ||||
|     "@types/express" "*" | ||||
|  | ||||
| "@types/node@*", "@types/node@^18.13.0", "@types/node@>=10.0.0": | ||||
| "@types/node@*", "@types/node@>=10.0.0", "@types/node@^18.13.0": | ||||
|   version "18.19.22" | ||||
|   resolved "https://registry.npmjs.org/@types/node/-/node-18.19.22.tgz" | ||||
|   integrity sha512-p3pDIfuMg/aXBmhkyanPshdfJuX5c5+bQjYLIikPLXAUycEogij/c50n/C+8XOA5L93cU4ZRXtn+dNQGi0IZqQ== | ||||
| @ -1424,7 +1424,7 @@ | ||||
|   resolved "https://registry.npmjs.org/@types/triple-beam/-/triple-beam-1.3.5.tgz" | ||||
|   integrity sha512-6WaYesThRMCl19iryMYP7/x2OVgCtbIVflDGFpWnb9irXI3UjYE4AzmYuiUKY1AJstGijoY+MgUszMgRxIYTYw== | ||||
|  | ||||
| "@types/validator@*", "@types/validator@^13.0.0", "@types/validator@^13.7.1": | ||||
| "@types/validator@^13.0.0", "@types/validator@^13.7.1": | ||||
|   version "13.11.9" | ||||
|   resolved "https://registry.npmjs.org/@types/validator/-/validator-13.11.9.tgz" | ||||
|   integrity sha512-FCTsikRozryfayPuiI46QzH3fnrOoctTjvOYZkho9BTFLCOZ2rgZJHMOVgCOfttjPJcgOx52EpkY0CMfy87MIw== | ||||
| @ -1468,7 +1468,7 @@ async-mutex@^0.4.0: | ||||
|   dependencies: | ||||
|     tslib "^2.4.0" | ||||
|  | ||||
| async@^3.2.3, async@>=0.2.9: | ||||
| async@>=0.2.9, async@^3.2.3: | ||||
|   version "3.2.5" | ||||
|   resolved "https://registry.npmjs.org/async/-/async-3.2.5.tgz" | ||||
|   integrity sha512-baNZyqaaLhyLVKm/DlvdW051MSgO6b8eVfIezl9E5PqWxFgzLm/wQntEW4zOytVburDEr0JlALEpdOFwvErLsg== | ||||
| @ -1478,7 +1478,7 @@ balanced-match@^1.0.0: | ||||
|   resolved "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz" | ||||
|   integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw== | ||||
|  | ||||
| base64id@~2.0.0, base64id@2.0.0: | ||||
| base64id@2.0.0, base64id@~2.0.0: | ||||
|   version "2.0.0" | ||||
|   resolved "https://registry.npmjs.org/base64id/-/base64id-2.0.0.tgz" | ||||
|   integrity sha512-lGe34o6EHj9y3Kts9R4ZYs/Gr+6N7MCaMlIFA3F1R2O5/m7K06AxfSeO5530PEERE6/WyEg3lsuyw4GHlPZHog== | ||||
| @ -1505,16 +1505,16 @@ blob-to-buffer@^1.2.9: | ||||
|   resolved "https://registry.npmjs.org/blob-to-buffer/-/blob-to-buffer-1.2.9.tgz" | ||||
|   integrity sha512-BF033y5fN6OCofD3vgHmNtwZWRcq9NLyyxyILx9hfMy1sXYy4ojFl765hJ2lP0YaN2fuxPaLO2Vzzoxy0FLFFA== | ||||
|  | ||||
| bluebird@3.7.2, bluebird@^3.5.0: | ||||
|   version "3.7.2" | ||||
|   resolved "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz" | ||||
|   integrity sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg== | ||||
|  | ||||
| bluebird@^2.10.0: | ||||
|   version "2.11.0" | ||||
|   resolved "https://registry.npmjs.org/bluebird/-/bluebird-2.11.0.tgz" | ||||
|   integrity sha512-UfFSr22dmHPQqPP9XWHRhq+gWnHCYguQGkXQlbyPtW5qTnhFWA8/iXg765tH0cAjy7l/zPJ1aBTO0g5XgA7kvQ== | ||||
|  | ||||
| bluebird@^3.5.0, bluebird@3.7.2: | ||||
|   version "3.7.2" | ||||
|   resolved "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz" | ||||
|   integrity sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg== | ||||
|  | ||||
| body-parser@1.20.2: | ||||
|   version "1.20.2" | ||||
|   resolved "https://registry.npmjs.org/body-parser/-/body-parser-1.20.2.tgz" | ||||
| @ -1579,7 +1579,7 @@ busboy@^1.0.0: | ||||
|   dependencies: | ||||
|     streamsearch "^1.1.0" | ||||
|  | ||||
| bytes@^3.1.0, bytes@3.1.2: | ||||
| bytes@3.1.2, bytes@^3.1.0: | ||||
|   version "3.1.2" | ||||
|   resolved "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz" | ||||
|   integrity sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg== | ||||
| @ -1645,7 +1645,7 @@ color-convert@^1.9.3: | ||||
|   dependencies: | ||||
|     color-name "1.1.3" | ||||
|  | ||||
| color-name@^1.0.0, color-name@1.1.3: | ||||
| color-name@1.1.3, color-name@^1.0.0: | ||||
|   version "1.1.3" | ||||
|   resolved "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz" | ||||
|   integrity sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw== | ||||
| @ -1706,16 +1706,16 @@ cookie-signature@1.0.6: | ||||
|   resolved "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz" | ||||
|   integrity sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ== | ||||
|  | ||||
| cookie@~0.4.1: | ||||
|   version "0.4.2" | ||||
|   resolved "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz" | ||||
|   integrity sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA== | ||||
|  | ||||
| cookie@0.5.0: | ||||
|   version "0.5.0" | ||||
|   resolved "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz" | ||||
|   integrity sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw== | ||||
|  | ||||
| cookie@~0.4.1: | ||||
|   version "0.4.2" | ||||
|   resolved "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz" | ||||
|   integrity sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA== | ||||
|  | ||||
| core-util-is@~1.0.0: | ||||
|   version "1.0.3" | ||||
|   resolved "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz" | ||||
| @ -1745,7 +1745,7 @@ cross-spawn@^7.0.3: | ||||
|     shebang-command "^2.0.0" | ||||
|     which "^2.0.1" | ||||
|  | ||||
| d@^1.0.1, d@^1.0.2, d@1: | ||||
| d@1, d@^1.0.1, d@^1.0.2: | ||||
|   version "1.0.2" | ||||
|   resolved "https://registry.npmjs.org/d/-/d-1.0.2.tgz" | ||||
|   integrity sha512-MOqHvMWF9/9MX6nza0KgvFH4HpMU0EF5uUDXqX/BtxtU8NfB0QzRtJ8Oe/6SuS4kbhyzVJwjd97EA4PKrzJ8bw== | ||||
| @ -1753,41 +1753,6 @@ d@^1.0.1, d@^1.0.2, d@1: | ||||
|     es5-ext "^0.10.64" | ||||
|     type "^2.7.2" | ||||
|  | ||||
| debug@^4.3.3: | ||||
|   version "4.3.4" | ||||
|   resolved "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz" | ||||
|   integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== | ||||
|   dependencies: | ||||
|     ms "2.1.2" | ||||
|  | ||||
| debug@^4.3.4: | ||||
|   version "4.3.4" | ||||
|   resolved "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz" | ||||
|   integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== | ||||
|   dependencies: | ||||
|     ms "2.1.2" | ||||
|  | ||||
| debug@~4.3.1: | ||||
|   version "4.3.4" | ||||
|   resolved "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz" | ||||
|   integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== | ||||
|   dependencies: | ||||
|     ms "2.1.2" | ||||
|  | ||||
| debug@~4.3.2: | ||||
|   version "4.3.4" | ||||
|   resolved "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz" | ||||
|   integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== | ||||
|   dependencies: | ||||
|     ms "2.1.2" | ||||
|  | ||||
| debug@~4.3.4: | ||||
|   version "4.3.4" | ||||
|   resolved "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz" | ||||
|   integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== | ||||
|   dependencies: | ||||
|     ms "2.1.2" | ||||
|  | ||||
| debug@2.6.9: | ||||
|   version "2.6.9" | ||||
|   resolved "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz" | ||||
| @ -1795,6 +1760,13 @@ debug@2.6.9: | ||||
|   dependencies: | ||||
|     ms "2.0.0" | ||||
|  | ||||
| debug@^4.3.3, debug@^4.3.4, debug@~4.3.1, debug@~4.3.2, debug@~4.3.4: | ||||
|   version "4.3.4" | ||||
|   resolved "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz" | ||||
|   integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== | ||||
|   dependencies: | ||||
|     ms "2.1.2" | ||||
|  | ||||
| decompress-response@^6.0.0: | ||||
|   version "6.0.0" | ||||
|   resolved "https://registry.npmjs.org/decompress-response/-/decompress-response-6.0.0.tgz" | ||||
| @ -1821,16 +1793,16 @@ denque@^2.1.0: | ||||
|   resolved "https://registry.npmjs.org/denque/-/denque-2.1.0.tgz" | ||||
|   integrity sha512-HVQE3AAb/pxF8fQAoiqpvg9i3evqug3hoiwakOyZAwJm+6vZehbkYXZ0l4JxS+I3QxM97v5aaRNhj8v5oBhekw== | ||||
|  | ||||
| depd@~1.1.2: | ||||
|   version "1.1.2" | ||||
|   resolved "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz" | ||||
|   integrity sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ== | ||||
|  | ||||
| depd@2.0.0: | ||||
|   version "2.0.0" | ||||
|   resolved "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz" | ||||
|   integrity sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw== | ||||
|  | ||||
| depd@~1.1.2: | ||||
|   version "1.1.2" | ||||
|   resolved "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz" | ||||
|   integrity sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ== | ||||
|  | ||||
| destroy@1.2.0: | ||||
|   version "1.2.0" | ||||
|   resolved "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz" | ||||
| @ -2123,17 +2095,6 @@ get-stream@^6.0.0: | ||||
|   resolved "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz" | ||||
|   integrity sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg== | ||||
|  | ||||
| glob@^8.0.3: | ||||
|   version "8.1.0" | ||||
|   resolved "https://registry.npmjs.org/glob/-/glob-8.1.0.tgz" | ||||
|   integrity sha512-r8hpEjiQEYlF2QU0df3dS+nxxSIreXQS1qRhMJM0Q5NDdR386C7jb7Hwwod8Fgiuex+k0GFjgft18yvxm5XoCQ== | ||||
|   dependencies: | ||||
|     fs.realpath "^1.0.0" | ||||
|     inflight "^1.0.4" | ||||
|     inherits "2" | ||||
|     minimatch "^5.0.1" | ||||
|     once "^1.3.0" | ||||
|  | ||||
| glob@7.2.0: | ||||
|   version "7.2.0" | ||||
|   resolved "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz" | ||||
| @ -2146,6 +2107,17 @@ glob@7.2.0: | ||||
|     once "^1.3.0" | ||||
|     path-is-absolute "^1.0.0" | ||||
|  | ||||
| glob@^8.0.3: | ||||
|   version "8.1.0" | ||||
|   resolved "https://registry.npmjs.org/glob/-/glob-8.1.0.tgz" | ||||
|   integrity sha512-r8hpEjiQEYlF2QU0df3dS+nxxSIreXQS1qRhMJM0Q5NDdR386C7jb7Hwwod8Fgiuex+k0GFjgft18yvxm5XoCQ== | ||||
|   dependencies: | ||||
|     fs.realpath "^1.0.0" | ||||
|     inflight "^1.0.4" | ||||
|     inherits "2" | ||||
|     minimatch "^5.0.1" | ||||
|     once "^1.3.0" | ||||
|  | ||||
| gopd@^1.0.1: | ||||
|   version "1.0.1" | ||||
|   resolved "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz" | ||||
| @ -2209,17 +2181,6 @@ http-cache-semantics@^4.0.0: | ||||
|   resolved "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.1.tgz" | ||||
|   integrity sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ== | ||||
|  | ||||
| http-errors@~1.8.1: | ||||
|   version "1.8.1" | ||||
|   resolved "https://registry.npmjs.org/http-errors/-/http-errors-1.8.1.tgz" | ||||
|   integrity sha512-Kpk9Sm7NmI+RHhnj6OIWDI1d6fIoFAtFt9RLaTMRlg/8w49juAStsrBgp0Dp4OdxdVbRIeKhtCUvoi/RuAhO4g== | ||||
|   dependencies: | ||||
|     depd "~1.1.2" | ||||
|     inherits "2.0.4" | ||||
|     setprototypeof "1.2.0" | ||||
|     statuses ">= 1.5.0 < 2" | ||||
|     toidentifier "1.0.1" | ||||
|  | ||||
| http-errors@2.0.0: | ||||
|   version "2.0.0" | ||||
|   resolved "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz" | ||||
| @ -2231,6 +2192,17 @@ http-errors@2.0.0: | ||||
|     statuses "2.0.1" | ||||
|     toidentifier "1.0.1" | ||||
|  | ||||
| http-errors@~1.8.1: | ||||
|   version "1.8.1" | ||||
|   resolved "https://registry.npmjs.org/http-errors/-/http-errors-1.8.1.tgz" | ||||
|   integrity sha512-Kpk9Sm7NmI+RHhnj6OIWDI1d6fIoFAtFt9RLaTMRlg/8w49juAStsrBgp0Dp4OdxdVbRIeKhtCUvoi/RuAhO4g== | ||||
|   dependencies: | ||||
|     depd "~1.1.2" | ||||
|     inherits "2.0.4" | ||||
|     setprototypeof "1.2.0" | ||||
|     statuses ">= 1.5.0 < 2" | ||||
|     toidentifier "1.0.1" | ||||
|  | ||||
| http2-wrapper@^1.0.0-beta.5.2: | ||||
|   version "1.0.3" | ||||
|   resolved "https://registry.npmjs.org/http2-wrapper/-/http2-wrapper-1.0.3.tgz" | ||||
| @ -2264,7 +2236,7 @@ inflight@^1.0.4: | ||||
|     once "^1.3.0" | ||||
|     wrappy "1" | ||||
|  | ||||
| inherits@^2.0.3, inherits@~2.0.3, inherits@2, inherits@2.0.4: | ||||
| inherits@2, inherits@2.0.4, inherits@^2.0.3, inherits@~2.0.3: | ||||
|   version "2.0.4" | ||||
|   resolved "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz" | ||||
|   integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== | ||||
| @ -2518,11 +2490,6 @@ moment@^2.29.1, moment@^2.29.4: | ||||
|   resolved "https://registry.npmjs.org/moment/-/moment-2.30.1.tgz" | ||||
|   integrity sha512-uEmtNhbDOrWPFS+hdjFCBfy9f2YoyzRpwcl+DqpC6taX21FzsTLQVbMV/W7PzNSX6x/bhC1zA3c2UQ5NzH6how== | ||||
|  | ||||
| ms@^2.1.1: | ||||
|   version "2.1.3" | ||||
|   resolved "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz" | ||||
|   integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== | ||||
|  | ||||
| ms@2.0.0: | ||||
|   version "2.0.0" | ||||
|   resolved "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz" | ||||
| @ -2533,7 +2500,7 @@ ms@2.1.2: | ||||
|   resolved "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz" | ||||
|   integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== | ||||
|  | ||||
| ms@2.1.3: | ||||
| ms@2.1.3, ms@^2.1.1: | ||||
|   version "2.1.3" | ||||
|   resolved "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz" | ||||
|   integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== | ||||
| @ -2586,7 +2553,7 @@ negotiator@0.6.3: | ||||
|   resolved "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz" | ||||
|   integrity sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg== | ||||
|  | ||||
| next-tick@^1.1.0, next-tick@1: | ||||
| next-tick@1, next-tick@^1.1.0: | ||||
|   version "1.1.0" | ||||
|   resolved "https://registry.npmjs.org/next-tick/-/next-tick-1.1.0.tgz" | ||||
|   integrity sha512-CXdUiJembsNjuToQvxayPZF9Vqht7hewsvy2sOWafLvi2awflj9mOC6bHIg50orX8IJvWKY9wYQ/zB2kogPslQ== | ||||
| @ -2774,16 +2741,7 @@ readable-stream@^2.2.2: | ||||
|     string_decoder "~1.1.1" | ||||
|     util-deprecate "~1.0.1" | ||||
|  | ||||
| readable-stream@^3.4.0: | ||||
|   version "3.6.2" | ||||
|   resolved "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz" | ||||
|   integrity sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA== | ||||
|   dependencies: | ||||
|     inherits "^2.0.3" | ||||
|     string_decoder "^1.1.1" | ||||
|     util-deprecate "^1.0.1" | ||||
|  | ||||
| readable-stream@^3.6.0: | ||||
| readable-stream@^3.4.0, readable-stream@^3.6.0: | ||||
|   version "3.6.2" | ||||
|   resolved "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz" | ||||
|   integrity sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA== | ||||
| @ -2804,7 +2762,7 @@ redis-parser@^3.0.0: | ||||
|   dependencies: | ||||
|     redis-errors "^1.0.0" | ||||
|  | ||||
| reflect-metadata@*, reflect-metadata@^0.1.12: | ||||
| reflect-metadata@^0.1.12: | ||||
|   version "0.1.14" | ||||
|   resolved "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.1.14.tgz" | ||||
|   integrity sha512-ZhYeb6nRaXCfhnndflDK8qI6ZQ/YcWZCISRAWICW9XYqMUwjZM9Z0DveWX/ABN01oxSHwVxKQmxeYZSsm0jh5A== | ||||
| @ -2831,7 +2789,7 @@ rusha@^0.8.13: | ||||
|   resolved "https://registry.npmjs.org/rusha/-/rusha-0.8.14.tgz" | ||||
|   integrity sha512-cLgakCUf6PedEu15t8kbsjnwIFFR2D4RfL+W3iWFJ4iac7z4B0ZI8fxy4R3J956kAI68HclCFGL8MPoUVC3qVA== | ||||
|  | ||||
| safe-buffer@~5.1.0, safe-buffer@~5.1.1, safe-buffer@5.1.2: | ||||
| safe-buffer@5.1.2, safe-buffer@~5.1.0, safe-buffer@~5.1.1: | ||||
|   version "5.1.2" | ||||
|   resolved "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz" | ||||
|   integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== | ||||
| @ -2894,7 +2852,7 @@ sequelize-typescript@^2.0.0-beta.1: | ||||
|   dependencies: | ||||
|     glob "7.2.0" | ||||
|  | ||||
| sequelize@>=6.20.1, sequelize@6.31.1: | ||||
| sequelize@6.31.1: | ||||
|   version "6.31.1" | ||||
|   resolved "https://registry.npmjs.org/sequelize/-/sequelize-6.31.1.tgz" | ||||
|   integrity sha512-cahWtRrYLjqoZP/aurGBoaxn29qQCF4bxkAUPEQ/ozjJjt6mtL4Q113S3N39mQRmX5fgxRbli+bzZARP/N51eg== | ||||
| @ -3046,16 +3004,16 @@ standard-as-callback@^2.1.0: | ||||
|   resolved "https://registry.npmjs.org/standard-as-callback/-/standard-as-callback-2.1.0.tgz" | ||||
|   integrity sha512-qoRRSyROncaz1z0mvYqIE4lCd9p2R90i6GxW3uZv5ucSu8tU7B5HXUP1gG8pVZsYNVaXjk8ClXHPttLyxAL48A== | ||||
|  | ||||
| "statuses@>= 1.5.0 < 2": | ||||
|   version "1.5.0" | ||||
|   resolved "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz" | ||||
|   integrity sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA== | ||||
|  | ||||
| statuses@2.0.1: | ||||
|   version "2.0.1" | ||||
|   resolved "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz" | ||||
|   integrity sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ== | ||||
|  | ||||
| "statuses@>= 1.5.0 < 2": | ||||
|   version "1.5.0" | ||||
|   resolved "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz" | ||||
|   integrity sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA== | ||||
|  | ||||
| streamsearch@^1.1.0: | ||||
|   version "1.1.0" | ||||
|   resolved "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz" | ||||
| @ -3121,7 +3079,7 @@ tslib@^2.0.0, tslib@^2.3.1, tslib@^2.4.0, tslib@^2.5.0: | ||||
|   resolved "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz" | ||||
|   integrity sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q== | ||||
|  | ||||
| type-is@^1.6.4, type-is@~1.6.18, type-is@1.6.18: | ||||
| type-is@1.6.18, type-is@^1.6.4, type-is@~1.6.18: | ||||
|   version "1.6.18" | ||||
|   resolved "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz" | ||||
|   integrity sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g== | ||||
| @ -3161,7 +3119,7 @@ universalify@^2.0.0: | ||||
|   resolved "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz" | ||||
|   integrity sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw== | ||||
|  | ||||
| unpipe@~1.0.0, unpipe@1.0.0: | ||||
| unpipe@1.0.0, unpipe@~1.0.0: | ||||
|   version "1.0.0" | ||||
|   resolved "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz" | ||||
|   integrity sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ== | ||||
|  | ||||
		Reference in New Issue
	
	Block a user