├── .eslintrc.json ├── .gitignore ├── .prettierrc.json ├── .travis.yml ├── CHANGELOG.md ├── LICENSE ├── MIGRATING.md ├── README.md ├── ROADMAP.md ├── example.js ├── luxtronik.js ├── package-lock.json ├── package.json ├── test ├── data │ ├── 3003 │ ├── 3004 │ └── 3005 ├── luxtronikTest.js └── mocha.opts ├── types.js └── utils.js /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "env": { 3 | "commonjs": true, 4 | "es2021": true, 5 | "node": true, 6 | "mocha": true 7 | }, 8 | "extends": [ 9 | "eslint:recommended" 10 | ], 11 | "parserOptions": { 12 | "ecmaVersion": 2020 13 | }, 14 | "rules": { 15 | "indent": [ 16 | "error", 17 | 4 18 | ], 19 | "linebreak-style": [ 20 | "error", 21 | "unix" 22 | ], 23 | "quotes": [ 24 | "error", 25 | "single" 26 | ], 27 | "semi": [ 28 | "error", 29 | "always" 30 | ] 31 | } 32 | } -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | 6 | # Runtime data 7 | pids 8 | *.pid 9 | *.seed 10 | 11 | # Directory for instrumented libs generated by jscoverage/JSCover 12 | lib-cov 13 | 14 | # Coverage directory used by tools like istanbul 15 | coverage 16 | 17 | # nyc test coverage 18 | .nyc_output 19 | 20 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) 21 | .grunt 22 | 23 | # node-waf configuration 24 | .lock-wscript 25 | 26 | # Compiled binary addons (http://nodejs.org/api/addons.html) 27 | build/Release 28 | 29 | # Dependency directories 30 | node_modules 31 | jspm_packages 32 | 33 | # Optional npm cache directory 34 | .npm 35 | 36 | # Optional REPL history 37 | .node_repl_history 38 | 39 | # Visual Studio Code 40 | .vscode 41 | 42 | # IntelliJ 43 | *.iml 44 | -------------------------------------------------------------------------------- /.prettierrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "semi": true, 3 | "trailingComma": "all", 4 | "singleQuote": true, 5 | "printWidth": 160, 6 | "tabWidth": 4 7 | } -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | sudo: false 3 | node_js: 4 | - "10" 5 | - "lts/*" 6 | - "node" 7 | install: 8 | - npm install 9 | -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | Upcoming 2 | ======== 3 | * optimize file/folder structure 4 | * queue read/write jobs (fix for job collisions) 5 | 6 | v1.0.0 / 25 Jul 2017 [see migrating guide](MIGRATING.md) 7 | ======================================================== 8 | * create object with luxtronik.createConnection() instead of "new" 9 | * return errors in callback instead of winston.log them 10 | * use error-first standard for handling callback parameters 11 | * correct spelling of "temperature" at write function 12 | * add early returns for cleaner functions 13 | * add installation how-to and rewrite example code 14 | * update dev-dependecies 15 | 16 | v0.1.2 / 13 Apr 2017 17 | ==================== 18 | * enable strict mode in all js files (**thanks to marcus**) 19 | 20 | v0.1.1 / 13 Apr 2017 21 | ==================== 22 | * insert roadmap 23 | * use of luxtronik always creates a new object - even without "new" 24 | * moved some code, renamed some functions and rewrite some passages to make the code more readable 25 | * add eslint to project and fix some eslint problems 26 | 27 | v0.1.0 / 12 Apr 2017 28 | ==================== 29 | * added missing error event handlers for client connection (**thanks to marcus**) 30 | * fixed handling, when heatpump is busy (**thanks to marcus**) 31 | * return plain text for error code and outage codes (**thanks to bakito**) 32 | 33 | v0.0.2 / 11 Apr 2017 34 | ==================== 35 | * add readRaw() function to get the raw data from the pump 36 | * code correctness 37 | 38 | v0.0.1 / 06 Apr 2017 39 | ==================== 40 | * first official release -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2017 Sebastian B. 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /MIGRATING.md: -------------------------------------------------------------------------------- 1 | # Migrating 2 | 3 | ## to 2.0.0 4 | 5 | Minimalistic breaking changes. Only the parameter name "returnTempHyst" has changed to "returnTemperatureHysteresis". And "hotWaterTemperatureHysterese" changed to "hotWaterTemperatureHysteresis". 6 | 7 | ## to 1.0.0 8 | 9 | Little changes were made betwen v0.1.2 and v1.0.0. This document describes how 10 | to upgrade your application or library to use the new APIs when upgrading to 11 | luxtronik2 1.0.0. 12 | 13 | ### Creating an object 14 | 15 | In version 1.0.0, you not longer need to create an instance of luxtronik2. Just 16 | use the createConnection() function to create an connection object to your pump. 17 | 18 | v0.1.2: 19 | 20 | ``` 21 | // v0.1.2 22 | const pump = new luxtronik('127.0.0.1', 8888); 23 | ``` 24 | 25 | v1.0.0: 26 | 27 | ``` 28 | // v1.0.0 29 | const pump = luxtronik.createConnection('127.0.0.1', 8888); 30 | ``` 31 | 32 | ### Use Node.js ["error-first" callback standard](http://fredkschott.com/post/2014/03/understanding-error-first-callbacks-in-node-js/) 33 | 34 | In version 1.0.0, luxtronik2 gives you two parameters in the callback. First 35 | is an error object, second is the data you want to receive. If the error argument 36 | is null, then the operation was successful and if the error argument is not null, 37 | then an error has occurred. This is the Node.js standard way for callbacks. 38 | 39 | So you fist have to check if there is an error. Otherwise your are able to continue 40 | processing your data. Be carefull! If error isn't null, no data 41 | 42 | v0.1.2: 43 | 44 | ``` 45 | // v0.1.2 46 | pump.read(function (data) { 47 | console.log(data); 48 | }); 49 | ``` 50 | 51 | v1.0.0: 52 | 53 | ``` 54 | // v1.0.0 55 | pump.read(function (err, data) { 56 | if (err) { 57 | return console.log(err); 58 | } 59 | console.log(data); 60 | }); 61 | ``` 62 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Luxtronik2 2 | 3 | Luxtronik2 reads and controls heat pumps based on the Luxtronik 2.0 contol unit with **Node.js**. 4 | 5 | This work based on the fantastic [FHEM module 'LUXTRONIK2'](https://wiki.fhem.de/wiki/Luxtronik_2.0), the very usefull [openHAB binding 'Novelan Luxtronic heat pump']( 6 | https://github.com/openhab/openhab1-addons/wiki/Novelan-Luxtronic-heat-pump-binding), the extensively [cbrandlehner/homebridge-luxtronik2](https://github.com/cbrandlehner/homebridge-luxtronik2) and a little bit research of my own. Hope you will like it. 7 | 8 | **Supports the following heat pumps** 9 | 10 | * Alpha Innotec 11 | * Siemens Novelan (WPR NET) 12 | * Roth (ThermoAura(r), ThermoTerra) 13 | * Elco 14 | * Buderus (Logamatic HMC20, HMC20 Z) 15 | * Nibe (AP-AW10) 16 | * Wolf Heiztechnik (BWL/BWS) 17 | * CTA (Aeroheat AH CI 1-16iL) 18 | 19 | ## Status 20 | 21 | | Category | Status | 22 | | ---------------- | ------------------------------------------------------------------------------------------------------------------------- | 23 | | Version | [![npm version](https://badge.fury.io/js/luxtronik2.svg)](https://badge.fury.io/js/luxtronik2) | 24 | | License | [![npm](https://img.shields.io/npm/l/express.svg)](https://www.npmjs.com/package/luxtronik2) | 25 | ## Installation 26 | 27 | ```shell 28 | npm install luxtronik2 29 | ``` 30 | 31 | ## How to use 32 | 33 | Connect your unit via lan and configure the ip parameters at your unit. The port number of your unit is 8888 by default. 34 | Clone this code via git or simply via npm. You will get a package named luxtronik. You can require this at your code to 35 | read and write to your heat pump. 36 | 37 | ## Examples 38 | 39 | ```javascript 40 | var luxtronik = require('luxtronik2'); 41 | 42 | const hostIp = '127.0.0.1'; // <- Enter your Luxtronik IP here 43 | var pump = new luxtronik.createConnection(hostIp, 8888); 44 | 45 | // read all readable data 46 | pump.read(function (err, data) { 47 | if (err) { 48 | return console.log(err); 49 | } 50 | console.log(data); 51 | console.log(data.values.errors); 52 | }); 53 | 54 | // set heating target temperature to 0 °C 55 | pump.write('heating_target_temperature', 0); 56 | 57 | // set warm water target temperature to 60 °C and use callback 58 | pump.write('warmwater_target_temperature', 60, function (err, res) { 59 | if (err) { 60 | return console.log(err); 61 | } 62 | console.log(res); 63 | }); 64 | 65 | // set heating operation mode to 'Auto' 66 | pump.write('heating_operation_mode', 0); 67 | 68 | // set warm water operation mode to 'Auto' 69 | pump.write('warmwater_operation_mode', 0); 70 | 71 | // set heating target temperature and use callback 72 | pump.write('heating_target_temperature', 0, function (err, res) { 73 | if (err) { 74 | return console.log(err); 75 | } 76 | console.log(res); 77 | }); 78 | 79 | ``` 80 | 81 | ### Ability to plug in to processing data 82 | 83 | It is possible to plug in to data processing by passing third option into `createConnection` function (or Luxtronik constructor). See the example below: 84 | 85 | ```javascript 86 | const pump = luxtronik.createConnection('192.168.0.190', 8889, { 87 | onProcessValues: function (heatpumpValues, heatpumpVisibility) { 88 | return { 89 | additional_value: (heatpumpVisibility[24] === 1) ? heatpumpValues[13] / 10 : 'no', 90 | }; 91 | }, 92 | onProcessParameters: function (heatpumpParameters, heatpumpVisibility) { 93 | return { 94 | additional_parameter: (heatpumpVisibility[207] === 1) ? heatpumpParameters[11] / 10 : 'no', 95 | }; 96 | }, 97 | }); 98 | 99 | pump.read(function (err, data) { 100 | if (err) { 101 | return console.log(err); 102 | } 103 | console.log(data); 104 | console.log(data.values.errors); 105 | }); 106 | ``` 107 | 108 | Output: 109 | 110 | ```javascript 111 | { 112 | values: { 113 | additional_value: 'no', 114 | // ...regular values 115 | }, 116 | parameters: { 117 | additional_parameter: 26.5, 118 | // ...regular parameters 119 | } 120 | } 121 | [ 122 | // ...errors will go here 123 | ] 124 | 125 | ``` 126 | 127 | ### read/set runDearate 128 | 129 | Note: you need to set "runDearate" directly after you set the related pump, otherwise the Lux will not start the pump! 130 | 131 | Example code: 132 | 133 | ```javascript 134 | const value= 1; 135 | pump.write('solarPumpDeaerate', value, function (err, data) { 136 | if (err) { 137 | return console.log(err); 138 | } 139 | console.log(data); 140 | console.log("done"); 141 | 142 | pump.write('runDeaerate', value, function (err, data) { 143 | if (err) { 144 | return console.log(err); 145 | } 146 | console.log(data); 147 | console.log("done"); 148 | }); 149 | }); 150 | ``` 151 | 152 | ## Migrating to version 2.0.0 153 | 154 | The API changed between version 1.0.3 and version 2.0.0. [See migrating guide](MIGRATING.md) for information on how to migrate your application to the new API. 155 | 156 | ## Migrating to version 1.0.0 157 | 158 | The API changed between version 0.1.2 and version 1.0.0. [See migrating guide](MIGRATING.md) for information on how to migrate your application to the new API. 159 | -------------------------------------------------------------------------------- /ROADMAP.md: -------------------------------------------------------------------------------- 1 | 2 | Luxtronik2 Roadmap 3 | ================== 4 | This roadmap is a short, living document and should give some indication for the future. 5 | 6 | Goals 7 | ----- 8 | * **Use a standard Node.js file/folder structure**. 9 | * **Translate to clean english and other languages**. The output of Luxtronik is a crazy language mixture. I want a clear output. First in English and than translate to other Languages. 10 | * **Queue read/write jobs**. If a new read/write command is triggered, before the old is done, the modules crashes. 11 | * **Reduce complexity of some functions**. Some functions are really complex and not readable. I will fix that. 12 | -------------------------------------------------------------------------------- /example.js: -------------------------------------------------------------------------------- 1 | const luxtronik = require('./luxtronik'); 2 | 3 | const pump = luxtronik.createConnection('127.0.0.1', 8888); 4 | 5 | pump.read(function (err, data) { 6 | if (err) { 7 | return console.log(err); 8 | } 9 | console.log(data); 10 | console.log(data.values.errors); 11 | 12 | require('fs').writeFileSync('data.json', JSON.stringify(data, null, 4)); 13 | }); 14 | /* 15 | pump.write('heating_target_temperature', 0, function (err, data) { 16 | if (!err) { 17 | console.log(data); 18 | } 19 | }); 20 | pump.write('warmwater_target_temperature', 60); 21 | pump.write('heating_operation_mode', 0, function (err, data) { 22 | if (!err) { 23 | console.log(data); 24 | } 25 | }); 26 | pump.write('warmwater_operation_mode', 0, function (err, data) { 27 | if (!err) { 28 | console.log(data); 29 | } 30 | }); 31 | */ 32 | -------------------------------------------------------------------------------- /luxtronik.js: -------------------------------------------------------------------------------- 1 | /** 2 | * @module luxtronik2 3 | * @copyright Sebastian B. 4 | */ 5 | 6 | 'use strict'; 7 | 8 | const net = require('net'); 9 | 10 | const utils = require('./utils'); 11 | const types = require('./types'); 12 | 13 | function Luxtronik(host, port, options) { 14 | if (!(this instanceof Luxtronik)) { 15 | return new Luxtronik(host, port, options); 16 | } 17 | 18 | if (typeof port === 'undefined') { 19 | this._port = 8888; 20 | } else { 21 | this._port = port; 22 | } 23 | this._host = host; 24 | this.receivy = {}; 25 | this.options = options; 26 | } 27 | 28 | function processValues(heatpumpValues, heatpumpVisibility) { 29 | let additionalValues = {}; 30 | if (this.options && typeof this.options.onProcessValues === 'function') { 31 | additionalValues = this.options.onProcessValues(heatpumpValues, heatpumpVisibility); 32 | } 33 | 34 | return { 35 | ...additionalValues, 36 | temperature_supply: heatpumpValues[10] / 10, // #15 37 | temperature_return: heatpumpValues[11] / 10, // #16 38 | temperature_target_return: heatpumpValues[12] / 10, // #17 39 | temperature_extern_return: heatpumpVisibility[24] === 1 ? heatpumpValues[13] / 10 : 'no', // #18 40 | temperature_hot_gas: heatpumpValues[14] / 10, // #26 41 | temperature_outside: heatpumpValues[15] / 10, // #12 42 | temperature_outside_avg: heatpumpValues[16] / 10, // #13 43 | temperature_hot_water: heatpumpValues[17] / 10, // #14 44 | temperature_hot_water_target: heatpumpValues[18] / 10, // #25 45 | temperature_heat_source_in: heatpumpValues[19] / 10, // #23 46 | temperature_heat_source_out: heatpumpValues[20] / 10, // #24 47 | temperature_mixer1_flow: heatpumpVisibility[31] === 1 ? heatpumpValues[21] / 10 : 'no', // #55 48 | temperature_mixer1_target: heatpumpVisibility[32] === 1 ? heatpumpValues[22] / 10 : 'no', // #56 49 | temperaturw_RFV: heatpumpVisibility[33] === 1 ? heatpumpValues[23] / 10 : 'no', 50 | temperature_mixer2_flow: heatpumpVisibility[34] === 1 ? heatpumpValues[24] / 10 : 'no', // #57 51 | temperature_mixer2_target: heatpumpVisibility[35] === 1 ? heatpumpValues[25] / 10 : 'no', // #48 52 | temperature_solar_collector: heatpumpVisibility[36] === 1 ? heatpumpValues[26] / 10 : 'no', // #50 53 | temperature_solar_storage: heatpumpVisibility[37] === 1 ? heatpumpValues[27] / 10 : 'no', // #51 54 | temperature_external_source: heatpumpVisibility[38] === 1 ? heatpumpValues[28] / 10 : 'no', 55 | 56 | temperature_intake_evaporation: heatpumpValues[175] / 10, // unit: °C 57 | temperature_intake_compressor1: heatpumpValues[176] / 10, // unit: °C 58 | temperature_compressor1_heating: heatpumpValues[177] / 10, // unit: °C 59 | temperature_overheating: heatpumpValues[178] / 10, // unit: Kelvin 60 | temperature_overheating_target: heatpumpValues[179] / 10, // unit: Kelvin 61 | 62 | ASDin: heatpumpValues[29], // Abtau, Soledruck, Durchfluss 63 | BWTin: heatpumpValues[30], 64 | EVUin: heatpumpValues[31], // Sperrzeit Energieversorger 65 | HDin: heatpumpValues[32], // Hochdruckpressostat, value 0: pressure OK 66 | HDin_pressure: heatpumpValues[180] / 100, // Hochdruckpressostat, unit: bar 67 | MOTin: heatpumpValues[33], // Motorschutz 68 | NDin: heatpumpValues[34], // Niederdruckpressostat, value 1: pressure OK 69 | NDin_pressure: heatpumpValues[181] / 100, // Niederdruckpressostat, unit: bar 70 | PEXin: heatpumpValues[35], // Fremdstromanode 71 | SWTin: heatpumpValues[36], 72 | 73 | AVout: heatpumpValues[37], // Abtauventil / Kreislaufumkehr 74 | BUPout: heatpumpValues[38], // Warmwasserumwälzpumpe 75 | HUPout: heatpumpValues[39], // Heizungsumwälzpumpe 76 | MA1out: heatpumpValues[40], // Mischer 1 auf 77 | MZ1out: heatpumpValues[41], // Mischer 1 zu 78 | VENout: heatpumpValues[42], // Ventilator Wärmepumpengehäuse 79 | VBOout: heatpumpValues[43], // Ventil BOSUP: Ventilator-, Brunnen- oder Soleumwälzpumpe 80 | VD1out: heatpumpValues[44], // Verdichter/Kompressor 1 81 | VD2out: heatpumpValues[45], // Verdichter/Kompressor 2 82 | ZIPout: heatpumpValues[46], // Zirkulationspumpe 83 | ZUPout: heatpumpValues[47], // Zusatzumwälzpumpe 84 | ZW1out: heatpumpValues[48], // Zweiter Wärmeerzeuger 1 85 | ZW2SSTout: heatpumpValues[49], // Zweiter Wärmeerzeuger 2 - Sammelstörung 86 | ZW3SSTout: heatpumpValues[50], // Zweiter Wärmeerzeuger 3 - Sammelstörung 87 | FP2out: heatpumpValues[51], 88 | SLPout: heatpumpValues[52], 89 | SUPout: heatpumpValues[53], 90 | MZ2out: heatpumpValues[54], // Mischer 2 zu 91 | MA2out: heatpumpValues[55], // Mischer 2 auf 92 | 93 | defrostValve: heatpumpVisibility[47] === 1 ? heatpumpValues[37] : 'no', // #67 94 | hotWaterBoilerValve: heatpumpValues[38], // #9 95 | heatingSystemCircPump: heatpumpValues[39] === 1 ? 'on' : 'off', // #27 96 | 97 | heatSourceMotor: heatpumpVisibility[54] === 1 ? heatpumpValues[43] : 'no', // #64 98 | compressor1: heatpumpValues[44], 99 | 100 | hotWaterCircPumpExtern: heatpumpVisibility[57] === 1 ? heatpumpValues[46] : 'no', // #28 101 | 102 | hours_compressor1: Math.round(heatpumpValues[56] / 3600), 103 | starts_compressor1: heatpumpValues[57], 104 | hours_compressor2: Math.round(heatpumpValues[58] / 3600), 105 | starts_compressor2: heatpumpValues[59], 106 | hours_2nd_heat_source1: heatpumpVisibility[84] === 1 ? Math.round(heatpumpValues[60] / 3600) : 'no', // #32 107 | hours_2nd_heat_source2: heatpumpVisibility[85] === 1 ? Math.round(heatpumpValues[61] / 3600) : 'no', // #38 108 | hours_2nd_heat_source3: heatpumpVisibility[86] === 1 ? Math.round(heatpumpValues[62] / 3600) : 'no', // #39 109 | hours_heatpump: heatpumpVisibility[87] === 1 ? Math.round(heatpumpValues[63] / 3600) : 'no', // #33 110 | hours_heating: heatpumpVisibility[195] === 1 ? Math.round(heatpumpValues[64] / 3600) : 'no', // #34 111 | hours_warmwater: heatpumpVisibility[196] === 1 ? Math.round(heatpumpValues[65] / 3600) : 'no', // #35 112 | hours_cooling: heatpumpVisibility[197] === 1 ? Math.round(heatpumpValues[66] / 3600) : 'no', 113 | 114 | Time_WPein_akt: heatpumpValues[67], 115 | Time_ZWE1_akt: heatpumpValues[68], 116 | Time_ZWE2_akt: heatpumpValues[69], 117 | Timer_EinschVerz: heatpumpValues[70], 118 | Time_SSPAUS_akt: heatpumpValues[71], 119 | Time_SSPEIN_akt: heatpumpValues[72], 120 | Time_VDStd_akt: heatpumpValues[73], 121 | Time_HRM_akt: heatpumpValues[74], 122 | Time_HRW_akt: heatpumpValues[75], 123 | Time_LGS_akt: heatpumpValues[76], 124 | Time_SBW_akt: heatpumpValues[77], 125 | 126 | typeHeatpump: utils.createHeatPumptTypeString(heatpumpValues[78]), // #31 127 | bivalentLevel: heatpumpValues[79], // #43 128 | 129 | WP_BZ_akt: heatpumpValues[80], 130 | 131 | firmware: utils.createFirmwareString(heatpumpValues.slice(81, 91)), // #20 132 | 133 | AdresseIP_akt: utils.int2ipAddress(heatpumpValues[91]), 134 | SubNetMask_akt: utils.int2ipAddress(heatpumpValues[92]), 135 | Add_Broadcast: utils.int2ipAddress(heatpumpValues[93]), 136 | Add_StdGateway: utils.int2ipAddress(heatpumpValues[94]), 137 | 138 | errors: utils.createErrorCodeList(heatpumpValues.slice(95, 100), heatpumpValues.slice(100, 105)), // #42 Time of first error 139 | 140 | error_count: heatpumpValues[105], 141 | 142 | switch_off: utils.createOutageCodeList(heatpumpValues.slice(111, 116), heatpumpValues.slice(106, 111)), 143 | 144 | Comfort_exists: heatpumpValues[116], 145 | 146 | heatpump_state1: heatpumpValues[117], 147 | heatpump_state2: heatpumpValues[118], // #40 148 | heatpump_state3: heatpumpValues[119], 149 | heatpump_duration: heatpumpValues[120], // #41 150 | heatpump_state_string: utils.createStateString(heatpumpValues), 151 | heatpump_extendet_state_string: utils.createExtendedStateString(heatpumpValues), 152 | 153 | ahp_Stufe: heatpumpValues[121], 154 | ahp_Temp: heatpumpValues[122], 155 | ahp_Zeit: heatpumpValues[123], 156 | 157 | opStateHotWater: heatpumpValues[124], // #8 158 | opStateHotWaterString: utils.createHotWaterStateString(heatpumpValues), 159 | opStateHeating: heatpumpValues[125], // #46 160 | opStateMixer1: heatpumpValues[126], 161 | opStateMixer2: heatpumpValues[127], 162 | Einst_Kurzprogramm: heatpumpValues[128], 163 | StatusSlave_1: heatpumpValues[129], 164 | StatusSlave_2: heatpumpValues[130], 165 | StatusSlave_3: heatpumpValues[131], 166 | StatusSlave_4: heatpumpValues[132], 167 | StatusSlave_5: heatpumpValues[133], 168 | 169 | rawDeviceTimeCalc: new Date(heatpumpValues[134] * 1000).toString(), // #22 170 | 171 | opStateMixer3: heatpumpValues[135], 172 | temperature_mixer3_target: heatpumpVisibility[211] === 1 ? heatpumpValues[136] / 10 : 'no', // #60 173 | temperature_mixer3_flow: heatpumpVisibility[210] === 1 ? heatpumpValues[137] / 10 : 'no', // #59 174 | 175 | MZ3out: heatpumpValues[138], 176 | MA3out: heatpumpValues[139], 177 | FP3out: heatpumpValues[140], 178 | 179 | heatSourceDefrostTimer: heatpumpVisibility[219] === 1 ? heatpumpValues[141] : 'no', // #66 180 | 181 | Temperatur_RFV2: heatpumpValues[142] / 10, 182 | Temperatur_RFV3: heatpumpValues[143] / 10, 183 | SH_SW: heatpumpValues[144], 184 | Zaehler_BetrZeitSW: Math.round(heatpumpValues[145] / 3600), 185 | FreigabKuehl: heatpumpValues[146], 186 | AnalogIn: heatpumpValues[147], 187 | SonderZeichen: heatpumpValues[148], 188 | SH_ZIP: heatpumpValues[149], 189 | WebsrvProgrammWerteBeobarten: heatpumpValues[150], 190 | 191 | thermalenergy_heating: heatpumpVisibility[0] === 1 ? heatpumpValues[151] / 10 : 'no', // #36 192 | thermalenergy_warmwater: heatpumpVisibility[1] === 1 ? heatpumpValues[152] / 10 : 'no', // #37 193 | thermalenergy_pool: heatpumpVisibility[2] === 1 ? heatpumpValues[153] / 10 : 'no', // #62 194 | thermalenergy_total: heatpumpValues[154] / 10, 195 | 196 | analogOut1: heatpumpValues[156], 197 | analogOut2: heatpumpValues[157], 198 | Time_Heissgas: heatpumpValues[158], 199 | Temp_Lueftung_Zuluft: heatpumpValues[159] / 10, 200 | Temp_Lueftung_Abluft: heatpumpValues[160] / 10, 201 | 202 | hours_solar: heatpumpVisibility[248] === 1 ? Math.round(heatpumpValues[161] / 3600) : 'no', // #52 203 | analogOut3: heatpumpValues[162], 204 | analogOut4: heatpumpVisibility[267] === 1 ? heatpumpValues[163] : 'no', // #73 - Voltage heating system circulation pump 205 | 206 | Out_VZU: heatpumpValues[164], 207 | Out_VAB: heatpumpValues[165], 208 | Out_VSK: heatpumpValues[166], 209 | Out_FRH: heatpumpValues[167], 210 | AnalogIn2: heatpumpValues[168], 211 | AnalogIn3: heatpumpValues[169], 212 | SAXin: heatpumpValues[170], 213 | SPLin: heatpumpValues[171], 214 | Compact_exists: heatpumpValues[172], 215 | Durchfluss_WQ: heatpumpValues[173], 216 | LIN_exists: heatpumpValues[174], 217 | LIN_TUE: heatpumpValues[175], 218 | LIN_TUE1: heatpumpValues[176], 219 | LIN_VDH: heatpumpValues[177], 220 | LIN_UH: heatpumpValues[178], 221 | LIN_UH_Soll: heatpumpValues[179], 222 | LIN_HD: heatpumpValues[180], 223 | LIN_ND: heatpumpValues[181], 224 | LIN_VDH_out: heatpumpValues[182], 225 | }; 226 | } 227 | 228 | function processParameters(heatpumpParameters, heatpumpVisibility) { 229 | let additionalParameters = {}; 230 | if (this.options && typeof this.options.onProcessParameters === 'function') { 231 | additionalParameters = this.options.onProcessParameters(heatpumpParameters, heatpumpVisibility); 232 | } 233 | 234 | return { 235 | ...additionalParameters, 236 | heating_temperature: heatpumpParameters[1] / 10, // #54 - returnTemperatureSetBack 237 | warmwater_temperature: heatpumpParameters[2] / 10, 238 | heating_operation_mode: heatpumpParameters[3], // #10 239 | warmwater_operation_mode: heatpumpParameters[4], // #7 240 | 241 | heating_operation_mode_string: utils.createOperationStateString(heatpumpParameters[3]), 242 | warmwater_operation_mode_string: utils.createOperationStateString(heatpumpParameters[4]), 243 | 244 | heating_curve_end_point: heatpumpVisibility[207] === 1 ? heatpumpParameters[11] / 10 : 'no', // #69 245 | heating_curve_parallel_offset: heatpumpVisibility[207] === 1 ? heatpumpParameters[12] / 10 : 'no', // #70 246 | deltaHeatingReduction: heatpumpParameters[13] / 10, // #47 247 | 248 | mk1_curve_end_point: heatpumpVisibility[207] === 1 ? heatpumpParameters[14] / 10 : 'no', // #69 249 | mk1_curve_parallel_offset: heatpumpVisibility[207] === 1 ? heatpumpParameters[15] / 10 : 'no', // #70 250 | deltaMk1Reduction: heatpumpParameters[16] / 10, // #47 251 | 252 | heatSourcedefrostAirThreshold: heatpumpVisibility[97] === 1 ? heatpumpParameters[44] / 10 : 'no', // #71 253 | 254 | hotWaterTemperatureHysteresis: heatpumpParameters[74] / 10, // #49 255 | 256 | returnTemperatureHysteresis: heatpumpVisibility[93] === 1 ? heatpumpParameters[88] / 10 : 'no', // #68 257 | 258 | // Freig. 2.VD: Einstellung der minimalen Außentemperatur, von der ab der 2. Verdichter bedarfsgerecht freigegeben werden kann. Oberhalb der eingestellten Außentemperatur bleibt der 2. Verdichter gesperrt. 259 | heatingTemperatureOutside2ndCompressor: heatpumpParameters[95] / 10, 260 | // Vorl 2.VD WW: Vorlauf 2. Verdichter Trinkwarmwasser Einstellung der Vorlauftemperatur, von der ab mit dem zweiten Verdichter Trinkwarmwasser bereitet wird zur Optimierung der Ladezeit und der erreichbaren Trinkwarmwassertemperaturen. 261 | hotwaterTemperatureForerun2ndCompressor: heatpumpParameters[96] / 10, 262 | 263 | heatSourcedefrostAirEnd: heatpumpVisibility[105] === 1 ? heatpumpParameters[98] / 10 : 'no', // #72 264 | 265 | temperature_hot_water_target: heatpumpParameters[105] / 10, 266 | 267 | cooling_operation_mode: heatpumpParameters[108], 268 | 269 | cooling_release_temperature: heatpumpParameters[110] / 10, 270 | thresholdTemperatureSetBack: heatpumpParameters[111] / 10, // #48 271 | 272 | cooling_inlet_temp: heatpumpParameters[132] / 10, 273 | 274 | hotWaterCircPumpDeaerate: heatpumpVisibility[167] === 1 ? heatpumpParameters[684] : 'no', // #61 275 | 276 | solarPumpDeaerate: heatpumpVisibility[167] === 1 ? heatpumpParameters[688] : 'no', 277 | 278 | runDeaerate: heatpumpVisibility[167] === 1 ? heatpumpParameters[158] : 'no', 279 | 280 | heatingLimit: heatpumpParameters[699], // #11 281 | thresholdHeatingLimit: heatpumpParameters[700] / 10, // #21 282 | 283 | cooling_start_after_hours: heatpumpParameters[850], 284 | cooling_stop_after_hours: heatpumpParameters[851], 285 | 286 | typeSerial: 287 | heatpumpParameters[874].toString().substr(0, 4) + 288 | '/' + 289 | heatpumpParameters[874].toString().substr(4) + 290 | '-' + 291 | heatpumpParameters[875].toString(16).toUpperCase(), 292 | 293 | returnTemperatureTargetMin: heatpumpParameters[979] / 10, // #63 294 | 295 | temperature_supply_limit: heatpumpParameters[149] / 10, // unit °C 296 | temperature_return_limit: heatpumpParameters[87] / 10, // unit °C 297 | temperature_outdoor_max: heatpumpParameters[91] / 10, // unit °C 298 | temperature_outdoor_min: heatpumpParameters[92] / 10, // unit °C 299 | temperature_ZWE_possible: heatpumpParameters[90] / 10, // unit °C 300 | 301 | temperature_hot_water_limit: heatpumpParameters[47] / 10, 302 | //'possible_temperature_hot_water_limit2': heatpumpParameters[84] / 10, 303 | //'possible_temperature_hot_water_limit3': heatpumpParameters[973] / 10, 304 | 305 | heating_system_circ_pump_voltage_nominal: heatpumpParameters[867] / 100, 306 | heating_system_circ_pump_voltage_minimal: heatpumpParameters[868] / 100, 307 | 308 | // ---- Timer table configurations ---- 309 | 310 | // Activated timer table for heating operation. 311 | // Possible values: 0=week (monday-sunday), 1=5+2 (monday-friday), 2=days (mo, tue, ...) 312 | heatingOperationTimerTableSelected: heatpumpParameters[222], 313 | heatingOperationTimerTableSelectedString: utils.createTimerTableTypeString(heatpumpParameters[222]), // string representation 314 | // heating operation table 0: week 315 | heatingOperationTimerTableWeek: utils.createTimerTable(heatpumpParameters, 223, 3), // 223..528 316 | // heating operation table 1: 5+2 317 | heatingOperationTimerTable52MonFri: utils.createTimerTable(heatpumpParameters, 229, 3), // 229..234 318 | heatingOperationTimerTable52SatSun: utils.createTimerTable(heatpumpParameters, 235, 3), // 235..240 319 | // heating operation table 2: day 320 | heatingOperationTimerTableDaySunday: utils.createTimerTable(heatpumpParameters, 241, 3), // 241..246 321 | heatingOperationTimerTableDayMonday: utils.createTimerTable(heatpumpParameters, 247, 3), // 247..252 322 | heatingOperationTimerTableDayTuesday: utils.createTimerTable(heatpumpParameters, 253, 3), // 253..258 323 | heatingOperationTimerTableDayWednesday: utils.createTimerTable(heatpumpParameters, 259, 3), // 259..264 324 | heatingOperationTimerTableDayThursday: utils.createTimerTable(heatpumpParameters, 265, 3), // 265..270 325 | heatingOperationTimerTableDayFriday: utils.createTimerTable(heatpumpParameters, 271, 3), // 271..276 326 | heatingOperationTimerTableDaySaturday: utils.createTimerTable(heatpumpParameters, 277, 3), // 277..282 327 | 328 | // Activated timer table for hot water operation. 329 | // Possible values: 0=week (monday-sunday), 1=5+2 (monday-friday), 2=days (mo, tue, ...) 330 | hotWaterOperationTimerTableSelected: heatpumpParameters[405], 331 | hotWaterOperationTimerTableSelectedString: utils.createTimerTableTypeString(heatpumpParameters[405]), // string representation 332 | 333 | // Important: hot water operation table specifies operation in inverse logic. Therefore swap the on/off times. 334 | // hot water operation table 0: week. 335 | hotWaterOperationTimerTableWeek: utils.createTimerTable(heatpumpParameters, 406, 5, true), // 406..415 336 | // hot water operation table 1: 5+2 337 | hotWaterOperationTimerTable52MonFri: utils.createTimerTable(heatpumpParameters, 416, 5, true), // 416..425 338 | hotWaterOperationTimerTable52SatSun: utils.createTimerTable(heatpumpParameters, 426, 5, true), // 426..435 339 | // hot water operation table 2: day 340 | hotWaterOperationTimerTableDaySunday: utils.createTimerTable(heatpumpParameters, 436, 5, true), // 436..445 341 | hotWaterOperationTimerTableDayMonday: utils.createTimerTable(heatpumpParameters, 446, 5, true), // 446..455 342 | hotWaterOperationTimerTableDayTuesday: utils.createTimerTable(heatpumpParameters, 456, 5, true), // 456..465 343 | hotWaterOperationTimerTableDayWednesday: utils.createTimerTable(heatpumpParameters, 466, 5, true), // 466..475 344 | hotWaterOperationTimerTableDayThursday: utils.createTimerTable(heatpumpParameters, 476, 5, true), // 476..485 345 | hotWaterOperationTimerTableDayFriday: utils.createTimerTable(heatpumpParameters, 486, 5, true), // 486..495 346 | hotWaterOperationTimerTableDaySaturday: utils.createTimerTable(heatpumpParameters, 496, 5, true), // 496..505 347 | 348 | // Activated timer table for hot water circulation pump. 349 | // Possible values: 0=week (monday-sunday), 1=5+2 (monday-friday), 2=days (mo, tue, ...) 350 | hotWaterCircPumpTimerTableSelected: heatpumpParameters[506], 351 | hotWaterCircPumpTimerTableSelectedString: utils.createTimerTableTypeString(heatpumpParameters[506]), // string representation 352 | // hot water circulation pump table 0: week 353 | hotWaterCircPumpTimerTableWeek: utils.createTimerTable(heatpumpParameters, 507, 5), // 507..516 354 | // hot water circulation pump table 1: 5+2 355 | hotWaterCircPumpTimerTable52MonFri: utils.createTimerTable(heatpumpParameters, 517, 5), // 517..526 356 | hotWaterCircPumpTimerTable52SatSun: utils.createTimerTable(heatpumpParameters, 527, 5), // 527..536 357 | // hot water circulation pump table 2: day 358 | hotWaterCircPumpTimerTableDaySunday: utils.createTimerTable(heatpumpParameters, 537, 5), // 537..546 359 | hotWaterCircPumpTimerTableDayMonday: utils.createTimerTable(heatpumpParameters, 547, 5), // 547..556 360 | hotWaterCircPumpTimerTableDayTuesday: utils.createTimerTable(heatpumpParameters, 557, 5), // 557..566 361 | hotWaterCircPumpTimerTableDayWednesday: utils.createTimerTable(heatpumpParameters, 567, 5), // 567..576 362 | hotWaterCircPumpTimerTableDayThursday: utils.createTimerTable(heatpumpParameters, 577, 5), // 577..586 363 | hotWaterCircPumpTimerTableDayFriday: utils.createTimerTable(heatpumpParameters, 587, 5), // 587..596 364 | hotWaterCircPumpTimerTableDaySaturday: utils.createTimerTable(heatpumpParameters, 597, 5), // 597..606 365 | 366 | hotWaterCircPumpOnTime: heatpumpParameters[697], // Time in minutes the circ pump is turned on within one cycle. 367 | hotWaterCircPumpOffTime: heatpumpParameters[698], // Time in minutes the circ pump is turned off within one cycle. 368 | 369 | // thermal desinfection 370 | thermal_desinfection_on_monday: heatpumpParameters[20], 371 | thermal_desinfection_on_tuesday: heatpumpParameters[21], 372 | thermal_desinfection_on_wednesday: heatpumpParameters[22], 373 | thermal_desinfection_on_thursday: heatpumpParameters[23], 374 | thermal_desinfection_on_friday: heatpumpParameters[24], 375 | thermal_desinfection_on_saturday: heatpumpParameters[25], 376 | thermal_desinfection_on_sunday: heatpumpParameters[26], 377 | thermal_desinfection_continuous_operation: heatpumpParameters[27], 378 | }; 379 | } 380 | 381 | Luxtronik.prototype._processData = function () { 382 | // break if one of the data packages is missing or has no payload 383 | const requiredDataFields = ['3003', '3004', '3005']; 384 | for (const element of requiredDataFields) { 385 | if (!Object.prototype.hasOwnProperty.call(this.receivy, element)) { 386 | return this.receivy.callback(new Error('Missing element at luxtronik response to ' + element)); 387 | } 388 | if (!Object.prototype.hasOwnProperty.call(this.receivy[element], 'payload')) { 389 | return this.receivy.callback(new Error('Missing payload for element at luxtronik response to ' + element)); 390 | } 391 | } 392 | 393 | const heatpumpParameters = utils.toInt32ArrayReadBE(this.receivy['3003'].payload); 394 | const heatpumpValues = utils.toInt32ArrayReadBE(this.receivy['3004'].payload); 395 | const heatpumpVisibility = this.receivy['3005'].payload; 396 | 397 | if (typeof heatpumpParameters === 'undefined' || typeof heatpumpValues === 'undefined' || typeof heatpumpVisibility === 'undefined') { 398 | return this.receivy.callback(new Error('Unexpected Data')); 399 | } 400 | if (this.receivy.rawdata) { 401 | return this.receivy.callback(null, { 402 | values: '[' + heatpumpValues + ']', 403 | parameters: '[' + heatpumpParameters + ']', 404 | }); 405 | } 406 | 407 | const values = processValues.call(this, heatpumpValues, heatpumpVisibility); 408 | const parameters = processParameters.call(this, heatpumpParameters, heatpumpVisibility); 409 | const additional = { 410 | reading_calculated_time_ms: this.receivy.readingEndTime - this.receivy.readingStartTime, 411 | }; 412 | 413 | // flow rate 414 | values.flowRate = heatpumpParameters[870] !== 0 ? heatpumpValues[155] : 'no'; // #19 415 | 416 | // skips inconsistent flow rates (known problem of the used flow measurement devices) 417 | if (values.flowRate !== 'no' && values.heatingSystemCircPump === 'on') { 418 | if (values.flowRate === 0) { 419 | values.flowRate = 'inconsistent'; 420 | } 421 | } 422 | 423 | if (parameters.hotWaterCircPumpDeaerate !== 'no') { 424 | parameters.hotWaterCircPumpDeaerate = parameters.hotWaterCircPumpDeaerate ? 'on' : 'off'; 425 | } 426 | 427 | if (parameters.solarPumpDeaerate !== 'no') { 428 | parameters.solarPumpDeaerate = parameters.solarPumpDeaerate ? 'on' : 'off'; 429 | } 430 | 431 | if (parameters.runDeaerate !== 'no') { 432 | parameters.runDeaerate = parameters.runDeaerate ? 'on' : 'off'; 433 | } 434 | 435 | // Consider also heating limit 436 | let heatingStateString = ''; 437 | if ( 438 | parameters.heating_operation_mode === 0 && 439 | parameters.heatingLimit === 1 && 440 | values.temperature_outside_avg >= parameters.thresholdHeatingLimit && 441 | (values.temperature_target_return === parameters.returnTemperatureTargetMin || 442 | (values.temperature_target_return === 20 && values.temperature_outside < 10)) 443 | ) { 444 | if (values.temperature_outside >= 10) { 445 | heatingStateString = 'Heizgrenze (Soll ' + parameters.returnTemperatureTargetMin + ' °C)'; 446 | } else { 447 | heatingStateString = 'Frostschutz (Soll 20 °C)'; 448 | } 449 | } else { 450 | if (Object.prototype.hasOwnProperty.call(types.heatingState, values.opStateHeating)) { 451 | heatingStateString = types.heatingState[values.opStateHeating]; 452 | } else { 453 | heatingStateString = 'unbekannt (' + values.opStateHeating + ')'; 454 | } 455 | 456 | // Consider heating reduction limit 457 | if (values.opStateHeating === 0) { 458 | if (parameters.thresholdTemperatureSetBack <= values.temperature_outside) { 459 | heatingStateString += ' ' + parameters.deltaHeatingReduction + ' °C'; 460 | } else { 461 | heatingStateString = 'Normal da < ' + parameters.thresholdTemperatureSetBack + ' °C'; 462 | } 463 | } 464 | } 465 | values.opStateHeatingString = heatingStateString; 466 | 467 | return this.receivy.callback(null, { 468 | values, 469 | parameters, 470 | additional, 471 | }); 472 | }; 473 | 474 | function sendData(client, data) { 475 | if (typeof client !== 'undefined' && client !== null) { 476 | data.forEach(function (element) { 477 | const buffer = Buffer.allocUnsafe(4); 478 | buffer.writeInt32BE(element); 479 | client.write(buffer); 480 | }); 481 | } 482 | } 483 | 484 | Luxtronik.prototype._nextJob = function () { 485 | if (this.receivy.jobs.length > 0) { 486 | this.receivy.activeCommand = 0; 487 | this.dataBuffer = undefined; 488 | sendData(this.client, [this.receivy.jobs.shift(), 0]); 489 | } else { 490 | if (this.client) this.client.end(); 491 | this.client = null; 492 | this.receivy.readingEndTime = Date.now(); 493 | process.nextTick(this._processData.bind(this)); 494 | } 495 | }; 496 | 497 | Luxtronik.prototype._startRead = function (rawdata, callback) { 498 | this.receivy = { 499 | jobs: [3003, 3004, 3005], 500 | activeCommand: 0, 501 | readingStartTime: Date.now(), 502 | rawdata, 503 | callback, 504 | }; 505 | 506 | this.client = net.createConnection( 507 | { 508 | host: this._host, 509 | port: this._port, 510 | }, 511 | function () { 512 | process.nextTick(this._nextJob.bind(this)); 513 | }.bind(this), 514 | ); 515 | 516 | this.client.on( 517 | 'error', 518 | function (error) { 519 | if (this.client) this.client.end(); 520 | this.client = null; 521 | process.nextTick( 522 | function () { 523 | this.receivy.callback(error); 524 | }.bind(this), 525 | ); 526 | }.bind(this), 527 | ); 528 | 529 | this.client.on( 530 | 'data', 531 | function (data) { 532 | if (this.dataBuffer === undefined) { 533 | this.dataBuffer = data; 534 | } else if (this.dataBuffer.length === 4) { 535 | this.dataBuffer = Buffer.concat([this.dataBuffer, data]); 536 | } 537 | 538 | if (data.length > 4 || this.receivy.activeCommand !== 0) { 539 | if (this.receivy.activeCommand === 0) { 540 | data = this.dataBuffer; 541 | const commandEcho = data.readInt32BE(0); 542 | let firstReadableDataAddress = 0; 543 | 544 | if (commandEcho === 3004) { 545 | const status = data.readInt32BE(4); 546 | if (status > 0) { 547 | // Parameter on target changed, restart parameter reading after 5 seconds 548 | if (this.client) this.client.end(); 549 | this.client = null; 550 | return process.nextTick( 551 | function () { 552 | this.receivy.callback(new Error('heatpump busy - state: ' + status)); 553 | }.bind(this), 554 | ); 555 | } else { 556 | firstReadableDataAddress = 12; 557 | } 558 | } else { 559 | firstReadableDataAddress = 8; 560 | } 561 | 562 | // Do not proceed if the field for paramCount is missing 563 | if (data.length < firstReadableDataAddress) { 564 | if (this.client) this.client.end(); 565 | this.client = null; 566 | return process.nextTick( 567 | function () { 568 | this.receivy.callback(new Error('parameter count missing')); 569 | }.bind(this), 570 | ); 571 | } 572 | const paramCount = data.readInt32BE(firstReadableDataAddress - 4); 573 | let dataCount = 0; 574 | if (commandEcho === 3005) { 575 | // 8 Bit values 576 | dataCount = paramCount; 577 | } else { 578 | // 32 Bit values 579 | dataCount = paramCount * 4; 580 | } 581 | const payload = data.slice(firstReadableDataAddress, data.length); 582 | 583 | this.receivy.activeCommand = commandEcho; 584 | this.receivy[commandEcho] = { 585 | remaining: dataCount - payload.length, 586 | payload, 587 | }; 588 | } else { 589 | this.receivy[this.receivy.activeCommand] = { 590 | remaining: this.receivy[this.receivy.activeCommand].remaining - data.length, 591 | payload: Buffer.concat([this.receivy[this.receivy.activeCommand].payload, data]), 592 | }; 593 | } 594 | 595 | if (this.receivy[this.receivy.activeCommand].remaining <= 0) { 596 | process.nextTick(this._nextJob.bind(this)); 597 | } 598 | } 599 | }.bind(this), 600 | ); 601 | 602 | this.client.on('close', function () {}); 603 | }; 604 | 605 | Luxtronik.prototype._startWrite = function (setParameter, setValue, callback) { 606 | this.writeClient = net.createConnection( 607 | { 608 | host: this._host, 609 | port: this._port, 610 | }, 611 | function () { 612 | const command = 3002; 613 | this.writeResponseBuffer = null; 614 | sendData(this.writeClient, [command, setParameter, setValue]); 615 | }.bind(this), 616 | ); 617 | 618 | this.writeClient.on( 619 | 'error', 620 | function (error) { 621 | process.nextTick(function () { 622 | callback(error); 623 | }); 624 | if (this.writeClient) this.writeClient.end(); 625 | this.writeClient = null; 626 | }.bind(this), 627 | ); 628 | 629 | this.writeClient.on( 630 | 'data', 631 | function (data) { 632 | if (this.writeResponseBuffer === null) { 633 | this.writeResponseBuffer = data; 634 | } else { 635 | this.writeResponseBuffer = Buffer.concat([this.writeResponseBuffer, data]); 636 | } 637 | if (this.writeResponseBuffer.length < 8) { 638 | return; 639 | } 640 | data = this.writeResponseBuffer; 641 | const commandEcho = data.readInt32BE(0); 642 | let next; 643 | if (commandEcho !== 3002) { 644 | const error = 'Host did not confirm parameter setting'; 645 | next = function () { 646 | callback(error); 647 | }; 648 | } else { 649 | const setParameterEcho = data.readInt32BE(4); 650 | next = function () { 651 | callback(null, { 652 | msg: 'write ok', 653 | echo: setParameterEcho, 654 | }); 655 | }; 656 | } 657 | process.nextTick(next); 658 | if (this.writeClient) this.writeClient.end(); 659 | this.writeClient = null; 660 | }.bind(this), 661 | ); 662 | }; 663 | 664 | Luxtronik.prototype._handleWriteCommand = function (parameterName, realValue, callback) { 665 | const writeParameters = Object.freeze({ 666 | heating_target_temperature: { 667 | setParameter: 1, 668 | setValue: utils.value2LuxtronikSetTemperatureValue(utils.limitRange(realValue, -10, 10)), 669 | }, 670 | warmwater_target_temperature: { 671 | setParameter: 2, 672 | setValue: utils.value2LuxtronikSetTemperatureValue(utils.limitRange(realValue, 30, 65)), 673 | }, 674 | heating_operation_mode: { 675 | setParameter: utils.isValidOperationMode(realValue) ? 3 : undefined, 676 | setValue: realValue, 677 | }, 678 | warmwater_operation_mode: { 679 | setParameter: utils.isValidOperationMode(realValue) ? 4 : undefined, 680 | setValue: realValue, 681 | }, 682 | heating_curve_end_point: { 683 | setParameter: 11, 684 | setValue: utils.value2LuxtronikSetTemperatureValue(utils.limitRange(realValue, 20, 70)), 685 | }, 686 | heating_curve_parallel_offset: { 687 | setParameter: 12, 688 | setValue: utils.value2LuxtronikSetTemperatureValue(utils.limitRange(realValue, 5, 35)), 689 | }, 690 | deltaHeatingReduction: { 691 | setParameter: 13, 692 | setValue: utils.value2LuxtronikSetTemperatureValue(utils.limitRange(realValue, -15, 10)), 693 | }, 694 | mk1_curve_end_point: { 695 | setParameter: 14, 696 | setValue: utils.value2LuxtronikSetTemperatureValue(utils.limitRange(realValue, 20, 70)), 697 | }, 698 | mk1_curve_parallel_offset: { 699 | setParameter: 15, 700 | setValue: utils.value2LuxtronikSetTemperatureValue(utils.limitRange(realValue, 5, 35)), 701 | }, 702 | deltaMk1Reduction: { 703 | setParameter: 16, 704 | setValue: utils.value2LuxtronikSetTemperatureValue(utils.limitRange(realValue, -15, 10)), 705 | }, 706 | hotwater_temperature_hysteresis: { 707 | setParameter: 74, 708 | setValue: utils.value2LuxtronikSetTemperatureValue(realValue), 709 | }, 710 | return_temperature_hysteresis: { 711 | setParameter: 88, 712 | setValue: utils.value2LuxtronikSetTemperatureValue(realValue), 713 | }, 714 | heating_temperature_outside_2nd_compressor: { 715 | setParameter: 95, 716 | setValue: utils.value2LuxtronikSetTemperatureValue(utils.limitRange(realValue, -20, 30)), 717 | }, 718 | hotwater_temperature_forerun_2nd_compressor: { 719 | setParameter: 96, 720 | setValue: utils.value2LuxtronikSetTemperatureValue(utils.limitRange(realValue, 10, 70)), 721 | }, 722 | temperature_hot_water_target: { 723 | setParameter: 105, 724 | setValue: utils.value2LuxtronikSetTemperatureValue(realValue), 725 | }, 726 | cooling_operation_mode: { 727 | setParameter: 108, 728 | setValue: realValue, 729 | }, 730 | cooling_release_temp: { 731 | setParameter: 110, 732 | setValue: utils.value2LuxtronikSetTemperatureValue(realValue), 733 | }, 734 | cooling_inlet_temp: { 735 | setParameter: 132, 736 | setValue: utils.value2LuxtronikSetTemperatureValue(realValue), 737 | }, 738 | runDeaerate: { 739 | setParameter: 158, 740 | setValue: realValue, 741 | }, 742 | hotWaterCircPumpDeaerate: { 743 | setParameter: 684, 744 | setValue: realValue, 745 | }, 746 | solarPumpDeaerate: { 747 | setParameter: 688, 748 | setValue: realValue, 749 | }, 750 | cooling_start: { 751 | setParameter: 850, 752 | setValue: realValue, 753 | }, 754 | cooling_stop: { 755 | setParameter: 851, 756 | setValue: realValue, 757 | }, 758 | heating_system_circ_pump_voltage_nominal: { 759 | setParameter: 867, 760 | setValue: utils.value2LuxtronikSetHundrethValue(realValue), 761 | }, 762 | heating_system_circ_pump_voltage_minimal: { 763 | setParameter: 868, 764 | setValue: utils.value2LuxtronikSetHundrethValue(realValue), 765 | }, 766 | wrongName: { 767 | //setParameter: undefined, 768 | }, 769 | }); 770 | 771 | const set = Object.prototype.hasOwnProperty.call(writeParameters, parameterName) ? writeParameters[parameterName] : writeParameters.wrongName; 772 | 773 | if (typeof set.setParameter !== 'undefined') { 774 | const setParameter = set.setParameter; 775 | const setValue = set.setValue; 776 | this._startWrite(setParameter, setValue, callback); 777 | } else { 778 | const error = 'Wrong data'; 779 | process.nextTick(function () { 780 | callback(error); 781 | }); 782 | } 783 | }; 784 | 785 | Luxtronik.prototype.read = function (rawdata, callback) { 786 | if (rawdata instanceof Function) { 787 | callback = rawdata; 788 | rawdata = false; 789 | } 790 | this._startRead(rawdata, callback); 791 | }; 792 | 793 | Luxtronik.prototype.readRaw = function (callback) { 794 | this._startRead(true, callback); 795 | }; 796 | 797 | Luxtronik.prototype.write = function (parameterName, realValue, callback) { 798 | if (typeof callback === 'undefined') { 799 | callback = function () {}; 800 | } 801 | this._handleWriteCommand(parameterName, realValue, callback); 802 | }; 803 | 804 | Luxtronik.prototype.writeRaw = function (parameterNumber, rawValue, callback) { 805 | if (typeof callback === 'undefined') { 806 | callback = function () {}; 807 | } 808 | 809 | if (typeof parameterNumber === 'number' && typeof rawValue === 'number') { 810 | this._startWrite(parameterNumber, rawValue, callback); 811 | } else { 812 | return callback(new Error('RAW write operation requires parameter and value as number!')); 813 | } 814 | }; 815 | 816 | const createConnection = function (host, port, options) { 817 | return new Luxtronik(host, port, options); 818 | }; 819 | 820 | module.exports.createConnection = createConnection; 821 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "luxtronik2", 3 | "version": "2.7.2", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "luxtronik2", 9 | "version": "2.7.2", 10 | "license": "MIT", 11 | "dependencies": { 12 | "humanize-duration": "^3.31.0", 13 | "net": "^1.0.2" 14 | }, 15 | "devDependencies": { 16 | "assertthat": "^6.5.2", 17 | "eslint": "^8.57.0", 18 | "eslint-config-standard": "^17.1.0", 19 | "eslint-plugin-import": "^2.29.1", 20 | "eslint-plugin-node": "^11.1.0", 21 | "eslint-plugin-promise": "^6.1.1", 22 | "mitm": "^1.7.2", 23 | "mocha": "^10.3.0" 24 | } 25 | }, 26 | "node_modules/@aashutoshrathi/word-wrap": { 27 | "version": "1.2.6", 28 | "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", 29 | "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", 30 | "dev": true, 31 | "engines": { 32 | "node": ">=0.10.0" 33 | } 34 | }, 35 | "node_modules/@eslint-community/eslint-utils": { 36 | "version": "4.4.0", 37 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", 38 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", 39 | "dev": true, 40 | "dependencies": { 41 | "eslint-visitor-keys": "^3.3.0" 42 | }, 43 | "engines": { 44 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 45 | }, 46 | "peerDependencies": { 47 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" 48 | } 49 | }, 50 | "node_modules/@eslint-community/regexpp": { 51 | "version": "4.10.0", 52 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.10.0.tgz", 53 | "integrity": "sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA==", 54 | "dev": true, 55 | "engines": { 56 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0" 57 | } 58 | }, 59 | "node_modules/@eslint/eslintrc": { 60 | "version": "2.1.4", 61 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", 62 | "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", 63 | "dev": true, 64 | "dependencies": { 65 | "ajv": "^6.12.4", 66 | "debug": "^4.3.2", 67 | "espree": "^9.6.0", 68 | "globals": "^13.19.0", 69 | "ignore": "^5.2.0", 70 | "import-fresh": "^3.2.1", 71 | "js-yaml": "^4.1.0", 72 | "minimatch": "^3.1.2", 73 | "strip-json-comments": "^3.1.1" 74 | }, 75 | "engines": { 76 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 77 | }, 78 | "funding": { 79 | "url": "https://opencollective.com/eslint" 80 | } 81 | }, 82 | "node_modules/@eslint/js": { 83 | "version": "8.57.0", 84 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.57.0.tgz", 85 | "integrity": "sha512-Ys+3g2TaW7gADOJzPt83SJtCDhMjndcDMFVQ/Tj9iA1BfJzFKD9mAUXT3OenpuPHbI6P/myECxRJrofUsDx/5g==", 86 | "dev": true, 87 | "engines": { 88 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 89 | } 90 | }, 91 | "node_modules/@humanwhocodes/config-array": { 92 | "version": "0.11.14", 93 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.14.tgz", 94 | "integrity": "sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==", 95 | "dev": true, 96 | "dependencies": { 97 | "@humanwhocodes/object-schema": "^2.0.2", 98 | "debug": "^4.3.1", 99 | "minimatch": "^3.0.5" 100 | }, 101 | "engines": { 102 | "node": ">=10.10.0" 103 | } 104 | }, 105 | "node_modules/@humanwhocodes/module-importer": { 106 | "version": "1.0.1", 107 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 108 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 109 | "dev": true, 110 | "engines": { 111 | "node": ">=12.22" 112 | }, 113 | "funding": { 114 | "type": "github", 115 | "url": "https://github.com/sponsors/nzakas" 116 | } 117 | }, 118 | "node_modules/@humanwhocodes/object-schema": { 119 | "version": "2.0.2", 120 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.2.tgz", 121 | "integrity": "sha512-6EwiSjwWYP7pTckG6I5eyFANjPhmPjUX9JRLUSfNPC7FX7zK9gyZAfUEaECL6ALTpGX5AjnBq3C9XmVWPitNpw==", 122 | "dev": true 123 | }, 124 | "node_modules/@nodelib/fs.scandir": { 125 | "version": "2.1.5", 126 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 127 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 128 | "dev": true, 129 | "dependencies": { 130 | "@nodelib/fs.stat": "2.0.5", 131 | "run-parallel": "^1.1.9" 132 | }, 133 | "engines": { 134 | "node": ">= 8" 135 | } 136 | }, 137 | "node_modules/@nodelib/fs.stat": { 138 | "version": "2.0.5", 139 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 140 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 141 | "dev": true, 142 | "engines": { 143 | "node": ">= 8" 144 | } 145 | }, 146 | "node_modules/@nodelib/fs.walk": { 147 | "version": "1.2.8", 148 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 149 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 150 | "dev": true, 151 | "dependencies": { 152 | "@nodelib/fs.scandir": "2.1.5", 153 | "fastq": "^1.6.0" 154 | }, 155 | "engines": { 156 | "node": ">= 8" 157 | } 158 | }, 159 | "node_modules/@types/common-tags": { 160 | "version": "1.8.1", 161 | "resolved": "https://registry.npmjs.org/@types/common-tags/-/common-tags-1.8.1.tgz", 162 | "integrity": "sha512-20R/mDpKSPWdJs5TOpz3e7zqbeCNuMCPhV7Yndk9KU2Rbij2r5W4RzwDPkzC+2lzUqXYu9rFzTktCBnDjHuNQg==", 163 | "dev": true 164 | }, 165 | "node_modules/@types/json5": { 166 | "version": "0.0.29", 167 | "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", 168 | "integrity": "sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ==", 169 | "dev": true 170 | }, 171 | "node_modules/@types/uuid": { 172 | "version": "8.3.4", 173 | "resolved": "https://registry.npmjs.org/@types/uuid/-/uuid-8.3.4.tgz", 174 | "integrity": "sha512-c/I8ZRb51j+pYGAu5CrFMRxqZ2ke4y2grEBO5AUjgSkSk+qT2Ea+OdWElz/OiMf5MNpn2b17kuVBwZLQJXzihw==", 175 | "dev": true 176 | }, 177 | "node_modules/@ungap/structured-clone": { 178 | "version": "1.2.0", 179 | "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz", 180 | "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==", 181 | "dev": true 182 | }, 183 | "node_modules/acorn": { 184 | "version": "8.11.3", 185 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", 186 | "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", 187 | "dev": true, 188 | "bin": { 189 | "acorn": "bin/acorn" 190 | }, 191 | "engines": { 192 | "node": ">=0.4.0" 193 | } 194 | }, 195 | "node_modules/acorn-jsx": { 196 | "version": "5.3.2", 197 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 198 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 199 | "dev": true, 200 | "peerDependencies": { 201 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 202 | } 203 | }, 204 | "node_modules/ajv": { 205 | "version": "6.12.6", 206 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 207 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 208 | "dev": true, 209 | "dependencies": { 210 | "fast-deep-equal": "^3.1.1", 211 | "fast-json-stable-stringify": "^2.0.0", 212 | "json-schema-traverse": "^0.4.1", 213 | "uri-js": "^4.2.2" 214 | }, 215 | "funding": { 216 | "type": "github", 217 | "url": "https://github.com/sponsors/epoberezkin" 218 | } 219 | }, 220 | "node_modules/ansi-colors": { 221 | "version": "4.1.1", 222 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 223 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 224 | "dev": true, 225 | "engines": { 226 | "node": ">=6" 227 | } 228 | }, 229 | "node_modules/ansi-regex": { 230 | "version": "5.0.1", 231 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 232 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 233 | "dev": true, 234 | "engines": { 235 | "node": ">=8" 236 | } 237 | }, 238 | "node_modules/ansi-styles": { 239 | "version": "4.3.0", 240 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 241 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 242 | "dev": true, 243 | "dependencies": { 244 | "color-convert": "^2.0.1" 245 | }, 246 | "engines": { 247 | "node": ">=8" 248 | }, 249 | "funding": { 250 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 251 | } 252 | }, 253 | "node_modules/anymatch": { 254 | "version": "3.1.3", 255 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 256 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 257 | "dev": true, 258 | "dependencies": { 259 | "normalize-path": "^3.0.0", 260 | "picomatch": "^2.0.4" 261 | }, 262 | "engines": { 263 | "node": ">= 8" 264 | } 265 | }, 266 | "node_modules/argparse": { 267 | "version": "2.0.1", 268 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 269 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 270 | "dev": true 271 | }, 272 | "node_modules/array-buffer-byte-length": { 273 | "version": "1.0.1", 274 | "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.1.tgz", 275 | "integrity": "sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==", 276 | "dev": true, 277 | "dependencies": { 278 | "call-bind": "^1.0.5", 279 | "is-array-buffer": "^3.0.4" 280 | }, 281 | "engines": { 282 | "node": ">= 0.4" 283 | }, 284 | "funding": { 285 | "url": "https://github.com/sponsors/ljharb" 286 | } 287 | }, 288 | "node_modules/array-includes": { 289 | "version": "3.1.7", 290 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.7.tgz", 291 | "integrity": "sha512-dlcsNBIiWhPkHdOEEKnehA+RNUWDc4UqFtnIXU4uuYDPtA4LDkr7qip2p0VvFAEXNDr0yWZ9PJyIRiGjRLQzwQ==", 292 | "dev": true, 293 | "dependencies": { 294 | "call-bind": "^1.0.2", 295 | "define-properties": "^1.2.0", 296 | "es-abstract": "^1.22.1", 297 | "get-intrinsic": "^1.2.1", 298 | "is-string": "^1.0.7" 299 | }, 300 | "engines": { 301 | "node": ">= 0.4" 302 | }, 303 | "funding": { 304 | "url": "https://github.com/sponsors/ljharb" 305 | } 306 | }, 307 | "node_modules/array.prototype.filter": { 308 | "version": "1.0.3", 309 | "resolved": "https://registry.npmjs.org/array.prototype.filter/-/array.prototype.filter-1.0.3.tgz", 310 | "integrity": "sha512-VizNcj/RGJiUyQBgzwxzE5oHdeuXY5hSbbmKMlphj1cy1Vl7Pn2asCGbSrru6hSQjmCzqTBPVWAF/whmEOVHbw==", 311 | "dev": true, 312 | "dependencies": { 313 | "call-bind": "^1.0.2", 314 | "define-properties": "^1.2.0", 315 | "es-abstract": "^1.22.1", 316 | "es-array-method-boxes-properly": "^1.0.0", 317 | "is-string": "^1.0.7" 318 | }, 319 | "engines": { 320 | "node": ">= 0.4" 321 | }, 322 | "funding": { 323 | "url": "https://github.com/sponsors/ljharb" 324 | } 325 | }, 326 | "node_modules/array.prototype.findlastindex": { 327 | "version": "1.2.4", 328 | "resolved": "https://registry.npmjs.org/array.prototype.findlastindex/-/array.prototype.findlastindex-1.2.4.tgz", 329 | "integrity": "sha512-hzvSHUshSpCflDR1QMUBLHGHP1VIEBegT4pix9H/Z92Xw3ySoy6c2qh7lJWTJnRJ8JCZ9bJNCgTyYaJGcJu6xQ==", 330 | "dev": true, 331 | "dependencies": { 332 | "call-bind": "^1.0.5", 333 | "define-properties": "^1.2.1", 334 | "es-abstract": "^1.22.3", 335 | "es-errors": "^1.3.0", 336 | "es-shim-unscopables": "^1.0.2" 337 | }, 338 | "engines": { 339 | "node": ">= 0.4" 340 | }, 341 | "funding": { 342 | "url": "https://github.com/sponsors/ljharb" 343 | } 344 | }, 345 | "node_modules/array.prototype.flat": { 346 | "version": "1.3.2", 347 | "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.3.2.tgz", 348 | "integrity": "sha512-djYB+Zx2vLewY8RWlNCUdHjDXs2XOgm602S9E7P/UpHgfeHL00cRiIF+IN/G/aUJ7kGPb6yO/ErDI5V2s8iycA==", 349 | "dev": true, 350 | "dependencies": { 351 | "call-bind": "^1.0.2", 352 | "define-properties": "^1.2.0", 353 | "es-abstract": "^1.22.1", 354 | "es-shim-unscopables": "^1.0.0" 355 | }, 356 | "engines": { 357 | "node": ">= 0.4" 358 | }, 359 | "funding": { 360 | "url": "https://github.com/sponsors/ljharb" 361 | } 362 | }, 363 | "node_modules/array.prototype.flatmap": { 364 | "version": "1.3.2", 365 | "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.3.2.tgz", 366 | "integrity": "sha512-Ewyx0c9PmpcsByhSW4r+9zDU7sGjFc86qf/kKtuSCRdhfbk0SNLLkaT5qvcHnRGgc5NP/ly/y+qkXkqONX54CQ==", 367 | "dev": true, 368 | "dependencies": { 369 | "call-bind": "^1.0.2", 370 | "define-properties": "^1.2.0", 371 | "es-abstract": "^1.22.1", 372 | "es-shim-unscopables": "^1.0.0" 373 | }, 374 | "engines": { 375 | "node": ">= 0.4" 376 | }, 377 | "funding": { 378 | "url": "https://github.com/sponsors/ljharb" 379 | } 380 | }, 381 | "node_modules/arraybuffer.prototype.slice": { 382 | "version": "1.0.3", 383 | "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.3.tgz", 384 | "integrity": "sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A==", 385 | "dev": true, 386 | "dependencies": { 387 | "array-buffer-byte-length": "^1.0.1", 388 | "call-bind": "^1.0.5", 389 | "define-properties": "^1.2.1", 390 | "es-abstract": "^1.22.3", 391 | "es-errors": "^1.2.1", 392 | "get-intrinsic": "^1.2.3", 393 | "is-array-buffer": "^3.0.4", 394 | "is-shared-array-buffer": "^1.0.2" 395 | }, 396 | "engines": { 397 | "node": ">= 0.4" 398 | }, 399 | "funding": { 400 | "url": "https://github.com/sponsors/ljharb" 401 | } 402 | }, 403 | "node_modules/assertthat": { 404 | "version": "6.5.2", 405 | "resolved": "https://registry.npmjs.org/assertthat/-/assertthat-6.5.2.tgz", 406 | "integrity": "sha512-iNxRVPzSRNL7PArfYaP7kuJ+wMCKs7Cv2Rb+XVqtCKBMh3l0KD5o3f0lQJ0O3Lv7aD1P1WNmRHOW8S1lTe4DuQ==", 407 | "dev": true, 408 | "dependencies": { 409 | "@types/common-tags": "1.8.1", 410 | "@types/uuid": "8.3.4", 411 | "chalk": "4.1.2", 412 | "common-tags": "1.8.2", 413 | "defekt": "9.1.0", 414 | "typedescriptor": "4.0.13", 415 | "uuid": "8.3.2" 416 | } 417 | }, 418 | "node_modules/available-typed-arrays": { 419 | "version": "1.0.7", 420 | "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz", 421 | "integrity": "sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ==", 422 | "dev": true, 423 | "dependencies": { 424 | "possible-typed-array-names": "^1.0.0" 425 | }, 426 | "engines": { 427 | "node": ">= 0.4" 428 | }, 429 | "funding": { 430 | "url": "https://github.com/sponsors/ljharb" 431 | } 432 | }, 433 | "node_modules/balanced-match": { 434 | "version": "1.0.2", 435 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 436 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 437 | "dev": true 438 | }, 439 | "node_modules/binary-extensions": { 440 | "version": "2.2.0", 441 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 442 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 443 | "dev": true, 444 | "engines": { 445 | "node": ">=8" 446 | } 447 | }, 448 | "node_modules/brace-expansion": { 449 | "version": "1.1.11", 450 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 451 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 452 | "dev": true, 453 | "dependencies": { 454 | "balanced-match": "^1.0.0", 455 | "concat-map": "0.0.1" 456 | } 457 | }, 458 | "node_modules/braces": { 459 | "version": "3.0.2", 460 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 461 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 462 | "dev": true, 463 | "dependencies": { 464 | "fill-range": "^7.0.1" 465 | }, 466 | "engines": { 467 | "node": ">=8" 468 | } 469 | }, 470 | "node_modules/browser-stdout": { 471 | "version": "1.3.1", 472 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 473 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 474 | "dev": true 475 | }, 476 | "node_modules/builtin-modules": { 477 | "version": "3.3.0", 478 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.3.0.tgz", 479 | "integrity": "sha512-zhaCDicdLuWN5UbN5IMnFqNMhNfo919sH85y2/ea+5Yg9TsTkeZxpL+JLbp6cgYFS4sRLp3YV4S6yDuqVWHYOw==", 480 | "dev": true, 481 | "peer": true, 482 | "engines": { 483 | "node": ">=6" 484 | }, 485 | "funding": { 486 | "url": "https://github.com/sponsors/sindresorhus" 487 | } 488 | }, 489 | "node_modules/builtins": { 490 | "version": "5.0.1", 491 | "resolved": "https://registry.npmjs.org/builtins/-/builtins-5.0.1.tgz", 492 | "integrity": "sha512-qwVpFEHNfhYJIzNRBvd2C1kyo6jz3ZSMPyyuR47OPdiKWlbYnZNyDWuyR175qDnAJLiCo5fBBqPb3RiXgWlkOQ==", 493 | "dev": true, 494 | "peer": true, 495 | "dependencies": { 496 | "semver": "^7.0.0" 497 | } 498 | }, 499 | "node_modules/builtins/node_modules/semver": { 500 | "version": "7.6.0", 501 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz", 502 | "integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==", 503 | "dev": true, 504 | "peer": true, 505 | "dependencies": { 506 | "lru-cache": "^6.0.0" 507 | }, 508 | "bin": { 509 | "semver": "bin/semver.js" 510 | }, 511 | "engines": { 512 | "node": ">=10" 513 | } 514 | }, 515 | "node_modules/call-bind": { 516 | "version": "1.0.7", 517 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", 518 | "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", 519 | "dev": true, 520 | "dependencies": { 521 | "es-define-property": "^1.0.0", 522 | "es-errors": "^1.3.0", 523 | "function-bind": "^1.1.2", 524 | "get-intrinsic": "^1.2.4", 525 | "set-function-length": "^1.2.1" 526 | }, 527 | "engines": { 528 | "node": ">= 0.4" 529 | }, 530 | "funding": { 531 | "url": "https://github.com/sponsors/ljharb" 532 | } 533 | }, 534 | "node_modules/callsites": { 535 | "version": "3.1.0", 536 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 537 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 538 | "dev": true, 539 | "engines": { 540 | "node": ">=6" 541 | } 542 | }, 543 | "node_modules/camelcase": { 544 | "version": "6.3.0", 545 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 546 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 547 | "dev": true, 548 | "engines": { 549 | "node": ">=10" 550 | }, 551 | "funding": { 552 | "url": "https://github.com/sponsors/sindresorhus" 553 | } 554 | }, 555 | "node_modules/chalk": { 556 | "version": "4.1.2", 557 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 558 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 559 | "dev": true, 560 | "dependencies": { 561 | "ansi-styles": "^4.1.0", 562 | "supports-color": "^7.1.0" 563 | }, 564 | "engines": { 565 | "node": ">=10" 566 | }, 567 | "funding": { 568 | "url": "https://github.com/chalk/chalk?sponsor=1" 569 | } 570 | }, 571 | "node_modules/chokidar": { 572 | "version": "3.5.3", 573 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 574 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 575 | "dev": true, 576 | "funding": [ 577 | { 578 | "type": "individual", 579 | "url": "https://paulmillr.com/funding/" 580 | } 581 | ], 582 | "dependencies": { 583 | "anymatch": "~3.1.2", 584 | "braces": "~3.0.2", 585 | "glob-parent": "~5.1.2", 586 | "is-binary-path": "~2.1.0", 587 | "is-glob": "~4.0.1", 588 | "normalize-path": "~3.0.0", 589 | "readdirp": "~3.6.0" 590 | }, 591 | "engines": { 592 | "node": ">= 8.10.0" 593 | }, 594 | "optionalDependencies": { 595 | "fsevents": "~2.3.2" 596 | } 597 | }, 598 | "node_modules/chokidar/node_modules/glob-parent": { 599 | "version": "5.1.2", 600 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 601 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 602 | "dev": true, 603 | "dependencies": { 604 | "is-glob": "^4.0.1" 605 | }, 606 | "engines": { 607 | "node": ">= 6" 608 | } 609 | }, 610 | "node_modules/cliui": { 611 | "version": "7.0.4", 612 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 613 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 614 | "dev": true, 615 | "dependencies": { 616 | "string-width": "^4.2.0", 617 | "strip-ansi": "^6.0.0", 618 | "wrap-ansi": "^7.0.0" 619 | } 620 | }, 621 | "node_modules/color-convert": { 622 | "version": "2.0.1", 623 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 624 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 625 | "dev": true, 626 | "dependencies": { 627 | "color-name": "~1.1.4" 628 | }, 629 | "engines": { 630 | "node": ">=7.0.0" 631 | } 632 | }, 633 | "node_modules/color-name": { 634 | "version": "1.1.4", 635 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 636 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 637 | "dev": true 638 | }, 639 | "node_modules/common-tags": { 640 | "version": "1.8.2", 641 | "resolved": "https://registry.npmjs.org/common-tags/-/common-tags-1.8.2.tgz", 642 | "integrity": "sha512-gk/Z852D2Wtb//0I+kRFNKKE9dIIVirjoqPoA1wJU+XePVXZfGeBpk45+A1rKO4Q43prqWBNY/MiIeRLbPWUaA==", 643 | "dev": true, 644 | "engines": { 645 | "node": ">=4.0.0" 646 | } 647 | }, 648 | "node_modules/concat-map": { 649 | "version": "0.0.1", 650 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 651 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 652 | "dev": true 653 | }, 654 | "node_modules/cross-spawn": { 655 | "version": "7.0.3", 656 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 657 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 658 | "dev": true, 659 | "dependencies": { 660 | "path-key": "^3.1.0", 661 | "shebang-command": "^2.0.0", 662 | "which": "^2.0.1" 663 | }, 664 | "engines": { 665 | "node": ">= 8" 666 | } 667 | }, 668 | "node_modules/debug": { 669 | "version": "4.3.4", 670 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 671 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 672 | "dev": true, 673 | "dependencies": { 674 | "ms": "2.1.2" 675 | }, 676 | "engines": { 677 | "node": ">=6.0" 678 | }, 679 | "peerDependenciesMeta": { 680 | "supports-color": { 681 | "optional": true 682 | } 683 | } 684 | }, 685 | "node_modules/decamelize": { 686 | "version": "4.0.0", 687 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 688 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 689 | "dev": true, 690 | "engines": { 691 | "node": ">=10" 692 | }, 693 | "funding": { 694 | "url": "https://github.com/sponsors/sindresorhus" 695 | } 696 | }, 697 | "node_modules/deep-is": { 698 | "version": "0.1.4", 699 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 700 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 701 | "dev": true 702 | }, 703 | "node_modules/defekt": { 704 | "version": "9.1.0", 705 | "resolved": "https://registry.npmjs.org/defekt/-/defekt-9.1.0.tgz", 706 | "integrity": "sha512-Ocx7DoFAX1c7cPOacNWV/dz7Ebino2k0//0old5cxKDf3Ovyiwio9MpKLDSkgIkp6Han+PXgROmffxAKsok5nA==", 707 | "dev": true 708 | }, 709 | "node_modules/define-data-property": { 710 | "version": "1.1.4", 711 | "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", 712 | "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", 713 | "dev": true, 714 | "dependencies": { 715 | "es-define-property": "^1.0.0", 716 | "es-errors": "^1.3.0", 717 | "gopd": "^1.0.1" 718 | }, 719 | "engines": { 720 | "node": ">= 0.4" 721 | }, 722 | "funding": { 723 | "url": "https://github.com/sponsors/ljharb" 724 | } 725 | }, 726 | "node_modules/define-properties": { 727 | "version": "1.2.1", 728 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz", 729 | "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==", 730 | "dev": true, 731 | "dependencies": { 732 | "define-data-property": "^1.0.1", 733 | "has-property-descriptors": "^1.0.0", 734 | "object-keys": "^1.1.1" 735 | }, 736 | "engines": { 737 | "node": ">= 0.4" 738 | }, 739 | "funding": { 740 | "url": "https://github.com/sponsors/ljharb" 741 | } 742 | }, 743 | "node_modules/diff": { 744 | "version": "5.0.0", 745 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 746 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 747 | "dev": true, 748 | "engines": { 749 | "node": ">=0.3.1" 750 | } 751 | }, 752 | "node_modules/doctrine": { 753 | "version": "3.0.0", 754 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 755 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 756 | "dev": true, 757 | "dependencies": { 758 | "esutils": "^2.0.2" 759 | }, 760 | "engines": { 761 | "node": ">=6.0.0" 762 | } 763 | }, 764 | "node_modules/emoji-regex": { 765 | "version": "8.0.0", 766 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 767 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 768 | "dev": true 769 | }, 770 | "node_modules/es-abstract": { 771 | "version": "1.22.4", 772 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.22.4.tgz", 773 | "integrity": "sha512-vZYJlk2u6qHYxBOTjAeg7qUxHdNfih64Uu2J8QqWgXZ2cri0ZpJAkzDUK/q593+mvKwlxyaxr6F1Q+3LKoQRgg==", 774 | "dev": true, 775 | "dependencies": { 776 | "array-buffer-byte-length": "^1.0.1", 777 | "arraybuffer.prototype.slice": "^1.0.3", 778 | "available-typed-arrays": "^1.0.6", 779 | "call-bind": "^1.0.7", 780 | "es-define-property": "^1.0.0", 781 | "es-errors": "^1.3.0", 782 | "es-set-tostringtag": "^2.0.2", 783 | "es-to-primitive": "^1.2.1", 784 | "function.prototype.name": "^1.1.6", 785 | "get-intrinsic": "^1.2.4", 786 | "get-symbol-description": "^1.0.2", 787 | "globalthis": "^1.0.3", 788 | "gopd": "^1.0.1", 789 | "has-property-descriptors": "^1.0.2", 790 | "has-proto": "^1.0.1", 791 | "has-symbols": "^1.0.3", 792 | "hasown": "^2.0.1", 793 | "internal-slot": "^1.0.7", 794 | "is-array-buffer": "^3.0.4", 795 | "is-callable": "^1.2.7", 796 | "is-negative-zero": "^2.0.2", 797 | "is-regex": "^1.1.4", 798 | "is-shared-array-buffer": "^1.0.2", 799 | "is-string": "^1.0.7", 800 | "is-typed-array": "^1.1.13", 801 | "is-weakref": "^1.0.2", 802 | "object-inspect": "^1.13.1", 803 | "object-keys": "^1.1.1", 804 | "object.assign": "^4.1.5", 805 | "regexp.prototype.flags": "^1.5.2", 806 | "safe-array-concat": "^1.1.0", 807 | "safe-regex-test": "^1.0.3", 808 | "string.prototype.trim": "^1.2.8", 809 | "string.prototype.trimend": "^1.0.7", 810 | "string.prototype.trimstart": "^1.0.7", 811 | "typed-array-buffer": "^1.0.1", 812 | "typed-array-byte-length": "^1.0.0", 813 | "typed-array-byte-offset": "^1.0.0", 814 | "typed-array-length": "^1.0.4", 815 | "unbox-primitive": "^1.0.2", 816 | "which-typed-array": "^1.1.14" 817 | }, 818 | "engines": { 819 | "node": ">= 0.4" 820 | }, 821 | "funding": { 822 | "url": "https://github.com/sponsors/ljharb" 823 | } 824 | }, 825 | "node_modules/es-array-method-boxes-properly": { 826 | "version": "1.0.0", 827 | "resolved": "https://registry.npmjs.org/es-array-method-boxes-properly/-/es-array-method-boxes-properly-1.0.0.tgz", 828 | "integrity": "sha512-wd6JXUmyHmt8T5a2xreUwKcGPq6f1f+WwIJkijUqiGcJz1qqnZgP6XIK+QyIWU5lT7imeNxUll48bziG+TSYcA==", 829 | "dev": true 830 | }, 831 | "node_modules/es-define-property": { 832 | "version": "1.0.0", 833 | "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", 834 | "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", 835 | "dev": true, 836 | "dependencies": { 837 | "get-intrinsic": "^1.2.4" 838 | }, 839 | "engines": { 840 | "node": ">= 0.4" 841 | } 842 | }, 843 | "node_modules/es-errors": { 844 | "version": "1.3.0", 845 | "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", 846 | "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", 847 | "dev": true, 848 | "engines": { 849 | "node": ">= 0.4" 850 | } 851 | }, 852 | "node_modules/es-set-tostringtag": { 853 | "version": "2.0.3", 854 | "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.3.tgz", 855 | "integrity": "sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ==", 856 | "dev": true, 857 | "dependencies": { 858 | "get-intrinsic": "^1.2.4", 859 | "has-tostringtag": "^1.0.2", 860 | "hasown": "^2.0.1" 861 | }, 862 | "engines": { 863 | "node": ">= 0.4" 864 | } 865 | }, 866 | "node_modules/es-shim-unscopables": { 867 | "version": "1.0.2", 868 | "resolved": "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.2.tgz", 869 | "integrity": "sha512-J3yBRXCzDu4ULnQwxyToo/OjdMx6akgVC7K6few0a7F/0wLtmKKN7I73AH5T2836UuXRqN7Qg+IIUw/+YJksRw==", 870 | "dev": true, 871 | "dependencies": { 872 | "hasown": "^2.0.0" 873 | } 874 | }, 875 | "node_modules/es-to-primitive": { 876 | "version": "1.2.1", 877 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 878 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 879 | "dev": true, 880 | "dependencies": { 881 | "is-callable": "^1.1.4", 882 | "is-date-object": "^1.0.1", 883 | "is-symbol": "^1.0.2" 884 | }, 885 | "engines": { 886 | "node": ">= 0.4" 887 | }, 888 | "funding": { 889 | "url": "https://github.com/sponsors/ljharb" 890 | } 891 | }, 892 | "node_modules/escalade": { 893 | "version": "3.1.2", 894 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.2.tgz", 895 | "integrity": "sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA==", 896 | "dev": true, 897 | "engines": { 898 | "node": ">=6" 899 | } 900 | }, 901 | "node_modules/escape-string-regexp": { 902 | "version": "4.0.0", 903 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 904 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 905 | "dev": true, 906 | "engines": { 907 | "node": ">=10" 908 | }, 909 | "funding": { 910 | "url": "https://github.com/sponsors/sindresorhus" 911 | } 912 | }, 913 | "node_modules/eslint": { 914 | "version": "8.57.0", 915 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.57.0.tgz", 916 | "integrity": "sha512-dZ6+mexnaTIbSBZWgou51U6OmzIhYM2VcNdtiTtI7qPNZm35Akpr0f6vtw3w1Kmn5PYo+tZVfh13WrhpS6oLqQ==", 917 | "dev": true, 918 | "dependencies": { 919 | "@eslint-community/eslint-utils": "^4.2.0", 920 | "@eslint-community/regexpp": "^4.6.1", 921 | "@eslint/eslintrc": "^2.1.4", 922 | "@eslint/js": "8.57.0", 923 | "@humanwhocodes/config-array": "^0.11.14", 924 | "@humanwhocodes/module-importer": "^1.0.1", 925 | "@nodelib/fs.walk": "^1.2.8", 926 | "@ungap/structured-clone": "^1.2.0", 927 | "ajv": "^6.12.4", 928 | "chalk": "^4.0.0", 929 | "cross-spawn": "^7.0.2", 930 | "debug": "^4.3.2", 931 | "doctrine": "^3.0.0", 932 | "escape-string-regexp": "^4.0.0", 933 | "eslint-scope": "^7.2.2", 934 | "eslint-visitor-keys": "^3.4.3", 935 | "espree": "^9.6.1", 936 | "esquery": "^1.4.2", 937 | "esutils": "^2.0.2", 938 | "fast-deep-equal": "^3.1.3", 939 | "file-entry-cache": "^6.0.1", 940 | "find-up": "^5.0.0", 941 | "glob-parent": "^6.0.2", 942 | "globals": "^13.19.0", 943 | "graphemer": "^1.4.0", 944 | "ignore": "^5.2.0", 945 | "imurmurhash": "^0.1.4", 946 | "is-glob": "^4.0.0", 947 | "is-path-inside": "^3.0.3", 948 | "js-yaml": "^4.1.0", 949 | "json-stable-stringify-without-jsonify": "^1.0.1", 950 | "levn": "^0.4.1", 951 | "lodash.merge": "^4.6.2", 952 | "minimatch": "^3.1.2", 953 | "natural-compare": "^1.4.0", 954 | "optionator": "^0.9.3", 955 | "strip-ansi": "^6.0.1", 956 | "text-table": "^0.2.0" 957 | }, 958 | "bin": { 959 | "eslint": "bin/eslint.js" 960 | }, 961 | "engines": { 962 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 963 | }, 964 | "funding": { 965 | "url": "https://opencollective.com/eslint" 966 | } 967 | }, 968 | "node_modules/eslint-compat-utils": { 969 | "version": "0.1.2", 970 | "resolved": "https://registry.npmjs.org/eslint-compat-utils/-/eslint-compat-utils-0.1.2.tgz", 971 | "integrity": "sha512-Jia4JDldWnFNIru1Ehx1H5s9/yxiRHY/TimCuUc0jNexew3cF1gI6CYZil1ociakfWO3rRqFjl1mskBblB3RYg==", 972 | "dev": true, 973 | "peer": true, 974 | "engines": { 975 | "node": ">=12" 976 | }, 977 | "peerDependencies": { 978 | "eslint": ">=6.0.0" 979 | } 980 | }, 981 | "node_modules/eslint-config-standard": { 982 | "version": "17.1.0", 983 | "resolved": "https://registry.npmjs.org/eslint-config-standard/-/eslint-config-standard-17.1.0.tgz", 984 | "integrity": "sha512-IwHwmaBNtDK4zDHQukFDW5u/aTb8+meQWZvNFWkiGmbWjD6bqyuSSBxxXKkCftCUzc1zwCH2m/baCNDLGmuO5Q==", 985 | "dev": true, 986 | "funding": [ 987 | { 988 | "type": "github", 989 | "url": "https://github.com/sponsors/feross" 990 | }, 991 | { 992 | "type": "patreon", 993 | "url": "https://www.patreon.com/feross" 994 | }, 995 | { 996 | "type": "consulting", 997 | "url": "https://feross.org/support" 998 | } 999 | ], 1000 | "engines": { 1001 | "node": ">=12.0.0" 1002 | }, 1003 | "peerDependencies": { 1004 | "eslint": "^8.0.1", 1005 | "eslint-plugin-import": "^2.25.2", 1006 | "eslint-plugin-n": "^15.0.0 || ^16.0.0 ", 1007 | "eslint-plugin-promise": "^6.0.0" 1008 | } 1009 | }, 1010 | "node_modules/eslint-import-resolver-node": { 1011 | "version": "0.3.9", 1012 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.9.tgz", 1013 | "integrity": "sha512-WFj2isz22JahUv+B788TlO3N6zL3nNJGU8CcZbPZvVEkBPaJdCV4vy5wyghty5ROFbCRnm132v8BScu5/1BQ8g==", 1014 | "dev": true, 1015 | "dependencies": { 1016 | "debug": "^3.2.7", 1017 | "is-core-module": "^2.13.0", 1018 | "resolve": "^1.22.4" 1019 | } 1020 | }, 1021 | "node_modules/eslint-import-resolver-node/node_modules/debug": { 1022 | "version": "3.2.7", 1023 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1024 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1025 | "dev": true, 1026 | "dependencies": { 1027 | "ms": "^2.1.1" 1028 | } 1029 | }, 1030 | "node_modules/eslint-module-utils": { 1031 | "version": "2.8.0", 1032 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.8.0.tgz", 1033 | "integrity": "sha512-aWajIYfsqCKRDgUfjEXNN/JlrzauMuSEy5sbd7WXbtW3EH6A6MpwEh42c7qD+MqQo9QMJ6fWLAeIJynx0g6OAw==", 1034 | "dev": true, 1035 | "dependencies": { 1036 | "debug": "^3.2.7" 1037 | }, 1038 | "engines": { 1039 | "node": ">=4" 1040 | }, 1041 | "peerDependenciesMeta": { 1042 | "eslint": { 1043 | "optional": true 1044 | } 1045 | } 1046 | }, 1047 | "node_modules/eslint-module-utils/node_modules/debug": { 1048 | "version": "3.2.7", 1049 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1050 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1051 | "dev": true, 1052 | "dependencies": { 1053 | "ms": "^2.1.1" 1054 | } 1055 | }, 1056 | "node_modules/eslint-plugin-es": { 1057 | "version": "3.0.1", 1058 | "resolved": "https://registry.npmjs.org/eslint-plugin-es/-/eslint-plugin-es-3.0.1.tgz", 1059 | "integrity": "sha512-GUmAsJaN4Fc7Gbtl8uOBlayo2DqhwWvEzykMHSCZHU3XdJ+NSzzZcVhXh3VxX5icqQ+oQdIEawXX8xkR3mIFmQ==", 1060 | "dev": true, 1061 | "dependencies": { 1062 | "eslint-utils": "^2.0.0", 1063 | "regexpp": "^3.0.0" 1064 | }, 1065 | "engines": { 1066 | "node": ">=8.10.0" 1067 | }, 1068 | "funding": { 1069 | "url": "https://github.com/sponsors/mysticatea" 1070 | }, 1071 | "peerDependencies": { 1072 | "eslint": ">=4.19.1" 1073 | } 1074 | }, 1075 | "node_modules/eslint-plugin-es-x": { 1076 | "version": "7.5.0", 1077 | "resolved": "https://registry.npmjs.org/eslint-plugin-es-x/-/eslint-plugin-es-x-7.5.0.tgz", 1078 | "integrity": "sha512-ODswlDSO0HJDzXU0XvgZ3lF3lS3XAZEossh15Q2UHjwrJggWeBoKqqEsLTZLXl+dh5eOAozG0zRcYtuE35oTuQ==", 1079 | "dev": true, 1080 | "peer": true, 1081 | "dependencies": { 1082 | "@eslint-community/eslint-utils": "^4.1.2", 1083 | "@eslint-community/regexpp": "^4.6.0", 1084 | "eslint-compat-utils": "^0.1.2" 1085 | }, 1086 | "engines": { 1087 | "node": "^14.18.0 || >=16.0.0" 1088 | }, 1089 | "funding": { 1090 | "url": "https://github.com/sponsors/ota-meshi" 1091 | }, 1092 | "peerDependencies": { 1093 | "eslint": ">=8" 1094 | } 1095 | }, 1096 | "node_modules/eslint-plugin-import": { 1097 | "version": "2.29.1", 1098 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.29.1.tgz", 1099 | "integrity": "sha512-BbPC0cuExzhiMo4Ff1BTVwHpjjv28C5R+btTOGaCRC7UEz801up0JadwkeSk5Ued6TG34uaczuVuH6qyy5YUxw==", 1100 | "dev": true, 1101 | "dependencies": { 1102 | "array-includes": "^3.1.7", 1103 | "array.prototype.findlastindex": "^1.2.3", 1104 | "array.prototype.flat": "^1.3.2", 1105 | "array.prototype.flatmap": "^1.3.2", 1106 | "debug": "^3.2.7", 1107 | "doctrine": "^2.1.0", 1108 | "eslint-import-resolver-node": "^0.3.9", 1109 | "eslint-module-utils": "^2.8.0", 1110 | "hasown": "^2.0.0", 1111 | "is-core-module": "^2.13.1", 1112 | "is-glob": "^4.0.3", 1113 | "minimatch": "^3.1.2", 1114 | "object.fromentries": "^2.0.7", 1115 | "object.groupby": "^1.0.1", 1116 | "object.values": "^1.1.7", 1117 | "semver": "^6.3.1", 1118 | "tsconfig-paths": "^3.15.0" 1119 | }, 1120 | "engines": { 1121 | "node": ">=4" 1122 | }, 1123 | "peerDependencies": { 1124 | "eslint": "^2 || ^3 || ^4 || ^5 || ^6 || ^7.2.0 || ^8" 1125 | } 1126 | }, 1127 | "node_modules/eslint-plugin-import/node_modules/debug": { 1128 | "version": "3.2.7", 1129 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1130 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1131 | "dev": true, 1132 | "dependencies": { 1133 | "ms": "^2.1.1" 1134 | } 1135 | }, 1136 | "node_modules/eslint-plugin-import/node_modules/doctrine": { 1137 | "version": "2.1.0", 1138 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 1139 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 1140 | "dev": true, 1141 | "dependencies": { 1142 | "esutils": "^2.0.2" 1143 | }, 1144 | "engines": { 1145 | "node": ">=0.10.0" 1146 | } 1147 | }, 1148 | "node_modules/eslint-plugin-n": { 1149 | "version": "16.6.2", 1150 | "resolved": "https://registry.npmjs.org/eslint-plugin-n/-/eslint-plugin-n-16.6.2.tgz", 1151 | "integrity": "sha512-6TyDmZ1HXoFQXnhCTUjVFULReoBPOAjpuiKELMkeP40yffI/1ZRO+d9ug/VC6fqISo2WkuIBk3cvuRPALaWlOQ==", 1152 | "dev": true, 1153 | "peer": true, 1154 | "dependencies": { 1155 | "@eslint-community/eslint-utils": "^4.4.0", 1156 | "builtins": "^5.0.1", 1157 | "eslint-plugin-es-x": "^7.5.0", 1158 | "get-tsconfig": "^4.7.0", 1159 | "globals": "^13.24.0", 1160 | "ignore": "^5.2.4", 1161 | "is-builtin-module": "^3.2.1", 1162 | "is-core-module": "^2.12.1", 1163 | "minimatch": "^3.1.2", 1164 | "resolve": "^1.22.2", 1165 | "semver": "^7.5.3" 1166 | }, 1167 | "engines": { 1168 | "node": ">=16.0.0" 1169 | }, 1170 | "funding": { 1171 | "url": "https://github.com/sponsors/mysticatea" 1172 | }, 1173 | "peerDependencies": { 1174 | "eslint": ">=7.0.0" 1175 | } 1176 | }, 1177 | "node_modules/eslint-plugin-n/node_modules/semver": { 1178 | "version": "7.6.0", 1179 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz", 1180 | "integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==", 1181 | "dev": true, 1182 | "peer": true, 1183 | "dependencies": { 1184 | "lru-cache": "^6.0.0" 1185 | }, 1186 | "bin": { 1187 | "semver": "bin/semver.js" 1188 | }, 1189 | "engines": { 1190 | "node": ">=10" 1191 | } 1192 | }, 1193 | "node_modules/eslint-plugin-node": { 1194 | "version": "11.1.0", 1195 | "resolved": "https://registry.npmjs.org/eslint-plugin-node/-/eslint-plugin-node-11.1.0.tgz", 1196 | "integrity": "sha512-oUwtPJ1W0SKD0Tr+wqu92c5xuCeQqB3hSCHasn/ZgjFdA9iDGNkNf2Zi9ztY7X+hNuMib23LNGRm6+uN+KLE3g==", 1197 | "dev": true, 1198 | "dependencies": { 1199 | "eslint-plugin-es": "^3.0.0", 1200 | "eslint-utils": "^2.0.0", 1201 | "ignore": "^5.1.1", 1202 | "minimatch": "^3.0.4", 1203 | "resolve": "^1.10.1", 1204 | "semver": "^6.1.0" 1205 | }, 1206 | "engines": { 1207 | "node": ">=8.10.0" 1208 | }, 1209 | "peerDependencies": { 1210 | "eslint": ">=5.16.0" 1211 | } 1212 | }, 1213 | "node_modules/eslint-plugin-promise": { 1214 | "version": "6.1.1", 1215 | "resolved": "https://registry.npmjs.org/eslint-plugin-promise/-/eslint-plugin-promise-6.1.1.tgz", 1216 | "integrity": "sha512-tjqWDwVZQo7UIPMeDReOpUgHCmCiH+ePnVT+5zVapL0uuHnegBUs2smM13CzOs2Xb5+MHMRFTs9v24yjba4Oig==", 1217 | "dev": true, 1218 | "engines": { 1219 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1220 | }, 1221 | "peerDependencies": { 1222 | "eslint": "^7.0.0 || ^8.0.0" 1223 | } 1224 | }, 1225 | "node_modules/eslint-scope": { 1226 | "version": "7.2.2", 1227 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", 1228 | "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", 1229 | "dev": true, 1230 | "dependencies": { 1231 | "esrecurse": "^4.3.0", 1232 | "estraverse": "^5.2.0" 1233 | }, 1234 | "engines": { 1235 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1236 | }, 1237 | "funding": { 1238 | "url": "https://opencollective.com/eslint" 1239 | } 1240 | }, 1241 | "node_modules/eslint-utils": { 1242 | "version": "2.1.0", 1243 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 1244 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 1245 | "dev": true, 1246 | "dependencies": { 1247 | "eslint-visitor-keys": "^1.1.0" 1248 | }, 1249 | "engines": { 1250 | "node": ">=6" 1251 | }, 1252 | "funding": { 1253 | "url": "https://github.com/sponsors/mysticatea" 1254 | } 1255 | }, 1256 | "node_modules/eslint-utils/node_modules/eslint-visitor-keys": { 1257 | "version": "1.3.0", 1258 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 1259 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 1260 | "dev": true, 1261 | "engines": { 1262 | "node": ">=4" 1263 | } 1264 | }, 1265 | "node_modules/eslint-visitor-keys": { 1266 | "version": "3.4.3", 1267 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 1268 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 1269 | "dev": true, 1270 | "engines": { 1271 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1272 | }, 1273 | "funding": { 1274 | "url": "https://opencollective.com/eslint" 1275 | } 1276 | }, 1277 | "node_modules/espree": { 1278 | "version": "9.6.1", 1279 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", 1280 | "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", 1281 | "dev": true, 1282 | "dependencies": { 1283 | "acorn": "^8.9.0", 1284 | "acorn-jsx": "^5.3.2", 1285 | "eslint-visitor-keys": "^3.4.1" 1286 | }, 1287 | "engines": { 1288 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1289 | }, 1290 | "funding": { 1291 | "url": "https://opencollective.com/eslint" 1292 | } 1293 | }, 1294 | "node_modules/esquery": { 1295 | "version": "1.5.0", 1296 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", 1297 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", 1298 | "dev": true, 1299 | "dependencies": { 1300 | "estraverse": "^5.1.0" 1301 | }, 1302 | "engines": { 1303 | "node": ">=0.10" 1304 | } 1305 | }, 1306 | "node_modules/esrecurse": { 1307 | "version": "4.3.0", 1308 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 1309 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 1310 | "dev": true, 1311 | "dependencies": { 1312 | "estraverse": "^5.2.0" 1313 | }, 1314 | "engines": { 1315 | "node": ">=4.0" 1316 | } 1317 | }, 1318 | "node_modules/estraverse": { 1319 | "version": "5.3.0", 1320 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 1321 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 1322 | "dev": true, 1323 | "engines": { 1324 | "node": ">=4.0" 1325 | } 1326 | }, 1327 | "node_modules/esutils": { 1328 | "version": "2.0.3", 1329 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 1330 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 1331 | "dev": true, 1332 | "engines": { 1333 | "node": ">=0.10.0" 1334 | } 1335 | }, 1336 | "node_modules/fast-deep-equal": { 1337 | "version": "3.1.3", 1338 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1339 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 1340 | "dev": true 1341 | }, 1342 | "node_modules/fast-json-stable-stringify": { 1343 | "version": "2.1.0", 1344 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1345 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1346 | "dev": true 1347 | }, 1348 | "node_modules/fast-levenshtein": { 1349 | "version": "2.0.6", 1350 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1351 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 1352 | "dev": true 1353 | }, 1354 | "node_modules/fastq": { 1355 | "version": "1.17.1", 1356 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", 1357 | "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==", 1358 | "dev": true, 1359 | "dependencies": { 1360 | "reusify": "^1.0.4" 1361 | } 1362 | }, 1363 | "node_modules/file-entry-cache": { 1364 | "version": "6.0.1", 1365 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 1366 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 1367 | "dev": true, 1368 | "dependencies": { 1369 | "flat-cache": "^3.0.4" 1370 | }, 1371 | "engines": { 1372 | "node": "^10.12.0 || >=12.0.0" 1373 | } 1374 | }, 1375 | "node_modules/fill-range": { 1376 | "version": "7.0.1", 1377 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1378 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1379 | "dev": true, 1380 | "dependencies": { 1381 | "to-regex-range": "^5.0.1" 1382 | }, 1383 | "engines": { 1384 | "node": ">=8" 1385 | } 1386 | }, 1387 | "node_modules/find-up": { 1388 | "version": "5.0.0", 1389 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 1390 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 1391 | "dev": true, 1392 | "dependencies": { 1393 | "locate-path": "^6.0.0", 1394 | "path-exists": "^4.0.0" 1395 | }, 1396 | "engines": { 1397 | "node": ">=10" 1398 | }, 1399 | "funding": { 1400 | "url": "https://github.com/sponsors/sindresorhus" 1401 | } 1402 | }, 1403 | "node_modules/flat": { 1404 | "version": "5.0.2", 1405 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 1406 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 1407 | "dev": true, 1408 | "bin": { 1409 | "flat": "cli.js" 1410 | } 1411 | }, 1412 | "node_modules/flat-cache": { 1413 | "version": "3.2.0", 1414 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", 1415 | "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", 1416 | "dev": true, 1417 | "dependencies": { 1418 | "flatted": "^3.2.9", 1419 | "keyv": "^4.5.3", 1420 | "rimraf": "^3.0.2" 1421 | }, 1422 | "engines": { 1423 | "node": "^10.12.0 || >=12.0.0" 1424 | } 1425 | }, 1426 | "node_modules/flatted": { 1427 | "version": "3.3.1", 1428 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", 1429 | "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==", 1430 | "dev": true 1431 | }, 1432 | "node_modules/for-each": { 1433 | "version": "0.3.3", 1434 | "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", 1435 | "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", 1436 | "dev": true, 1437 | "dependencies": { 1438 | "is-callable": "^1.1.3" 1439 | } 1440 | }, 1441 | "node_modules/fs.realpath": { 1442 | "version": "1.0.0", 1443 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1444 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 1445 | "dev": true 1446 | }, 1447 | "node_modules/fsevents": { 1448 | "version": "2.3.3", 1449 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 1450 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 1451 | "dev": true, 1452 | "hasInstallScript": true, 1453 | "optional": true, 1454 | "os": [ 1455 | "darwin" 1456 | ], 1457 | "engines": { 1458 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 1459 | } 1460 | }, 1461 | "node_modules/function-bind": { 1462 | "version": "1.1.2", 1463 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 1464 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 1465 | "dev": true, 1466 | "funding": { 1467 | "url": "https://github.com/sponsors/ljharb" 1468 | } 1469 | }, 1470 | "node_modules/function.prototype.name": { 1471 | "version": "1.1.6", 1472 | "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz", 1473 | "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==", 1474 | "dev": true, 1475 | "dependencies": { 1476 | "call-bind": "^1.0.2", 1477 | "define-properties": "^1.2.0", 1478 | "es-abstract": "^1.22.1", 1479 | "functions-have-names": "^1.2.3" 1480 | }, 1481 | "engines": { 1482 | "node": ">= 0.4" 1483 | }, 1484 | "funding": { 1485 | "url": "https://github.com/sponsors/ljharb" 1486 | } 1487 | }, 1488 | "node_modules/functions-have-names": { 1489 | "version": "1.2.3", 1490 | "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", 1491 | "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", 1492 | "dev": true, 1493 | "funding": { 1494 | "url": "https://github.com/sponsors/ljharb" 1495 | } 1496 | }, 1497 | "node_modules/get-caller-file": { 1498 | "version": "2.0.5", 1499 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1500 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1501 | "dev": true, 1502 | "engines": { 1503 | "node": "6.* || 8.* || >= 10.*" 1504 | } 1505 | }, 1506 | "node_modules/get-intrinsic": { 1507 | "version": "1.2.4", 1508 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", 1509 | "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", 1510 | "dev": true, 1511 | "dependencies": { 1512 | "es-errors": "^1.3.0", 1513 | "function-bind": "^1.1.2", 1514 | "has-proto": "^1.0.1", 1515 | "has-symbols": "^1.0.3", 1516 | "hasown": "^2.0.0" 1517 | }, 1518 | "engines": { 1519 | "node": ">= 0.4" 1520 | }, 1521 | "funding": { 1522 | "url": "https://github.com/sponsors/ljharb" 1523 | } 1524 | }, 1525 | "node_modules/get-symbol-description": { 1526 | "version": "1.0.2", 1527 | "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.2.tgz", 1528 | "integrity": "sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==", 1529 | "dev": true, 1530 | "dependencies": { 1531 | "call-bind": "^1.0.5", 1532 | "es-errors": "^1.3.0", 1533 | "get-intrinsic": "^1.2.4" 1534 | }, 1535 | "engines": { 1536 | "node": ">= 0.4" 1537 | }, 1538 | "funding": { 1539 | "url": "https://github.com/sponsors/ljharb" 1540 | } 1541 | }, 1542 | "node_modules/get-tsconfig": { 1543 | "version": "4.7.2", 1544 | "resolved": "https://registry.npmjs.org/get-tsconfig/-/get-tsconfig-4.7.2.tgz", 1545 | "integrity": "sha512-wuMsz4leaj5hbGgg4IvDU0bqJagpftG5l5cXIAvo8uZrqn0NJqwtfupTN00VnkQJPcIRrxYrm1Ue24btpCha2A==", 1546 | "dev": true, 1547 | "peer": true, 1548 | "dependencies": { 1549 | "resolve-pkg-maps": "^1.0.0" 1550 | }, 1551 | "funding": { 1552 | "url": "https://github.com/privatenumber/get-tsconfig?sponsor=1" 1553 | } 1554 | }, 1555 | "node_modules/glob": { 1556 | "version": "8.1.0", 1557 | "resolved": "https://registry.npmjs.org/glob/-/glob-8.1.0.tgz", 1558 | "integrity": "sha512-r8hpEjiQEYlF2QU0df3dS+nxxSIreXQS1qRhMJM0Q5NDdR386C7jb7Hwwod8Fgiuex+k0GFjgft18yvxm5XoCQ==", 1559 | "dev": true, 1560 | "dependencies": { 1561 | "fs.realpath": "^1.0.0", 1562 | "inflight": "^1.0.4", 1563 | "inherits": "2", 1564 | "minimatch": "^5.0.1", 1565 | "once": "^1.3.0" 1566 | }, 1567 | "engines": { 1568 | "node": ">=12" 1569 | }, 1570 | "funding": { 1571 | "url": "https://github.com/sponsors/isaacs" 1572 | } 1573 | }, 1574 | "node_modules/glob-parent": { 1575 | "version": "6.0.2", 1576 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 1577 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 1578 | "dev": true, 1579 | "dependencies": { 1580 | "is-glob": "^4.0.3" 1581 | }, 1582 | "engines": { 1583 | "node": ">=10.13.0" 1584 | } 1585 | }, 1586 | "node_modules/glob/node_modules/brace-expansion": { 1587 | "version": "2.0.1", 1588 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 1589 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 1590 | "dev": true, 1591 | "dependencies": { 1592 | "balanced-match": "^1.0.0" 1593 | } 1594 | }, 1595 | "node_modules/glob/node_modules/minimatch": { 1596 | "version": "5.1.6", 1597 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz", 1598 | "integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==", 1599 | "dev": true, 1600 | "dependencies": { 1601 | "brace-expansion": "^2.0.1" 1602 | }, 1603 | "engines": { 1604 | "node": ">=10" 1605 | } 1606 | }, 1607 | "node_modules/globals": { 1608 | "version": "13.24.0", 1609 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", 1610 | "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", 1611 | "dev": true, 1612 | "dependencies": { 1613 | "type-fest": "^0.20.2" 1614 | }, 1615 | "engines": { 1616 | "node": ">=8" 1617 | }, 1618 | "funding": { 1619 | "url": "https://github.com/sponsors/sindresorhus" 1620 | } 1621 | }, 1622 | "node_modules/globalthis": { 1623 | "version": "1.0.3", 1624 | "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.3.tgz", 1625 | "integrity": "sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA==", 1626 | "dev": true, 1627 | "dependencies": { 1628 | "define-properties": "^1.1.3" 1629 | }, 1630 | "engines": { 1631 | "node": ">= 0.4" 1632 | }, 1633 | "funding": { 1634 | "url": "https://github.com/sponsors/ljharb" 1635 | } 1636 | }, 1637 | "node_modules/gopd": { 1638 | "version": "1.0.1", 1639 | "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", 1640 | "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", 1641 | "dev": true, 1642 | "dependencies": { 1643 | "get-intrinsic": "^1.1.3" 1644 | }, 1645 | "funding": { 1646 | "url": "https://github.com/sponsors/ljharb" 1647 | } 1648 | }, 1649 | "node_modules/graphemer": { 1650 | "version": "1.4.0", 1651 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", 1652 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", 1653 | "dev": true 1654 | }, 1655 | "node_modules/has-bigints": { 1656 | "version": "1.0.2", 1657 | "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", 1658 | "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", 1659 | "dev": true, 1660 | "funding": { 1661 | "url": "https://github.com/sponsors/ljharb" 1662 | } 1663 | }, 1664 | "node_modules/has-flag": { 1665 | "version": "4.0.0", 1666 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1667 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1668 | "dev": true, 1669 | "engines": { 1670 | "node": ">=8" 1671 | } 1672 | }, 1673 | "node_modules/has-property-descriptors": { 1674 | "version": "1.0.2", 1675 | "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", 1676 | "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", 1677 | "dev": true, 1678 | "dependencies": { 1679 | "es-define-property": "^1.0.0" 1680 | }, 1681 | "funding": { 1682 | "url": "https://github.com/sponsors/ljharb" 1683 | } 1684 | }, 1685 | "node_modules/has-proto": { 1686 | "version": "1.0.3", 1687 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", 1688 | "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", 1689 | "dev": true, 1690 | "engines": { 1691 | "node": ">= 0.4" 1692 | }, 1693 | "funding": { 1694 | "url": "https://github.com/sponsors/ljharb" 1695 | } 1696 | }, 1697 | "node_modules/has-symbols": { 1698 | "version": "1.0.3", 1699 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 1700 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 1701 | "dev": true, 1702 | "engines": { 1703 | "node": ">= 0.4" 1704 | }, 1705 | "funding": { 1706 | "url": "https://github.com/sponsors/ljharb" 1707 | } 1708 | }, 1709 | "node_modules/has-tostringtag": { 1710 | "version": "1.0.2", 1711 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz", 1712 | "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==", 1713 | "dev": true, 1714 | "dependencies": { 1715 | "has-symbols": "^1.0.3" 1716 | }, 1717 | "engines": { 1718 | "node": ">= 0.4" 1719 | }, 1720 | "funding": { 1721 | "url": "https://github.com/sponsors/ljharb" 1722 | } 1723 | }, 1724 | "node_modules/hasown": { 1725 | "version": "2.0.1", 1726 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.1.tgz", 1727 | "integrity": "sha512-1/th4MHjnwncwXsIW6QMzlvYL9kG5e/CpVvLRZe4XPa8TOUNbCELqmvhDmnkNsAjwaG4+I8gJJL0JBvTTLO9qA==", 1728 | "dev": true, 1729 | "dependencies": { 1730 | "function-bind": "^1.1.2" 1731 | }, 1732 | "engines": { 1733 | "node": ">= 0.4" 1734 | } 1735 | }, 1736 | "node_modules/he": { 1737 | "version": "1.2.0", 1738 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 1739 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 1740 | "dev": true, 1741 | "bin": { 1742 | "he": "bin/he" 1743 | } 1744 | }, 1745 | "node_modules/humanize-duration": { 1746 | "version": "3.31.0", 1747 | "resolved": "https://registry.npmjs.org/humanize-duration/-/humanize-duration-3.31.0.tgz", 1748 | "integrity": "sha512-fRrehgBG26NNZysRlTq1S+HPtDpp3u+Jzdc/d5A4cEzOD86YLAkDaJyJg8krSdCi7CJ+s7ht3fwRj8Dl+Btd0w==" 1749 | }, 1750 | "node_modules/ignore": { 1751 | "version": "5.3.1", 1752 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.1.tgz", 1753 | "integrity": "sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw==", 1754 | "dev": true, 1755 | "engines": { 1756 | "node": ">= 4" 1757 | } 1758 | }, 1759 | "node_modules/import-fresh": { 1760 | "version": "3.3.0", 1761 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 1762 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 1763 | "dev": true, 1764 | "dependencies": { 1765 | "parent-module": "^1.0.0", 1766 | "resolve-from": "^4.0.0" 1767 | }, 1768 | "engines": { 1769 | "node": ">=6" 1770 | }, 1771 | "funding": { 1772 | "url": "https://github.com/sponsors/sindresorhus" 1773 | } 1774 | }, 1775 | "node_modules/imurmurhash": { 1776 | "version": "0.1.4", 1777 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1778 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 1779 | "dev": true, 1780 | "engines": { 1781 | "node": ">=0.8.19" 1782 | } 1783 | }, 1784 | "node_modules/inflight": { 1785 | "version": "1.0.6", 1786 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1787 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 1788 | "dev": true, 1789 | "dependencies": { 1790 | "once": "^1.3.0", 1791 | "wrappy": "1" 1792 | } 1793 | }, 1794 | "node_modules/inherits": { 1795 | "version": "2.0.4", 1796 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1797 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1798 | "dev": true 1799 | }, 1800 | "node_modules/internal-slot": { 1801 | "version": "1.0.7", 1802 | "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.7.tgz", 1803 | "integrity": "sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==", 1804 | "dev": true, 1805 | "dependencies": { 1806 | "es-errors": "^1.3.0", 1807 | "hasown": "^2.0.0", 1808 | "side-channel": "^1.0.4" 1809 | }, 1810 | "engines": { 1811 | "node": ">= 0.4" 1812 | } 1813 | }, 1814 | "node_modules/is-array-buffer": { 1815 | "version": "3.0.4", 1816 | "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.4.tgz", 1817 | "integrity": "sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==", 1818 | "dev": true, 1819 | "dependencies": { 1820 | "call-bind": "^1.0.2", 1821 | "get-intrinsic": "^1.2.1" 1822 | }, 1823 | "engines": { 1824 | "node": ">= 0.4" 1825 | }, 1826 | "funding": { 1827 | "url": "https://github.com/sponsors/ljharb" 1828 | } 1829 | }, 1830 | "node_modules/is-bigint": { 1831 | "version": "1.0.4", 1832 | "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", 1833 | "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", 1834 | "dev": true, 1835 | "dependencies": { 1836 | "has-bigints": "^1.0.1" 1837 | }, 1838 | "funding": { 1839 | "url": "https://github.com/sponsors/ljharb" 1840 | } 1841 | }, 1842 | "node_modules/is-binary-path": { 1843 | "version": "2.1.0", 1844 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1845 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1846 | "dev": true, 1847 | "dependencies": { 1848 | "binary-extensions": "^2.0.0" 1849 | }, 1850 | "engines": { 1851 | "node": ">=8" 1852 | } 1853 | }, 1854 | "node_modules/is-boolean-object": { 1855 | "version": "1.1.2", 1856 | "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", 1857 | "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", 1858 | "dev": true, 1859 | "dependencies": { 1860 | "call-bind": "^1.0.2", 1861 | "has-tostringtag": "^1.0.0" 1862 | }, 1863 | "engines": { 1864 | "node": ">= 0.4" 1865 | }, 1866 | "funding": { 1867 | "url": "https://github.com/sponsors/ljharb" 1868 | } 1869 | }, 1870 | "node_modules/is-builtin-module": { 1871 | "version": "3.2.1", 1872 | "resolved": "https://registry.npmjs.org/is-builtin-module/-/is-builtin-module-3.2.1.tgz", 1873 | "integrity": "sha512-BSLE3HnV2syZ0FK0iMA/yUGplUeMmNz4AW5fnTunbCIqZi4vG3WjJT9FHMy5D69xmAYBHXQhJdALdpwVxV501A==", 1874 | "dev": true, 1875 | "peer": true, 1876 | "dependencies": { 1877 | "builtin-modules": "^3.3.0" 1878 | }, 1879 | "engines": { 1880 | "node": ">=6" 1881 | }, 1882 | "funding": { 1883 | "url": "https://github.com/sponsors/sindresorhus" 1884 | } 1885 | }, 1886 | "node_modules/is-callable": { 1887 | "version": "1.2.7", 1888 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", 1889 | "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", 1890 | "dev": true, 1891 | "engines": { 1892 | "node": ">= 0.4" 1893 | }, 1894 | "funding": { 1895 | "url": "https://github.com/sponsors/ljharb" 1896 | } 1897 | }, 1898 | "node_modules/is-core-module": { 1899 | "version": "2.13.1", 1900 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", 1901 | "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==", 1902 | "dev": true, 1903 | "dependencies": { 1904 | "hasown": "^2.0.0" 1905 | }, 1906 | "funding": { 1907 | "url": "https://github.com/sponsors/ljharb" 1908 | } 1909 | }, 1910 | "node_modules/is-date-object": { 1911 | "version": "1.0.5", 1912 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", 1913 | "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", 1914 | "dev": true, 1915 | "dependencies": { 1916 | "has-tostringtag": "^1.0.0" 1917 | }, 1918 | "engines": { 1919 | "node": ">= 0.4" 1920 | }, 1921 | "funding": { 1922 | "url": "https://github.com/sponsors/ljharb" 1923 | } 1924 | }, 1925 | "node_modules/is-extglob": { 1926 | "version": "2.1.1", 1927 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1928 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 1929 | "dev": true, 1930 | "engines": { 1931 | "node": ">=0.10.0" 1932 | } 1933 | }, 1934 | "node_modules/is-fullwidth-code-point": { 1935 | "version": "3.0.0", 1936 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1937 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1938 | "dev": true, 1939 | "engines": { 1940 | "node": ">=8" 1941 | } 1942 | }, 1943 | "node_modules/is-glob": { 1944 | "version": "4.0.3", 1945 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1946 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1947 | "dev": true, 1948 | "dependencies": { 1949 | "is-extglob": "^2.1.1" 1950 | }, 1951 | "engines": { 1952 | "node": ">=0.10.0" 1953 | } 1954 | }, 1955 | "node_modules/is-negative-zero": { 1956 | "version": "2.0.3", 1957 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.3.tgz", 1958 | "integrity": "sha512-5KoIu2Ngpyek75jXodFvnafB6DJgr3u8uuK0LEZJjrU19DrMD3EVERaR8sjz8CCGgpZvxPl9SuE1GMVPFHx1mw==", 1959 | "dev": true, 1960 | "engines": { 1961 | "node": ">= 0.4" 1962 | }, 1963 | "funding": { 1964 | "url": "https://github.com/sponsors/ljharb" 1965 | } 1966 | }, 1967 | "node_modules/is-number": { 1968 | "version": "7.0.0", 1969 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1970 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1971 | "dev": true, 1972 | "engines": { 1973 | "node": ">=0.12.0" 1974 | } 1975 | }, 1976 | "node_modules/is-number-object": { 1977 | "version": "1.0.7", 1978 | "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", 1979 | "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", 1980 | "dev": true, 1981 | "dependencies": { 1982 | "has-tostringtag": "^1.0.0" 1983 | }, 1984 | "engines": { 1985 | "node": ">= 0.4" 1986 | }, 1987 | "funding": { 1988 | "url": "https://github.com/sponsors/ljharb" 1989 | } 1990 | }, 1991 | "node_modules/is-path-inside": { 1992 | "version": "3.0.3", 1993 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 1994 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 1995 | "dev": true, 1996 | "engines": { 1997 | "node": ">=8" 1998 | } 1999 | }, 2000 | "node_modules/is-plain-obj": { 2001 | "version": "2.1.0", 2002 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 2003 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 2004 | "dev": true, 2005 | "engines": { 2006 | "node": ">=8" 2007 | } 2008 | }, 2009 | "node_modules/is-regex": { 2010 | "version": "1.1.4", 2011 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", 2012 | "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", 2013 | "dev": true, 2014 | "dependencies": { 2015 | "call-bind": "^1.0.2", 2016 | "has-tostringtag": "^1.0.0" 2017 | }, 2018 | "engines": { 2019 | "node": ">= 0.4" 2020 | }, 2021 | "funding": { 2022 | "url": "https://github.com/sponsors/ljharb" 2023 | } 2024 | }, 2025 | "node_modules/is-shared-array-buffer": { 2026 | "version": "1.0.3", 2027 | "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.3.tgz", 2028 | "integrity": "sha512-nA2hv5XIhLR3uVzDDfCIknerhx8XUKnstuOERPNNIinXG7v9u+ohXF67vxm4TPTEPU6lm61ZkwP3c9PCB97rhg==", 2029 | "dev": true, 2030 | "dependencies": { 2031 | "call-bind": "^1.0.7" 2032 | }, 2033 | "engines": { 2034 | "node": ">= 0.4" 2035 | }, 2036 | "funding": { 2037 | "url": "https://github.com/sponsors/ljharb" 2038 | } 2039 | }, 2040 | "node_modules/is-string": { 2041 | "version": "1.0.7", 2042 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", 2043 | "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", 2044 | "dev": true, 2045 | "dependencies": { 2046 | "has-tostringtag": "^1.0.0" 2047 | }, 2048 | "engines": { 2049 | "node": ">= 0.4" 2050 | }, 2051 | "funding": { 2052 | "url": "https://github.com/sponsors/ljharb" 2053 | } 2054 | }, 2055 | "node_modules/is-symbol": { 2056 | "version": "1.0.4", 2057 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", 2058 | "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", 2059 | "dev": true, 2060 | "dependencies": { 2061 | "has-symbols": "^1.0.2" 2062 | }, 2063 | "engines": { 2064 | "node": ">= 0.4" 2065 | }, 2066 | "funding": { 2067 | "url": "https://github.com/sponsors/ljharb" 2068 | } 2069 | }, 2070 | "node_modules/is-typed-array": { 2071 | "version": "1.1.13", 2072 | "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.13.tgz", 2073 | "integrity": "sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==", 2074 | "dev": true, 2075 | "dependencies": { 2076 | "which-typed-array": "^1.1.14" 2077 | }, 2078 | "engines": { 2079 | "node": ">= 0.4" 2080 | }, 2081 | "funding": { 2082 | "url": "https://github.com/sponsors/ljharb" 2083 | } 2084 | }, 2085 | "node_modules/is-unicode-supported": { 2086 | "version": "0.1.0", 2087 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 2088 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 2089 | "dev": true, 2090 | "engines": { 2091 | "node": ">=10" 2092 | }, 2093 | "funding": { 2094 | "url": "https://github.com/sponsors/sindresorhus" 2095 | } 2096 | }, 2097 | "node_modules/is-weakref": { 2098 | "version": "1.0.2", 2099 | "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", 2100 | "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", 2101 | "dev": true, 2102 | "dependencies": { 2103 | "call-bind": "^1.0.2" 2104 | }, 2105 | "funding": { 2106 | "url": "https://github.com/sponsors/ljharb" 2107 | } 2108 | }, 2109 | "node_modules/isarray": { 2110 | "version": "2.0.5", 2111 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", 2112 | "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", 2113 | "dev": true 2114 | }, 2115 | "node_modules/isexe": { 2116 | "version": "2.0.0", 2117 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2118 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 2119 | "dev": true 2120 | }, 2121 | "node_modules/js-yaml": { 2122 | "version": "4.1.0", 2123 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 2124 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 2125 | "dev": true, 2126 | "dependencies": { 2127 | "argparse": "^2.0.1" 2128 | }, 2129 | "bin": { 2130 | "js-yaml": "bin/js-yaml.js" 2131 | } 2132 | }, 2133 | "node_modules/json-buffer": { 2134 | "version": "3.0.1", 2135 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 2136 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", 2137 | "dev": true 2138 | }, 2139 | "node_modules/json-schema-traverse": { 2140 | "version": "0.4.1", 2141 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2142 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2143 | "dev": true 2144 | }, 2145 | "node_modules/json-stable-stringify-without-jsonify": { 2146 | "version": "1.0.1", 2147 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2148 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 2149 | "dev": true 2150 | }, 2151 | "node_modules/json5": { 2152 | "version": "1.0.2", 2153 | "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.2.tgz", 2154 | "integrity": "sha512-g1MWMLBiz8FKi1e4w0UyVL3w+iJceWAFBAaBnnGKOpNa5f8TLktkbre1+s6oICydWAm+HRUGTmI+//xv2hvXYA==", 2155 | "dev": true, 2156 | "dependencies": { 2157 | "minimist": "^1.2.0" 2158 | }, 2159 | "bin": { 2160 | "json5": "lib/cli.js" 2161 | } 2162 | }, 2163 | "node_modules/keyv": { 2164 | "version": "4.5.4", 2165 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", 2166 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", 2167 | "dev": true, 2168 | "dependencies": { 2169 | "json-buffer": "3.0.1" 2170 | } 2171 | }, 2172 | "node_modules/levn": { 2173 | "version": "0.4.1", 2174 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2175 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 2176 | "dev": true, 2177 | "dependencies": { 2178 | "prelude-ls": "^1.2.1", 2179 | "type-check": "~0.4.0" 2180 | }, 2181 | "engines": { 2182 | "node": ">= 0.8.0" 2183 | } 2184 | }, 2185 | "node_modules/locate-path": { 2186 | "version": "6.0.0", 2187 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 2188 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 2189 | "dev": true, 2190 | "dependencies": { 2191 | "p-locate": "^5.0.0" 2192 | }, 2193 | "engines": { 2194 | "node": ">=10" 2195 | }, 2196 | "funding": { 2197 | "url": "https://github.com/sponsors/sindresorhus" 2198 | } 2199 | }, 2200 | "node_modules/lodash.merge": { 2201 | "version": "4.6.2", 2202 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 2203 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 2204 | "dev": true 2205 | }, 2206 | "node_modules/log-symbols": { 2207 | "version": "4.1.0", 2208 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 2209 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 2210 | "dev": true, 2211 | "dependencies": { 2212 | "chalk": "^4.1.0", 2213 | "is-unicode-supported": "^0.1.0" 2214 | }, 2215 | "engines": { 2216 | "node": ">=10" 2217 | }, 2218 | "funding": { 2219 | "url": "https://github.com/sponsors/sindresorhus" 2220 | } 2221 | }, 2222 | "node_modules/lru-cache": { 2223 | "version": "6.0.0", 2224 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2225 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2226 | "dev": true, 2227 | "peer": true, 2228 | "dependencies": { 2229 | "yallist": "^4.0.0" 2230 | }, 2231 | "engines": { 2232 | "node": ">=10" 2233 | } 2234 | }, 2235 | "node_modules/minimatch": { 2236 | "version": "3.1.2", 2237 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2238 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2239 | "dev": true, 2240 | "dependencies": { 2241 | "brace-expansion": "^1.1.7" 2242 | }, 2243 | "engines": { 2244 | "node": "*" 2245 | } 2246 | }, 2247 | "node_modules/minimist": { 2248 | "version": "1.2.8", 2249 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", 2250 | "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", 2251 | "dev": true, 2252 | "funding": { 2253 | "url": "https://github.com/sponsors/ljharb" 2254 | } 2255 | }, 2256 | "node_modules/mitm": { 2257 | "version": "1.7.2", 2258 | "resolved": "https://registry.npmjs.org/mitm/-/mitm-1.7.2.tgz", 2259 | "integrity": "sha512-SuiJbc5xisP/iUYvsKAvrvPeoyJQbYI3WOfnp8A7XHDn4wkdtmGZe2ZTFXIo3K1of05oxUiaJIK+GoAU5KgFOw==", 2260 | "dev": true, 2261 | "dependencies": { 2262 | "semver": ">= 5 < 6", 2263 | "underscore": ">= 1.1.6 < 1.14" 2264 | }, 2265 | "engines": { 2266 | "node": ">= 0.10.24" 2267 | } 2268 | }, 2269 | "node_modules/mitm/node_modules/semver": { 2270 | "version": "5.7.2", 2271 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", 2272 | "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", 2273 | "dev": true, 2274 | "bin": { 2275 | "semver": "bin/semver" 2276 | } 2277 | }, 2278 | "node_modules/mocha": { 2279 | "version": "10.3.0", 2280 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-10.3.0.tgz", 2281 | "integrity": "sha512-uF2XJs+7xSLsrmIvn37i/wnc91nw7XjOQB8ccyx5aEgdnohr7n+rEiZP23WkCYHjilR6+EboEnbq/ZQDz4LSbg==", 2282 | "dev": true, 2283 | "dependencies": { 2284 | "ansi-colors": "4.1.1", 2285 | "browser-stdout": "1.3.1", 2286 | "chokidar": "3.5.3", 2287 | "debug": "4.3.4", 2288 | "diff": "5.0.0", 2289 | "escape-string-regexp": "4.0.0", 2290 | "find-up": "5.0.0", 2291 | "glob": "8.1.0", 2292 | "he": "1.2.0", 2293 | "js-yaml": "4.1.0", 2294 | "log-symbols": "4.1.0", 2295 | "minimatch": "5.0.1", 2296 | "ms": "2.1.3", 2297 | "serialize-javascript": "6.0.0", 2298 | "strip-json-comments": "3.1.1", 2299 | "supports-color": "8.1.1", 2300 | "workerpool": "6.2.1", 2301 | "yargs": "16.2.0", 2302 | "yargs-parser": "20.2.4", 2303 | "yargs-unparser": "2.0.0" 2304 | }, 2305 | "bin": { 2306 | "_mocha": "bin/_mocha", 2307 | "mocha": "bin/mocha.js" 2308 | }, 2309 | "engines": { 2310 | "node": ">= 14.0.0" 2311 | } 2312 | }, 2313 | "node_modules/mocha/node_modules/brace-expansion": { 2314 | "version": "2.0.1", 2315 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 2316 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 2317 | "dev": true, 2318 | "dependencies": { 2319 | "balanced-match": "^1.0.0" 2320 | } 2321 | }, 2322 | "node_modules/mocha/node_modules/minimatch": { 2323 | "version": "5.0.1", 2324 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.0.1.tgz", 2325 | "integrity": "sha512-nLDxIFRyhDblz3qMuq+SoRZED4+miJ/G+tdDrjkkkRnjAsBexeGpgjLEQ0blJy7rHhR2b93rhQY4SvyWu9v03g==", 2326 | "dev": true, 2327 | "dependencies": { 2328 | "brace-expansion": "^2.0.1" 2329 | }, 2330 | "engines": { 2331 | "node": ">=10" 2332 | } 2333 | }, 2334 | "node_modules/mocha/node_modules/ms": { 2335 | "version": "2.1.3", 2336 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2337 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 2338 | "dev": true 2339 | }, 2340 | "node_modules/mocha/node_modules/supports-color": { 2341 | "version": "8.1.1", 2342 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 2343 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 2344 | "dev": true, 2345 | "dependencies": { 2346 | "has-flag": "^4.0.0" 2347 | }, 2348 | "engines": { 2349 | "node": ">=10" 2350 | }, 2351 | "funding": { 2352 | "url": "https://github.com/chalk/supports-color?sponsor=1" 2353 | } 2354 | }, 2355 | "node_modules/ms": { 2356 | "version": "2.1.2", 2357 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2358 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2359 | "dev": true 2360 | }, 2361 | "node_modules/natural-compare": { 2362 | "version": "1.4.0", 2363 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2364 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 2365 | "dev": true 2366 | }, 2367 | "node_modules/net": { 2368 | "version": "1.0.2", 2369 | "resolved": "https://registry.npmjs.org/net/-/net-1.0.2.tgz", 2370 | "integrity": "sha512-kbhcj2SVVR4caaVnGLJKmlk2+f+oLkjqdKeQlmUtz6nGzOpbcobwVIeSURNgraV/v3tlmGIX82OcPCl0K6RbHQ==" 2371 | }, 2372 | "node_modules/normalize-path": { 2373 | "version": "3.0.0", 2374 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2375 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2376 | "dev": true, 2377 | "engines": { 2378 | "node": ">=0.10.0" 2379 | } 2380 | }, 2381 | "node_modules/object-inspect": { 2382 | "version": "1.13.1", 2383 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.1.tgz", 2384 | "integrity": "sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==", 2385 | "dev": true, 2386 | "funding": { 2387 | "url": "https://github.com/sponsors/ljharb" 2388 | } 2389 | }, 2390 | "node_modules/object-keys": { 2391 | "version": "1.1.1", 2392 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 2393 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 2394 | "dev": true, 2395 | "engines": { 2396 | "node": ">= 0.4" 2397 | } 2398 | }, 2399 | "node_modules/object.assign": { 2400 | "version": "4.1.5", 2401 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.5.tgz", 2402 | "integrity": "sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==", 2403 | "dev": true, 2404 | "dependencies": { 2405 | "call-bind": "^1.0.5", 2406 | "define-properties": "^1.2.1", 2407 | "has-symbols": "^1.0.3", 2408 | "object-keys": "^1.1.1" 2409 | }, 2410 | "engines": { 2411 | "node": ">= 0.4" 2412 | }, 2413 | "funding": { 2414 | "url": "https://github.com/sponsors/ljharb" 2415 | } 2416 | }, 2417 | "node_modules/object.fromentries": { 2418 | "version": "2.0.7", 2419 | "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.7.tgz", 2420 | "integrity": "sha512-UPbPHML6sL8PI/mOqPwsH4G6iyXcCGzLin8KvEPenOZN5lpCNBZZQ+V62vdjB1mQHrmqGQt5/OJzemUA+KJmEA==", 2421 | "dev": true, 2422 | "dependencies": { 2423 | "call-bind": "^1.0.2", 2424 | "define-properties": "^1.2.0", 2425 | "es-abstract": "^1.22.1" 2426 | }, 2427 | "engines": { 2428 | "node": ">= 0.4" 2429 | }, 2430 | "funding": { 2431 | "url": "https://github.com/sponsors/ljharb" 2432 | } 2433 | }, 2434 | "node_modules/object.groupby": { 2435 | "version": "1.0.2", 2436 | "resolved": "https://registry.npmjs.org/object.groupby/-/object.groupby-1.0.2.tgz", 2437 | "integrity": "sha512-bzBq58S+x+uo0VjurFT0UktpKHOZmv4/xePiOA1nbB9pMqpGK7rUPNgf+1YC+7mE+0HzhTMqNUuCqvKhj6FnBw==", 2438 | "dev": true, 2439 | "dependencies": { 2440 | "array.prototype.filter": "^1.0.3", 2441 | "call-bind": "^1.0.5", 2442 | "define-properties": "^1.2.1", 2443 | "es-abstract": "^1.22.3", 2444 | "es-errors": "^1.0.0" 2445 | } 2446 | }, 2447 | "node_modules/object.values": { 2448 | "version": "1.1.7", 2449 | "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.7.tgz", 2450 | "integrity": "sha512-aU6xnDFYT3x17e/f0IiiwlGPTy2jzMySGfUB4fq6z7CV8l85CWHDk5ErhyhpfDHhrOMwGFhSQkhMGHaIotA6Ng==", 2451 | "dev": true, 2452 | "dependencies": { 2453 | "call-bind": "^1.0.2", 2454 | "define-properties": "^1.2.0", 2455 | "es-abstract": "^1.22.1" 2456 | }, 2457 | "engines": { 2458 | "node": ">= 0.4" 2459 | }, 2460 | "funding": { 2461 | "url": "https://github.com/sponsors/ljharb" 2462 | } 2463 | }, 2464 | "node_modules/once": { 2465 | "version": "1.4.0", 2466 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2467 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 2468 | "dev": true, 2469 | "dependencies": { 2470 | "wrappy": "1" 2471 | } 2472 | }, 2473 | "node_modules/optionator": { 2474 | "version": "0.9.3", 2475 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", 2476 | "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", 2477 | "dev": true, 2478 | "dependencies": { 2479 | "@aashutoshrathi/word-wrap": "^1.2.3", 2480 | "deep-is": "^0.1.3", 2481 | "fast-levenshtein": "^2.0.6", 2482 | "levn": "^0.4.1", 2483 | "prelude-ls": "^1.2.1", 2484 | "type-check": "^0.4.0" 2485 | }, 2486 | "engines": { 2487 | "node": ">= 0.8.0" 2488 | } 2489 | }, 2490 | "node_modules/p-limit": { 2491 | "version": "3.1.0", 2492 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2493 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2494 | "dev": true, 2495 | "dependencies": { 2496 | "yocto-queue": "^0.1.0" 2497 | }, 2498 | "engines": { 2499 | "node": ">=10" 2500 | }, 2501 | "funding": { 2502 | "url": "https://github.com/sponsors/sindresorhus" 2503 | } 2504 | }, 2505 | "node_modules/p-locate": { 2506 | "version": "5.0.0", 2507 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2508 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2509 | "dev": true, 2510 | "dependencies": { 2511 | "p-limit": "^3.0.2" 2512 | }, 2513 | "engines": { 2514 | "node": ">=10" 2515 | }, 2516 | "funding": { 2517 | "url": "https://github.com/sponsors/sindresorhus" 2518 | } 2519 | }, 2520 | "node_modules/parent-module": { 2521 | "version": "1.0.1", 2522 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2523 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2524 | "dev": true, 2525 | "dependencies": { 2526 | "callsites": "^3.0.0" 2527 | }, 2528 | "engines": { 2529 | "node": ">=6" 2530 | } 2531 | }, 2532 | "node_modules/path-exists": { 2533 | "version": "4.0.0", 2534 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2535 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2536 | "dev": true, 2537 | "engines": { 2538 | "node": ">=8" 2539 | } 2540 | }, 2541 | "node_modules/path-is-absolute": { 2542 | "version": "1.0.1", 2543 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2544 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 2545 | "dev": true, 2546 | "engines": { 2547 | "node": ">=0.10.0" 2548 | } 2549 | }, 2550 | "node_modules/path-key": { 2551 | "version": "3.1.1", 2552 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2553 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2554 | "dev": true, 2555 | "engines": { 2556 | "node": ">=8" 2557 | } 2558 | }, 2559 | "node_modules/path-parse": { 2560 | "version": "1.0.7", 2561 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 2562 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 2563 | "dev": true 2564 | }, 2565 | "node_modules/picomatch": { 2566 | "version": "2.3.1", 2567 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2568 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2569 | "dev": true, 2570 | "engines": { 2571 | "node": ">=8.6" 2572 | }, 2573 | "funding": { 2574 | "url": "https://github.com/sponsors/jonschlinkert" 2575 | } 2576 | }, 2577 | "node_modules/possible-typed-array-names": { 2578 | "version": "1.0.0", 2579 | "resolved": "https://registry.npmjs.org/possible-typed-array-names/-/possible-typed-array-names-1.0.0.tgz", 2580 | "integrity": "sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q==", 2581 | "dev": true, 2582 | "engines": { 2583 | "node": ">= 0.4" 2584 | } 2585 | }, 2586 | "node_modules/prelude-ls": { 2587 | "version": "1.2.1", 2588 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 2589 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 2590 | "dev": true, 2591 | "engines": { 2592 | "node": ">= 0.8.0" 2593 | } 2594 | }, 2595 | "node_modules/punycode": { 2596 | "version": "2.3.1", 2597 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 2598 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 2599 | "dev": true, 2600 | "engines": { 2601 | "node": ">=6" 2602 | } 2603 | }, 2604 | "node_modules/queue-microtask": { 2605 | "version": "1.2.3", 2606 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 2607 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 2608 | "dev": true, 2609 | "funding": [ 2610 | { 2611 | "type": "github", 2612 | "url": "https://github.com/sponsors/feross" 2613 | }, 2614 | { 2615 | "type": "patreon", 2616 | "url": "https://www.patreon.com/feross" 2617 | }, 2618 | { 2619 | "type": "consulting", 2620 | "url": "https://feross.org/support" 2621 | } 2622 | ] 2623 | }, 2624 | "node_modules/randombytes": { 2625 | "version": "2.1.0", 2626 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 2627 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 2628 | "dev": true, 2629 | "dependencies": { 2630 | "safe-buffer": "^5.1.0" 2631 | } 2632 | }, 2633 | "node_modules/readdirp": { 2634 | "version": "3.6.0", 2635 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 2636 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 2637 | "dev": true, 2638 | "dependencies": { 2639 | "picomatch": "^2.2.1" 2640 | }, 2641 | "engines": { 2642 | "node": ">=8.10.0" 2643 | } 2644 | }, 2645 | "node_modules/regexp.prototype.flags": { 2646 | "version": "1.5.2", 2647 | "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.2.tgz", 2648 | "integrity": "sha512-NcDiDkTLuPR+++OCKB0nWafEmhg/Da8aUPLPMQbK+bxKKCm1/S5he+AqYa4PlMCVBalb4/yxIRub6qkEx5yJbw==", 2649 | "dev": true, 2650 | "dependencies": { 2651 | "call-bind": "^1.0.6", 2652 | "define-properties": "^1.2.1", 2653 | "es-errors": "^1.3.0", 2654 | "set-function-name": "^2.0.1" 2655 | }, 2656 | "engines": { 2657 | "node": ">= 0.4" 2658 | }, 2659 | "funding": { 2660 | "url": "https://github.com/sponsors/ljharb" 2661 | } 2662 | }, 2663 | "node_modules/regexpp": { 2664 | "version": "3.2.0", 2665 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 2666 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 2667 | "dev": true, 2668 | "engines": { 2669 | "node": ">=8" 2670 | }, 2671 | "funding": { 2672 | "url": "https://github.com/sponsors/mysticatea" 2673 | } 2674 | }, 2675 | "node_modules/require-directory": { 2676 | "version": "2.1.1", 2677 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2678 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 2679 | "dev": true, 2680 | "engines": { 2681 | "node": ">=0.10.0" 2682 | } 2683 | }, 2684 | "node_modules/resolve": { 2685 | "version": "1.22.8", 2686 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", 2687 | "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", 2688 | "dev": true, 2689 | "dependencies": { 2690 | "is-core-module": "^2.13.0", 2691 | "path-parse": "^1.0.7", 2692 | "supports-preserve-symlinks-flag": "^1.0.0" 2693 | }, 2694 | "bin": { 2695 | "resolve": "bin/resolve" 2696 | }, 2697 | "funding": { 2698 | "url": "https://github.com/sponsors/ljharb" 2699 | } 2700 | }, 2701 | "node_modules/resolve-from": { 2702 | "version": "4.0.0", 2703 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2704 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2705 | "dev": true, 2706 | "engines": { 2707 | "node": ">=4" 2708 | } 2709 | }, 2710 | "node_modules/resolve-pkg-maps": { 2711 | "version": "1.0.0", 2712 | "resolved": "https://registry.npmjs.org/resolve-pkg-maps/-/resolve-pkg-maps-1.0.0.tgz", 2713 | "integrity": "sha512-seS2Tj26TBVOC2NIc2rOe2y2ZO7efxITtLZcGSOnHHNOQ7CkiUBfw0Iw2ck6xkIhPwLhKNLS8BO+hEpngQlqzw==", 2714 | "dev": true, 2715 | "peer": true, 2716 | "funding": { 2717 | "url": "https://github.com/privatenumber/resolve-pkg-maps?sponsor=1" 2718 | } 2719 | }, 2720 | "node_modules/reusify": { 2721 | "version": "1.0.4", 2722 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 2723 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 2724 | "dev": true, 2725 | "engines": { 2726 | "iojs": ">=1.0.0", 2727 | "node": ">=0.10.0" 2728 | } 2729 | }, 2730 | "node_modules/rimraf": { 2731 | "version": "3.0.2", 2732 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2733 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2734 | "dev": true, 2735 | "dependencies": { 2736 | "glob": "^7.1.3" 2737 | }, 2738 | "bin": { 2739 | "rimraf": "bin.js" 2740 | }, 2741 | "funding": { 2742 | "url": "https://github.com/sponsors/isaacs" 2743 | } 2744 | }, 2745 | "node_modules/rimraf/node_modules/glob": { 2746 | "version": "7.2.3", 2747 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 2748 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 2749 | "dev": true, 2750 | "dependencies": { 2751 | "fs.realpath": "^1.0.0", 2752 | "inflight": "^1.0.4", 2753 | "inherits": "2", 2754 | "minimatch": "^3.1.1", 2755 | "once": "^1.3.0", 2756 | "path-is-absolute": "^1.0.0" 2757 | }, 2758 | "engines": { 2759 | "node": "*" 2760 | }, 2761 | "funding": { 2762 | "url": "https://github.com/sponsors/isaacs" 2763 | } 2764 | }, 2765 | "node_modules/run-parallel": { 2766 | "version": "1.2.0", 2767 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 2768 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 2769 | "dev": true, 2770 | "funding": [ 2771 | { 2772 | "type": "github", 2773 | "url": "https://github.com/sponsors/feross" 2774 | }, 2775 | { 2776 | "type": "patreon", 2777 | "url": "https://www.patreon.com/feross" 2778 | }, 2779 | { 2780 | "type": "consulting", 2781 | "url": "https://feross.org/support" 2782 | } 2783 | ], 2784 | "dependencies": { 2785 | "queue-microtask": "^1.2.2" 2786 | } 2787 | }, 2788 | "node_modules/safe-array-concat": { 2789 | "version": "1.1.0", 2790 | "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.1.0.tgz", 2791 | "integrity": "sha512-ZdQ0Jeb9Ofti4hbt5lX3T2JcAamT9hfzYU1MNB+z/jaEbB6wfFfPIR/zEORmZqobkCCJhSjodobH6WHNmJ97dg==", 2792 | "dev": true, 2793 | "dependencies": { 2794 | "call-bind": "^1.0.5", 2795 | "get-intrinsic": "^1.2.2", 2796 | "has-symbols": "^1.0.3", 2797 | "isarray": "^2.0.5" 2798 | }, 2799 | "engines": { 2800 | "node": ">=0.4" 2801 | }, 2802 | "funding": { 2803 | "url": "https://github.com/sponsors/ljharb" 2804 | } 2805 | }, 2806 | "node_modules/safe-buffer": { 2807 | "version": "5.2.1", 2808 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 2809 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 2810 | "dev": true, 2811 | "funding": [ 2812 | { 2813 | "type": "github", 2814 | "url": "https://github.com/sponsors/feross" 2815 | }, 2816 | { 2817 | "type": "patreon", 2818 | "url": "https://www.patreon.com/feross" 2819 | }, 2820 | { 2821 | "type": "consulting", 2822 | "url": "https://feross.org/support" 2823 | } 2824 | ] 2825 | }, 2826 | "node_modules/safe-regex-test": { 2827 | "version": "1.0.3", 2828 | "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.3.tgz", 2829 | "integrity": "sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw==", 2830 | "dev": true, 2831 | "dependencies": { 2832 | "call-bind": "^1.0.6", 2833 | "es-errors": "^1.3.0", 2834 | "is-regex": "^1.1.4" 2835 | }, 2836 | "engines": { 2837 | "node": ">= 0.4" 2838 | }, 2839 | "funding": { 2840 | "url": "https://github.com/sponsors/ljharb" 2841 | } 2842 | }, 2843 | "node_modules/semver": { 2844 | "version": "6.3.1", 2845 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 2846 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 2847 | "dev": true, 2848 | "bin": { 2849 | "semver": "bin/semver.js" 2850 | } 2851 | }, 2852 | "node_modules/serialize-javascript": { 2853 | "version": "6.0.0", 2854 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 2855 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 2856 | "dev": true, 2857 | "dependencies": { 2858 | "randombytes": "^2.1.0" 2859 | } 2860 | }, 2861 | "node_modules/set-function-length": { 2862 | "version": "1.2.1", 2863 | "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.1.tgz", 2864 | "integrity": "sha512-j4t6ccc+VsKwYHso+kElc5neZpjtq9EnRICFZtWyBsLojhmeF/ZBd/elqm22WJh/BziDe/SBiOeAt0m2mfLD0g==", 2865 | "dev": true, 2866 | "dependencies": { 2867 | "define-data-property": "^1.1.2", 2868 | "es-errors": "^1.3.0", 2869 | "function-bind": "^1.1.2", 2870 | "get-intrinsic": "^1.2.3", 2871 | "gopd": "^1.0.1", 2872 | "has-property-descriptors": "^1.0.1" 2873 | }, 2874 | "engines": { 2875 | "node": ">= 0.4" 2876 | } 2877 | }, 2878 | "node_modules/set-function-name": { 2879 | "version": "2.0.2", 2880 | "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.2.tgz", 2881 | "integrity": "sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ==", 2882 | "dev": true, 2883 | "dependencies": { 2884 | "define-data-property": "^1.1.4", 2885 | "es-errors": "^1.3.0", 2886 | "functions-have-names": "^1.2.3", 2887 | "has-property-descriptors": "^1.0.2" 2888 | }, 2889 | "engines": { 2890 | "node": ">= 0.4" 2891 | } 2892 | }, 2893 | "node_modules/shebang-command": { 2894 | "version": "2.0.0", 2895 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2896 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2897 | "dev": true, 2898 | "dependencies": { 2899 | "shebang-regex": "^3.0.0" 2900 | }, 2901 | "engines": { 2902 | "node": ">=8" 2903 | } 2904 | }, 2905 | "node_modules/shebang-regex": { 2906 | "version": "3.0.0", 2907 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2908 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2909 | "dev": true, 2910 | "engines": { 2911 | "node": ">=8" 2912 | } 2913 | }, 2914 | "node_modules/side-channel": { 2915 | "version": "1.0.5", 2916 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.5.tgz", 2917 | "integrity": "sha512-QcgiIWV4WV7qWExbN5llt6frQB/lBven9pqliLXfGPB+K9ZYXxDozp0wLkHS24kWCm+6YXH/f0HhnObZnZOBnQ==", 2918 | "dev": true, 2919 | "dependencies": { 2920 | "call-bind": "^1.0.6", 2921 | "es-errors": "^1.3.0", 2922 | "get-intrinsic": "^1.2.4", 2923 | "object-inspect": "^1.13.1" 2924 | }, 2925 | "engines": { 2926 | "node": ">= 0.4" 2927 | }, 2928 | "funding": { 2929 | "url": "https://github.com/sponsors/ljharb" 2930 | } 2931 | }, 2932 | "node_modules/string-width": { 2933 | "version": "4.2.3", 2934 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2935 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2936 | "dev": true, 2937 | "dependencies": { 2938 | "emoji-regex": "^8.0.0", 2939 | "is-fullwidth-code-point": "^3.0.0", 2940 | "strip-ansi": "^6.0.1" 2941 | }, 2942 | "engines": { 2943 | "node": ">=8" 2944 | } 2945 | }, 2946 | "node_modules/string.prototype.trim": { 2947 | "version": "1.2.8", 2948 | "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.8.tgz", 2949 | "integrity": "sha512-lfjY4HcixfQXOfaqCvcBuOIapyaroTXhbkfJN3gcB1OtyupngWK4sEET9Knd0cXd28kTUqu/kHoV4HKSJdnjiQ==", 2950 | "dev": true, 2951 | "dependencies": { 2952 | "call-bind": "^1.0.2", 2953 | "define-properties": "^1.2.0", 2954 | "es-abstract": "^1.22.1" 2955 | }, 2956 | "engines": { 2957 | "node": ">= 0.4" 2958 | }, 2959 | "funding": { 2960 | "url": "https://github.com/sponsors/ljharb" 2961 | } 2962 | }, 2963 | "node_modules/string.prototype.trimend": { 2964 | "version": "1.0.7", 2965 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.7.tgz", 2966 | "integrity": "sha512-Ni79DqeB72ZFq1uH/L6zJ+DKZTkOtPIHovb3YZHQViE+HDouuU4mBrLOLDn5Dde3RF8qw5qVETEjhu9locMLvA==", 2967 | "dev": true, 2968 | "dependencies": { 2969 | "call-bind": "^1.0.2", 2970 | "define-properties": "^1.2.0", 2971 | "es-abstract": "^1.22.1" 2972 | }, 2973 | "funding": { 2974 | "url": "https://github.com/sponsors/ljharb" 2975 | } 2976 | }, 2977 | "node_modules/string.prototype.trimstart": { 2978 | "version": "1.0.7", 2979 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.7.tgz", 2980 | "integrity": "sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg==", 2981 | "dev": true, 2982 | "dependencies": { 2983 | "call-bind": "^1.0.2", 2984 | "define-properties": "^1.2.0", 2985 | "es-abstract": "^1.22.1" 2986 | }, 2987 | "funding": { 2988 | "url": "https://github.com/sponsors/ljharb" 2989 | } 2990 | }, 2991 | "node_modules/strip-ansi": { 2992 | "version": "6.0.1", 2993 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2994 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2995 | "dev": true, 2996 | "dependencies": { 2997 | "ansi-regex": "^5.0.1" 2998 | }, 2999 | "engines": { 3000 | "node": ">=8" 3001 | } 3002 | }, 3003 | "node_modules/strip-bom": { 3004 | "version": "3.0.0", 3005 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 3006 | "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", 3007 | "dev": true, 3008 | "engines": { 3009 | "node": ">=4" 3010 | } 3011 | }, 3012 | "node_modules/strip-json-comments": { 3013 | "version": "3.1.1", 3014 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3015 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3016 | "dev": true, 3017 | "engines": { 3018 | "node": ">=8" 3019 | }, 3020 | "funding": { 3021 | "url": "https://github.com/sponsors/sindresorhus" 3022 | } 3023 | }, 3024 | "node_modules/supports-color": { 3025 | "version": "7.2.0", 3026 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 3027 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 3028 | "dev": true, 3029 | "dependencies": { 3030 | "has-flag": "^4.0.0" 3031 | }, 3032 | "engines": { 3033 | "node": ">=8" 3034 | } 3035 | }, 3036 | "node_modules/supports-preserve-symlinks-flag": { 3037 | "version": "1.0.0", 3038 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 3039 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 3040 | "dev": true, 3041 | "engines": { 3042 | "node": ">= 0.4" 3043 | }, 3044 | "funding": { 3045 | "url": "https://github.com/sponsors/ljharb" 3046 | } 3047 | }, 3048 | "node_modules/text-table": { 3049 | "version": "0.2.0", 3050 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3051 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 3052 | "dev": true 3053 | }, 3054 | "node_modules/to-regex-range": { 3055 | "version": "5.0.1", 3056 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3057 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3058 | "dev": true, 3059 | "dependencies": { 3060 | "is-number": "^7.0.0" 3061 | }, 3062 | "engines": { 3063 | "node": ">=8.0" 3064 | } 3065 | }, 3066 | "node_modules/tsconfig-paths": { 3067 | "version": "3.15.0", 3068 | "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.15.0.tgz", 3069 | "integrity": "sha512-2Ac2RgzDe/cn48GvOe3M+o82pEFewD3UPbyoUHHdKasHwJKjds4fLXWf/Ux5kATBKN20oaFGu+jbElp1pos0mg==", 3070 | "dev": true, 3071 | "dependencies": { 3072 | "@types/json5": "^0.0.29", 3073 | "json5": "^1.0.2", 3074 | "minimist": "^1.2.6", 3075 | "strip-bom": "^3.0.0" 3076 | } 3077 | }, 3078 | "node_modules/type-check": { 3079 | "version": "0.4.0", 3080 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 3081 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 3082 | "dev": true, 3083 | "dependencies": { 3084 | "prelude-ls": "^1.2.1" 3085 | }, 3086 | "engines": { 3087 | "node": ">= 0.8.0" 3088 | } 3089 | }, 3090 | "node_modules/type-fest": { 3091 | "version": "0.20.2", 3092 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 3093 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 3094 | "dev": true, 3095 | "engines": { 3096 | "node": ">=10" 3097 | }, 3098 | "funding": { 3099 | "url": "https://github.com/sponsors/sindresorhus" 3100 | } 3101 | }, 3102 | "node_modules/typed-array-buffer": { 3103 | "version": "1.0.2", 3104 | "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.2.tgz", 3105 | "integrity": "sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ==", 3106 | "dev": true, 3107 | "dependencies": { 3108 | "call-bind": "^1.0.7", 3109 | "es-errors": "^1.3.0", 3110 | "is-typed-array": "^1.1.13" 3111 | }, 3112 | "engines": { 3113 | "node": ">= 0.4" 3114 | } 3115 | }, 3116 | "node_modules/typed-array-byte-length": { 3117 | "version": "1.0.1", 3118 | "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.1.tgz", 3119 | "integrity": "sha512-3iMJ9q0ao7WE9tWcaYKIptkNBuOIcZCCT0d4MRvuuH88fEoEH62IuQe0OtraD3ebQEoTRk8XCBoknUNc1Y67pw==", 3120 | "dev": true, 3121 | "dependencies": { 3122 | "call-bind": "^1.0.7", 3123 | "for-each": "^0.3.3", 3124 | "gopd": "^1.0.1", 3125 | "has-proto": "^1.0.3", 3126 | "is-typed-array": "^1.1.13" 3127 | }, 3128 | "engines": { 3129 | "node": ">= 0.4" 3130 | }, 3131 | "funding": { 3132 | "url": "https://github.com/sponsors/ljharb" 3133 | } 3134 | }, 3135 | "node_modules/typed-array-byte-offset": { 3136 | "version": "1.0.2", 3137 | "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.2.tgz", 3138 | "integrity": "sha512-Ous0vodHa56FviZucS2E63zkgtgrACj7omjwd/8lTEMEPFFyjfixMZ1ZXenpgCFBBt4EC1J2XsyVS2gkG0eTFA==", 3139 | "dev": true, 3140 | "dependencies": { 3141 | "available-typed-arrays": "^1.0.7", 3142 | "call-bind": "^1.0.7", 3143 | "for-each": "^0.3.3", 3144 | "gopd": "^1.0.1", 3145 | "has-proto": "^1.0.3", 3146 | "is-typed-array": "^1.1.13" 3147 | }, 3148 | "engines": { 3149 | "node": ">= 0.4" 3150 | }, 3151 | "funding": { 3152 | "url": "https://github.com/sponsors/ljharb" 3153 | } 3154 | }, 3155 | "node_modules/typed-array-length": { 3156 | "version": "1.0.5", 3157 | "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.5.tgz", 3158 | "integrity": "sha512-yMi0PlwuznKHxKmcpoOdeLwxBoVPkqZxd7q2FgMkmD3bNwvF5VW0+UlUQ1k1vmktTu4Yu13Q0RIxEP8+B+wloA==", 3159 | "dev": true, 3160 | "dependencies": { 3161 | "call-bind": "^1.0.7", 3162 | "for-each": "^0.3.3", 3163 | "gopd": "^1.0.1", 3164 | "has-proto": "^1.0.3", 3165 | "is-typed-array": "^1.1.13", 3166 | "possible-typed-array-names": "^1.0.0" 3167 | }, 3168 | "engines": { 3169 | "node": ">= 0.4" 3170 | }, 3171 | "funding": { 3172 | "url": "https://github.com/sponsors/ljharb" 3173 | } 3174 | }, 3175 | "node_modules/typedescriptor": { 3176 | "version": "4.0.13", 3177 | "resolved": "https://registry.npmjs.org/typedescriptor/-/typedescriptor-4.0.13.tgz", 3178 | "integrity": "sha512-k2+oyaiwBsf1YT+7NaSR/cza4ifVU+6/1sgKincN3XoEBsG33uYsEjsbHiczGrNagd3uNybgZliakOlPFOEsfg==", 3179 | "dev": true, 3180 | "dependencies": { 3181 | "defekt": "9.1.0" 3182 | } 3183 | }, 3184 | "node_modules/unbox-primitive": { 3185 | "version": "1.0.2", 3186 | "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", 3187 | "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", 3188 | "dev": true, 3189 | "dependencies": { 3190 | "call-bind": "^1.0.2", 3191 | "has-bigints": "^1.0.2", 3192 | "has-symbols": "^1.0.3", 3193 | "which-boxed-primitive": "^1.0.2" 3194 | }, 3195 | "funding": { 3196 | "url": "https://github.com/sponsors/ljharb" 3197 | } 3198 | }, 3199 | "node_modules/underscore": { 3200 | "version": "1.13.6", 3201 | "resolved": "https://registry.npmjs.org/underscore/-/underscore-1.13.6.tgz", 3202 | "integrity": "sha512-+A5Sja4HP1M08MaXya7p5LvjuM7K6q/2EaC0+iovj/wOcMsTzMvDFbasi/oSapiwOlt252IqsKqPjCl7huKS0A==", 3203 | "dev": true 3204 | }, 3205 | "node_modules/uri-js": { 3206 | "version": "4.4.1", 3207 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 3208 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 3209 | "dev": true, 3210 | "dependencies": { 3211 | "punycode": "^2.1.0" 3212 | } 3213 | }, 3214 | "node_modules/uuid": { 3215 | "version": "8.3.2", 3216 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", 3217 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", 3218 | "dev": true, 3219 | "bin": { 3220 | "uuid": "dist/bin/uuid" 3221 | } 3222 | }, 3223 | "node_modules/which": { 3224 | "version": "2.0.2", 3225 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3226 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3227 | "dev": true, 3228 | "dependencies": { 3229 | "isexe": "^2.0.0" 3230 | }, 3231 | "bin": { 3232 | "node-which": "bin/node-which" 3233 | }, 3234 | "engines": { 3235 | "node": ">= 8" 3236 | } 3237 | }, 3238 | "node_modules/which-boxed-primitive": { 3239 | "version": "1.0.2", 3240 | "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", 3241 | "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", 3242 | "dev": true, 3243 | "dependencies": { 3244 | "is-bigint": "^1.0.1", 3245 | "is-boolean-object": "^1.1.0", 3246 | "is-number-object": "^1.0.4", 3247 | "is-string": "^1.0.5", 3248 | "is-symbol": "^1.0.3" 3249 | }, 3250 | "funding": { 3251 | "url": "https://github.com/sponsors/ljharb" 3252 | } 3253 | }, 3254 | "node_modules/which-typed-array": { 3255 | "version": "1.1.14", 3256 | "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.14.tgz", 3257 | "integrity": "sha512-VnXFiIW8yNn9kIHN88xvZ4yOWchftKDsRJ8fEPacX/wl1lOvBrhsJ/OeJCXq7B0AaijRuqgzSKalJoPk+D8MPg==", 3258 | "dev": true, 3259 | "dependencies": { 3260 | "available-typed-arrays": "^1.0.6", 3261 | "call-bind": "^1.0.5", 3262 | "for-each": "^0.3.3", 3263 | "gopd": "^1.0.1", 3264 | "has-tostringtag": "^1.0.1" 3265 | }, 3266 | "engines": { 3267 | "node": ">= 0.4" 3268 | }, 3269 | "funding": { 3270 | "url": "https://github.com/sponsors/ljharb" 3271 | } 3272 | }, 3273 | "node_modules/workerpool": { 3274 | "version": "6.2.1", 3275 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.2.1.tgz", 3276 | "integrity": "sha512-ILEIE97kDZvF9Wb9f6h5aXK4swSlKGUcOEGiIYb2OOu/IrDU9iwj0fD//SsA6E5ibwJxpEvhullJY4Sl4GcpAw==", 3277 | "dev": true 3278 | }, 3279 | "node_modules/wrap-ansi": { 3280 | "version": "7.0.0", 3281 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3282 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3283 | "dev": true, 3284 | "dependencies": { 3285 | "ansi-styles": "^4.0.0", 3286 | "string-width": "^4.1.0", 3287 | "strip-ansi": "^6.0.0" 3288 | }, 3289 | "engines": { 3290 | "node": ">=10" 3291 | }, 3292 | "funding": { 3293 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 3294 | } 3295 | }, 3296 | "node_modules/wrappy": { 3297 | "version": "1.0.2", 3298 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3299 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 3300 | "dev": true 3301 | }, 3302 | "node_modules/y18n": { 3303 | "version": "5.0.8", 3304 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 3305 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 3306 | "dev": true, 3307 | "engines": { 3308 | "node": ">=10" 3309 | } 3310 | }, 3311 | "node_modules/yallist": { 3312 | "version": "4.0.0", 3313 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3314 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 3315 | "dev": true, 3316 | "peer": true 3317 | }, 3318 | "node_modules/yargs": { 3319 | "version": "16.2.0", 3320 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 3321 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 3322 | "dev": true, 3323 | "dependencies": { 3324 | "cliui": "^7.0.2", 3325 | "escalade": "^3.1.1", 3326 | "get-caller-file": "^2.0.5", 3327 | "require-directory": "^2.1.1", 3328 | "string-width": "^4.2.0", 3329 | "y18n": "^5.0.5", 3330 | "yargs-parser": "^20.2.2" 3331 | }, 3332 | "engines": { 3333 | "node": ">=10" 3334 | } 3335 | }, 3336 | "node_modules/yargs-parser": { 3337 | "version": "20.2.4", 3338 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 3339 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 3340 | "dev": true, 3341 | "engines": { 3342 | "node": ">=10" 3343 | } 3344 | }, 3345 | "node_modules/yargs-unparser": { 3346 | "version": "2.0.0", 3347 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 3348 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 3349 | "dev": true, 3350 | "dependencies": { 3351 | "camelcase": "^6.0.0", 3352 | "decamelize": "^4.0.0", 3353 | "flat": "^5.0.2", 3354 | "is-plain-obj": "^2.1.0" 3355 | }, 3356 | "engines": { 3357 | "node": ">=10" 3358 | } 3359 | }, 3360 | "node_modules/yocto-queue": { 3361 | "version": "0.1.0", 3362 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 3363 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 3364 | "dev": true, 3365 | "engines": { 3366 | "node": ">=10" 3367 | }, 3368 | "funding": { 3369 | "url": "https://github.com/sponsors/sindresorhus" 3370 | } 3371 | } 3372 | } 3373 | } 3374 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "luxtronik2", 3 | "version": "2.7.2", 4 | "description": "Reads and controls heat pumps based on the Luxtronik 2.0 contol unit. Supports for example AlphaInnotec and Siemens Novelan (WRP NET).", 5 | "main": "luxtronik.js", 6 | "dependencies": { 7 | "humanize-duration": "^3.31.0", 8 | "net": "^1.0.2" 9 | }, 10 | "devDependencies": { 11 | "assertthat": "^6.5.2", 12 | "eslint": "^8.57.0", 13 | "eslint-config-standard": "^17.1.0", 14 | "eslint-plugin-import": "^2.29.1", 15 | "eslint-plugin-node": "^11.1.0", 16 | "eslint-plugin-promise": "^6.1.1", 17 | "mitm": "^1.7.2", 18 | "mocha": "^10.3.0" 19 | }, 20 | "scripts": { 21 | "start": "node example.js", 22 | "test": "npx mocha", 23 | "lint": "npx eslint ." 24 | }, 25 | "repository": { 26 | "type": "git", 27 | "url": "git+https://github.com/coolchip/luxtronik2.git" 28 | }, 29 | "keywords": [ 30 | "luxtronik", 31 | "luxtronik2", 32 | "alpha", 33 | "innotec", 34 | "novelan", 35 | "thermoaura", 36 | "thermotech", 37 | "elco" 38 | ], 39 | "author": "Sebastian B.", 40 | "license": "MIT", 41 | "bugs": { 42 | "url": "https://github.com/coolchip/luxtronik2/issues" 43 | }, 44 | "homepage": "https://github.com/coolchip/luxtronik2#readme" 45 | } 46 | -------------------------------------------------------------------------------- /test/data/3003: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/coolchip/luxtronik2/c00e99cf93d2ee5c649d7eaebc84fa472bc1a2d3/test/data/3003 -------------------------------------------------------------------------------- /test/data/3004: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/coolchip/luxtronik2/c00e99cf93d2ee5c649d7eaebc84fa472bc1a2d3/test/data/3004 -------------------------------------------------------------------------------- /test/data/3005: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/coolchip/luxtronik2/c00e99cf93d2ee5c649d7eaebc84fa472bc1a2d3/test/data/3005 -------------------------------------------------------------------------------- /test/luxtronikTest.js: -------------------------------------------------------------------------------- 1 | // 'use strict'; 2 | 3 | // const fs = require('fs'); 4 | // const path = require('path'); 5 | 6 | // const { assert } = require('assertthat'); 7 | // const mitm = require('mitm')(); 8 | 9 | // const luxtronik = require('../luxtronik'); 10 | 11 | // let receiveDataBuffer = []; 12 | 13 | // mitm.on('connection', function (socket) { 14 | // socket.on('data', function (data) { 15 | // const recvSym = data.readInt32BE(0); 16 | // if (recvSym === 0) { 17 | // const command = receiveDataBuffer.pop(); 18 | // const dataFile = path.join(__dirname, 'data', command.toString()); 19 | // fs.readFile(dataFile, function (err, data) { 20 | // if (!err) { 21 | // socket.write(data); 22 | // } 23 | // }); 24 | // receiveDataBuffer = []; 25 | // } else { 26 | // receiveDataBuffer.push(recvSym); 27 | // } 28 | // }); 29 | // }); 30 | 31 | // suite('Mocha tests', () => { 32 | // suite('Luxtronik', () => { 33 | // test('is an object.', done => { 34 | // assert.that(luxtronik).is.ofType('object'); 35 | // done(); 36 | // }); 37 | 38 | // test('createConnection() function returns an object.', done => { 39 | // assert.that(luxtronik.createConnection()).is.ofType('object'); 40 | // done(); 41 | // }); 42 | 43 | // test('connection has function read.', done => { 44 | // assert.that(luxtronik.createConnection().read).is.ofType('function'); 45 | // done(); 46 | // }); 47 | 48 | // test('connection has function write.', done => { 49 | // assert.that(luxtronik.createConnection().write).is.ofType('function'); 50 | // done(); 51 | // }); 52 | // }); 53 | 54 | // /* suite('Luxtronik pump', () => { 55 | // const pump = luxtronik.createConnection('127.0.0.1', 8888); 56 | // test('read returns data.', done => { 57 | // pump.read(function (err, data) { 58 | // assert.that(err).is.null(); 59 | // assert.that(data).is.ofType('object'); 60 | // assert.that(data.values).is.ofType('object'); 61 | // assert.that(data.parameters).is.ofType('object'); 62 | // done(); 63 | // }); 64 | // }); 65 | // });*/ 66 | // }); 67 | -------------------------------------------------------------------------------- /test/mocha.opts: -------------------------------------------------------------------------------- 1 | ./test 2 | --async-only 3 | --colors 4 | --reporter spec 5 | --ui tdd 6 | -------------------------------------------------------------------------------- /types.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | module.exports = { 4 | operatingModes: Object.freeze({ 5 | 0: 'Automatik', 6 | 1: 'Zusatzheizung', 7 | 2: 'Party', 8 | 3: 'Ferien', 9 | 4: 'Aus', 10 | }), 11 | 12 | stateMessages: Object.freeze({ 13 | 0: 'Waermepumpe laeuft', 14 | 1: 'Waermepumpe steht', 15 | 2: 'Waermepumpe kommt', 16 | 4: 'Fehler', 17 | 5: 'Abtauen', 18 | 7: 'Verdichter heizt auf', 19 | 8: 'Pumpenvorlauf', 20 | }), 21 | 22 | extendetStateMessages: Object.freeze({ 23 | 0: 'Heizbetrieb', 24 | 1: 'Keine Anforderung', 25 | 2: 'Netz Einschaltverzoegerung', 26 | 3: 'Schaltspielzeit', 27 | 4: 'EVU Sperrzeit', 28 | 5: 'Brauchwasser', 29 | 6: 'Estrich Programm', 30 | 7: 'Abtauen', 31 | 8: 'Pumpenvorlauf', 32 | 9: 'Thermische Desinfektion', 33 | 10: 'Kuehlbetrieb', 34 | 12: 'Schwimmbad/Photovoltaik', 35 | 13: 'Heizen Ext.', 36 | 14: 'Brauchwasser Ext.', 37 | 16: 'Durchflussueberwachung', 38 | 17: 'Elektrische Zusatzheizung', 39 | 19: 'Warmw. Nachheizung', 40 | }), 41 | 42 | hpMode: Object.freeze({ 43 | 0: 'Automatik', 44 | 1: 'Zusatzheizung', 45 | 2: 'Party', 46 | 3: 'Ferien', 47 | 4: 'Aus', 48 | }), 49 | 50 | heatingState: Object.freeze({ 51 | 0: 'Abgesenkt', 52 | 1: 'Normal', 53 | 3: 'Aus', 54 | }), 55 | 56 | hpTypes: Object.freeze({ 57 | 0: 'ERC', 58 | 1: 'SW1', 59 | 2: 'SW2', 60 | 3: 'WW1', 61 | 4: 'WW2', 62 | 5: 'L1I', 63 | 6: 'L2I', 64 | 7: 'L1A', 65 | 8: 'L2A', 66 | 9: 'KSW', 67 | 10: 'KLW', 68 | 11: 'SWC', 69 | 12: 'LWC', 70 | 13: 'L2G', 71 | 14: 'WZS', 72 | 15: 'L1I407', 73 | 16: 'L2I407', 74 | 17: 'L1A407', 75 | 18: 'L2A407', 76 | 19: 'L2G407', 77 | 20: 'LWC407', 78 | 21: 'L1AREV', 79 | 22: 'L2AREV', 80 | 23: 'WWC1', 81 | 24: 'WWC2', 82 | 25: 'L2G404', 83 | 26: 'WZW', 84 | 27: 'L1S', 85 | 28: 'L1H', 86 | 29: 'L2H', 87 | 30: 'WZWD', 88 | 31: 'ERC', 89 | 40: 'WWB_20', 90 | 41: 'LD5', 91 | 42: 'LD7', 92 | 43: 'SW 37_45', 93 | 44: 'SW 58_69', 94 | 45: 'SW 29_56', 95 | 46: 'LD5 (230V)', 96 | 47: 'LD7 (230 V)', 97 | 48: 'LD9', 98 | 49: 'LD5 REV', 99 | 50: 'LD7 REV', 100 | 51: 'LD5 REV 230V', 101 | 52: 'LD7 REV 230V', 102 | 53: 'LD9 REV 230V', 103 | 54: 'SW 291', 104 | 55: 'LW SEC', 105 | 56: 'HMD 2', 106 | 57: 'MSW 4', 107 | 58: 'MSW 6', 108 | 59: 'MSW 8', 109 | 60: 'MSW 10', 110 | 61: 'MSW 12', 111 | 62: 'MSW 14', 112 | 63: 'MSW 17', 113 | 64: 'MSW 19', 114 | 65: 'MSW 23', 115 | 66: 'MSW 26', 116 | 67: 'MSW 30', 117 | 68: 'MSW 4S', 118 | 69: 'MSW 6S', 119 | 70: 'MSW 8S', 120 | 71: 'MSW 10S', 121 | 72: 'MSW 13S', 122 | 73: 'MSW 16S', 123 | 74: 'MSW2-6S', 124 | 75: 'MSW4-16', 125 | 76: 'LD2AG', 126 | 77: 'LWD90V', 127 | 78: 'MSW3-12', 128 | 79: 'MSW3-12S', 129 | '-1': 'Unbekannter Typ', 130 | }), 131 | 132 | timerTableTypes: Object.freeze({ 133 | 0: 'Woche (Mo-So)', 134 | 1: '5+2 (Mo-Fr, Sa-So)', 135 | 2: 'Tage (Mo, Di, ...)', 136 | }), 137 | 138 | errorCodes: Object.freeze({ 139 | 701: 'Niederdruckstoerung - Bitte Inst. rufen', 140 | 702: 'Niederdrucksperre - RESET automatisch', 141 | 703: 'Frostschutz - Bitte Inst. rufen', 142 | 704: 'Heissgasstoerung - Reset in hh:mm', 143 | 705: 'Motorschutz VEN - Bitte Inst. rufen', 144 | 706: 'Motorschutz BSUP - Bitte Inst. rufen', 145 | 707: 'Codierung WP - Bitte Inst. rufen', 146 | 708: 'Fuehler Ruecklauf - Bitte Inst. rufen', 147 | 709: 'Fuehler Vorlauf - Bitte Inst. rufen', 148 | 710: 'Fuehler Heissgas - Bitte Inst. rufen', 149 | 711: 'Fuehler Aussentemp. - Bitte Inst. rufen', 150 | 712: 'Fuehler Warmwasser - Bitte Inst. rufen', 151 | 713: 'Fuehler WQ-Ein - Bitte Inst. rufen', 152 | 714: 'Heissgas WW - Reset in hh:mm', 153 | 715: 'Hochdruck-Abschalt. - RESET automatisch', 154 | 716: 'Hochdruckstoerung - Bitte Inst rufen', 155 | 717: 'Durchfluss-WQ - Bitte Inst. rufen', 156 | 718: 'Max. Aussentemp. - RESET automatisch', 157 | 719: 'Min. Aussentemp. - RESET automatisch', 158 | 720: 'WQ-Temperatur - RESET automatisch in hh:mm', 159 | 721: 'Niederdruckabschaltung - RESET automatisch', 160 | 722: 'Tempdiff Heizwasser - Bitte Inst. rufen', 161 | 723: 'Tempdiff Warmwasser - Bitte Inst. rufen', 162 | 724: 'Tempdiff Abtauen - Bitte Inst. rufen', 163 | 725: 'Anlagefehler WW - Bitte Inst. rufen', 164 | 726: 'Fuehler Mischkreis 1 - Bitte Inst. rufen', 165 | 727: 'Soledruck - Bitte Inst. rufen', 166 | 728: 'Fuehler WQ-Aus - Bitte Inst. rufen', 167 | 729: 'Drehfeldfehler - Bitte Inst. rufen', 168 | 730: 'Leistung Ausheizen - Bitte Inst. rufen', 169 | 732: 'Stoerung Kuehlung - Bitte Inst. rufen', 170 | 733: 'Stoerung Anode - Bitte Inst. rufen', 171 | 734: 'Stoerung Anode - Bitte Inst. rufen', 172 | 735: 'Fuehler Ext. Energiequelle - Bitte Inst. rufen', 173 | 736: 'Fuehler Solarkollektor - Bitte Inst. rufen', 174 | 737: 'Fuehler Solarspeicher - Bitte Inst. rufen', 175 | 738: 'Fuehler Mischkreis2 - Bitte Inst. rufen', 176 | 750: 'Fuehler Ruecklauf extern - Bitte Inst. rufen', 177 | 751: 'Phasenueberwachungsfehler', 178 | 752: 'Phasenueberwachungs / Durchflussfehler', 179 | 755: 'Verbindung zu Slave verloren - Bitte Inst. rufen', 180 | 756: 'Verbindung zu Master verloren - Bitte Inst. rufen', 181 | 757: 'ND-Stoerung bei WW-Geraet', 182 | 758: 'Stoerung Abtauung', 183 | 759: 'Meldung TDI', 184 | 760: 'Stoerung Abtauung', 185 | 761: 'LIN-Verbindung unterbrochen', 186 | 762: 'Fuehler Ansaug-Verdichter', 187 | 763: 'Fuehler Ansaug-Verdampfer', 188 | 764: 'Fuehler Verdichterheizung', 189 | 765: 'Ueberhitzung', 190 | 766: 'Einsatzgrenzen-VD', 191 | 767: 'STB E-Stab', 192 | 770: 'Niedrige Ueberhitzung', 193 | 771: 'Hohe Ueberhitzung', 194 | 776: 'Einsatzgrenzen-VD', 195 | 777: 'Expansionsventil', 196 | 778: 'Fuehler Niederdruck', 197 | 779: 'Fuehler Hochdruck', 198 | 780: 'Fuehler EVI', 199 | 781: 'Fuehler Fluessig, vor Ex-Ventil', 200 | 782: 'Fuehler EVI Sauggas', 201 | 783: 'Kommunikation SEC-Inverter', 202 | 784: 'VSS gesperrt', 203 | 785: 'SEC-Board defekt', 204 | 786: 'Kommunikation SEC-Inverter', 205 | 787: 'VD Alarm', 206 | 788: 'Schwerw. Inverter Fehler', 207 | 789: 'LIN/Kodierung nicht vorhanden', 208 | 790: 'Schwerw. Inverter Fehler', 209 | 791: 'ModBus Verbindung verloren', 210 | 792: 'LIN-Verbindung unterbrochen', 211 | 793: 'Schwerw. Inverter Fehler', 212 | '-1': 'Unbekannter Fehler', 213 | }), 214 | 215 | outageCodes: Object.freeze({ 216 | 0: 'Waermepumpe Stoerung', 217 | 1: 'Anlagen Stoerung', 218 | 2: 'Betriebsart Zweiter Waermeerzeuger', 219 | 3: 'EVU-Sperre', 220 | 4: '', 221 | 5: 'Lauftabtau (nur LW-Geraete)', 222 | 6: 'Temperatur Einsatzgrenze maximal', 223 | 7: 'Temperatur Einsatzgrenze minimal', 224 | 8: 'Untere Einsatzgrenze', 225 | 9: 'Keine Anforderung', 226 | '-1': 'Unbekannte Abschaltung', 227 | }), 228 | }; 229 | -------------------------------------------------------------------------------- /utils.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const humanizeduration = require('humanize-duration'); 4 | const huminizeoptions = { 5 | language: 'de', 6 | conjunction: ' und ', 7 | serialComma: false, 8 | }; 9 | 10 | const types = require('./types'); 11 | 12 | function createFirmwareString(buf) { 13 | let firmware = ''; 14 | for (const key in buf) { 15 | if ({}.hasOwnProperty.call(buf, key)) { 16 | firmware += buf[key] === 0 ? '' : String.fromCharCode(buf[key]); 17 | } 18 | } 19 | return firmware; 20 | } 21 | 22 | function int2ipAddress(value) { 23 | const part1 = value & 255; 24 | const part2 = (value >> 8) & 255; 25 | const part3 = (value >> 16) & 255; 26 | const part4 = (value >> 24) & 255; 27 | return part4 + '.' + part3 + '.' + part2 + '.' + part1; 28 | } 29 | 30 | function createStateString(values) { 31 | let stateStr = ''; 32 | const state1 = values[117]; 33 | const state2 = values[118]; 34 | const duration = values[120]; 35 | 36 | // Text aus Define 37 | if (Object.prototype.hasOwnProperty.call(types.stateMessages, state1)) { 38 | stateStr = types.stateMessages[state1]; 39 | if (state2 === 0 || state2 === 2) { 40 | stateStr += ' seit '; 41 | } else if (state2 === 1) { 42 | stateStr += ' in '; 43 | } 44 | 45 | // Sonderbehandlung bei WP-Fehlern - Zeitstempel des zuletzt aufgetretenen Fehlers nehmen 46 | if (state2 === 2) { 47 | stateStr += new Date(values[95] * 1000).toString(); 48 | } else { 49 | stateStr += humanizeduration(duration * 1000, huminizeoptions); 50 | } 51 | } else { 52 | stateStr = 'Unknown [' + state1 + ']'; 53 | } 54 | return stateStr; 55 | } 56 | 57 | function createExtendedStateString(values) { 58 | let stateStr = ''; 59 | const defrostValve = values[37]; 60 | const heatSourceMotor = values[43]; 61 | const compressor1 = values[44]; 62 | const state3 = values[119]; 63 | const ahpStufe = values[121]; 64 | const ahpTemp = values[122] / 10; 65 | 66 | if (Object.prototype.hasOwnProperty.call(types.extendetStateMessages, state3)) { 67 | stateStr = types.extendetStateMessages[state3]; 68 | if (state3 === 6) { 69 | // Estrich Programm 70 | stateStr += ' Stufe ' + ahpStufe + ' - ' + ahpTemp + ' °C'; 71 | } else if (state3 === 7) { 72 | // Abtauen 73 | if (defrostValve === 1) { 74 | stateStr += 'Abtauen (Kreisumkehr)'; 75 | } else if (compressor1 === 0 && heatSourceMotor === 1) { 76 | stateStr += 'Luftabtauen'; 77 | } else { 78 | stateStr += 'Abtauen'; 79 | } 80 | } 81 | } else { 82 | stateStr = 'Unknown [' + state3 + ']'; 83 | } 84 | return stateStr; 85 | } 86 | 87 | function createOperationStateString(state) { 88 | let stateStr = ''; 89 | if (Object.prototype.hasOwnProperty.call(types.hpMode, state)) { 90 | stateStr = types.hpMode[state]; 91 | } else { 92 | stateStr = 'Unknown [' + state + ']'; 93 | } 94 | return stateStr; 95 | } 96 | 97 | function createHotWaterStateString(values) { 98 | let stateStr = ''; 99 | const hotWaterBoilerValve = values[38]; 100 | const opStateHotWater = values[124]; 101 | if (opStateHotWater === 0) { 102 | stateStr = 'Sperrzeit'; 103 | } else if (opStateHotWater === 1 && hotWaterBoilerValve === 1) { 104 | stateStr = 'Aufheizen'; 105 | } else if (opStateHotWater === 1 && hotWaterBoilerValve === 0) { 106 | stateStr = 'Temp. OK'; 107 | } else if (opStateHotWater === 3) { 108 | stateStr = 'Aus'; 109 | } else { 110 | stateStr = 'Unknown [' + opStateHotWater + '/' + hotWaterBoilerValve + ']'; 111 | } 112 | return stateStr; 113 | } 114 | 115 | function createCode(time, code, codeTypes) { 116 | return { 117 | code, 118 | date: new Date(time * 1000), 119 | message: Object.prototype.hasOwnProperty.call(codeTypes, code) ? codeTypes[code] : codeTypes[-1], 120 | }; 121 | } 122 | 123 | function createCodeList(timeArray, codeArray, codeTypes) { 124 | const logArray = []; 125 | for (let i = 0; i < timeArray.length; i++) { 126 | logArray.push(createCode(timeArray[i], codeArray[i], codeTypes)); 127 | } 128 | return logArray; 129 | } 130 | 131 | function createOutageCodeList(timeArray, codeArray) { 132 | return createCodeList(timeArray, codeArray, types.outageCodes); 133 | } 134 | 135 | function createErrorCodeList(timeArray, codeArray) { 136 | return createCodeList(timeArray, codeArray, types.errorCodes); 137 | } 138 | 139 | function toInt32ArrayReadBE(buffer) { 140 | const i32a = new Int32Array(buffer.length / 4); 141 | for (let i = 0; i < i32a.length; i++) { 142 | i32a[i] = buffer.readInt32BE(i * 4); 143 | } 144 | return i32a; 145 | } 146 | 147 | function createHeatPumptTypeString(value) { 148 | return Object.prototype.hasOwnProperty.call(types.hpTypes, value) ? types.hpTypes[value] : types.hpTypes[-1]; 149 | } 150 | 151 | function value2LuxtronikSetTemperatureValue(realValue) { 152 | // Allow only integer temperature. Add factor x10. 153 | return parseInt(realValue * 10, 10); 154 | } 155 | 156 | function value2LuxtronikSetHundrethValue(realValue) { 157 | // Allow only integer temperature. Add factor x100. 158 | return parseInt(realValue * 100, 10); 159 | } 160 | 161 | function isValidOperationMode(value) { 162 | return Object.prototype.hasOwnProperty.call(types.hpMode, value.toString()); 163 | } 164 | 165 | function limitRange(value, min, max) { 166 | if (value < min) { 167 | value = min; 168 | } 169 | if (value > max) { 170 | value = max; 171 | } 172 | return value; 173 | } 174 | 175 | function createTimerTableTypeString(value) { 176 | let tableStr = ''; 177 | 178 | if (Object.prototype.hasOwnProperty.call(types.timerTableTypes, value)) { 179 | tableStr = types.timerTableTypes[value]; 180 | } else { 181 | tableStr = 'unbekannt'; 182 | } 183 | 184 | return tableStr; 185 | } 186 | 187 | function secondsToTimeString(value) { 188 | const timeMilliseconds = new Date(value * 1000); 189 | const timeStr = timeMilliseconds.toISOString().substr(11, 5); 190 | return timeStr; 191 | } 192 | 193 | function createTimerTable(parameters, startindex, rows, swapOnOff = false) { 194 | const timerTable = []; 195 | 196 | for (let rowindex = 0; rowindex < rows; rowindex++) { 197 | let onTime = secondsToTimeString(parameters[startindex + rowindex * 2]); 198 | let offTime = secondsToTimeString(parameters[startindex + rowindex * 2 + 1]); 199 | if (swapOnOff === true) { 200 | const tmp = onTime; 201 | onTime = offTime; 202 | offTime = tmp; 203 | } 204 | timerTable.push({ 205 | on: onTime, 206 | off: offTime, 207 | }); 208 | } 209 | 210 | return timerTable; 211 | } 212 | 213 | module.exports = { 214 | createFirmwareString, 215 | int2ipAddress, 216 | createStateString, 217 | createExtendedStateString, 218 | createOperationStateString, 219 | createHotWaterStateString, 220 | createOutageCodeList, 221 | createErrorCodeList, 222 | toInt32ArrayReadBE, 223 | createHeatPumptTypeString, 224 | value2LuxtronikSetTemperatureValue, 225 | value2LuxtronikSetHundrethValue, 226 | isValidOperationMode, 227 | limitRange, 228 | createTimerTableTypeString, 229 | createTimerTable, 230 | }; 231 | --------------------------------------------------------------------------------