├── .gitignore ├── README.md ├── nodemon.json ├── package-lock.json ├── package.json ├── src ├── StyleTool.ts └── index.ts └── tsconfig.json /.gitignore: -------------------------------------------------------------------------------- 1 | .env 2 | build 3 | node_modules 4 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Langchain agent style tool 2 | 3 | Explore the power of AI in web design with Langchain JS. This repository contains the StyleExtractorTool, a unique AI tool that fetches and processes CSS styles from any webpage, empowering AI agents to create webpages with styles inspired by your favorite sites. Used in conjunction with JSDOM, this tool exemplifies the exciting intersection of AI and web development. Dive into the code, examples, and resources to start building your own AI-powered web projects today! 4 | 5 | ## Install dependencies 6 | 7 | ```bash 8 | npm install 9 | ``` 10 | 11 | ## Run locally 12 | 13 | ```bash 14 | npm run start:dev 15 | ``` 16 | -------------------------------------------------------------------------------- /nodemon.json: -------------------------------------------------------------------------------- 1 | { 2 | "watch": ["src"], 3 | "ext": ".ts,.js", 4 | "ignore": [], 5 | "exec": "npx ts-node ./src/index.ts" 6 | } -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "test-web-langchain", 3 | "version": "1.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "test-web-langchain", 9 | "version": "1.0.0", 10 | "license": "ISC", 11 | "dependencies": { 12 | "axios": "^1.4.0", 13 | "cheerio": "^1.0.0-rc.12", 14 | "dotenv": "^16.0.3", 15 | "jsdom": "^22.1.0", 16 | "langchain": "^0.0.84" 17 | }, 18 | "devDependencies": { 19 | "@types/jsdom": "^21.1.1", 20 | "@types/node": "^20.2.5", 21 | "nodemon": "^2.0.22", 22 | "ts-node": "^10.9.1", 23 | "typescript": "^5.0.4" 24 | } 25 | }, 26 | "node_modules/@anthropic-ai/sdk": { 27 | "version": "0.4.3", 28 | "resolved": "https://registry.npmjs.org/@anthropic-ai/sdk/-/sdk-0.4.3.tgz", 29 | "integrity": "sha512-SZrlXvjUUYT9rPmSzlTtmVk1OjVNpkCzILRluhiYwNcxXfQyvPJDi0CI6PyymygcgtqEF5EVqhKmC/PtPsNEIw==", 30 | "dependencies": { 31 | "@fortaine/fetch-event-source": "^3.0.6", 32 | "cross-fetch": "^3.1.5" 33 | } 34 | }, 35 | "node_modules/@cspotcode/source-map-support": { 36 | "version": "0.8.1", 37 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz", 38 | "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==", 39 | "dev": true, 40 | "dependencies": { 41 | "@jridgewell/trace-mapping": "0.3.9" 42 | }, 43 | "engines": { 44 | "node": ">=12" 45 | } 46 | }, 47 | "node_modules/@fortaine/fetch-event-source": { 48 | "version": "3.0.6", 49 | "resolved": "https://registry.npmjs.org/@fortaine/fetch-event-source/-/fetch-event-source-3.0.6.tgz", 50 | "integrity": "sha512-621GAuLMvKtyZQ3IA6nlDWhV1V/7PGOTNIGLUifxt0KzM+dZIweJ6F3XvQF3QnqeNfS1N7WQ0Kil1Di/lhChEw==", 51 | "engines": { 52 | "node": ">=16.15" 53 | } 54 | }, 55 | "node_modules/@jridgewell/resolve-uri": { 56 | "version": "3.1.1", 57 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz", 58 | "integrity": "sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA==", 59 | "dev": true, 60 | "engines": { 61 | "node": ">=6.0.0" 62 | } 63 | }, 64 | "node_modules/@jridgewell/sourcemap-codec": { 65 | "version": "1.4.15", 66 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 67 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 68 | "dev": true 69 | }, 70 | "node_modules/@jridgewell/trace-mapping": { 71 | "version": "0.3.9", 72 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz", 73 | "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==", 74 | "dev": true, 75 | "dependencies": { 76 | "@jridgewell/resolve-uri": "^3.0.3", 77 | "@jridgewell/sourcemap-codec": "^1.4.10" 78 | } 79 | }, 80 | "node_modules/@tootallnate/once": { 81 | "version": "2.0.0", 82 | "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-2.0.0.tgz", 83 | "integrity": "sha512-XCuKFP5PS55gnMVu3dty8KPatLqUoy/ZYzDzAGCQ8JNFCkLXzmI7vNHCR+XpbZaMWQK/vQubr7PkYq8g470J/A==", 84 | "engines": { 85 | "node": ">= 10" 86 | } 87 | }, 88 | "node_modules/@tsconfig/node10": { 89 | "version": "1.0.9", 90 | "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.9.tgz", 91 | "integrity": "sha512-jNsYVVxU8v5g43Erja32laIDHXeoNvFEpX33OK4d6hljo3jDhCBDhx5dhCCTMWUojscpAagGiRkBKxpdl9fxqA==", 92 | "dev": true 93 | }, 94 | "node_modules/@tsconfig/node12": { 95 | "version": "1.0.11", 96 | "resolved": "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.11.tgz", 97 | "integrity": "sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag==", 98 | "dev": true 99 | }, 100 | "node_modules/@tsconfig/node14": { 101 | "version": "1.0.3", 102 | "resolved": "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.3.tgz", 103 | "integrity": "sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow==", 104 | "dev": true 105 | }, 106 | "node_modules/@tsconfig/node16": { 107 | "version": "1.0.4", 108 | "resolved": "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.4.tgz", 109 | "integrity": "sha512-vxhUy4J8lyeyinH7Azl1pdd43GJhZH/tP2weN8TntQblOY+A0XbT8DJk1/oCPuOOyg/Ja757rG0CgHcWC8OfMA==", 110 | "dev": true 111 | }, 112 | "node_modules/@types/jsdom": { 113 | "version": "21.1.1", 114 | "resolved": "https://registry.npmjs.org/@types/jsdom/-/jsdom-21.1.1.tgz", 115 | "integrity": "sha512-cZFuoVLtzKP3gmq9eNosUL1R50U+USkbLtUQ1bYVgl/lKp0FZM7Cq4aIHAL8oIvQ17uSHi7jXPtfDOdjPwBE7A==", 116 | "dev": true, 117 | "dependencies": { 118 | "@types/node": "*", 119 | "@types/tough-cookie": "*", 120 | "parse5": "^7.0.0" 121 | } 122 | }, 123 | "node_modules/@types/node": { 124 | "version": "20.2.5", 125 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.2.5.tgz", 126 | "integrity": "sha512-JJulVEQXmiY9Px5axXHeYGLSjhkZEnD+MDPDGbCbIAbMslkKwmygtZFy1X6s/075Yo94sf8GuSlFfPzysQrWZQ==", 127 | "dev": true 128 | }, 129 | "node_modules/@types/retry": { 130 | "version": "0.12.0", 131 | "resolved": "https://registry.npmjs.org/@types/retry/-/retry-0.12.0.tgz", 132 | "integrity": "sha512-wWKOClTTiizcZhXnPY4wikVAwmdYHp8q6DmC+EJUzAMsycb7HB32Kh9RN4+0gExjmPmZSAQjgURXIGATPegAvA==" 133 | }, 134 | "node_modules/@types/tough-cookie": { 135 | "version": "4.0.2", 136 | "resolved": "https://registry.npmjs.org/@types/tough-cookie/-/tough-cookie-4.0.2.tgz", 137 | "integrity": "sha512-Q5vtl1W5ue16D+nIaW8JWebSSraJVlK+EthKn7e7UcD4KWsaSJ8BqGPXNaPghgtcn/fhvrN17Tv8ksUsQpiplw==", 138 | "dev": true 139 | }, 140 | "node_modules/abab": { 141 | "version": "2.0.6", 142 | "resolved": "https://registry.npmjs.org/abab/-/abab-2.0.6.tgz", 143 | "integrity": "sha512-j2afSsaIENvHZN2B8GOpF566vZ5WVk5opAiMTvWgaQT8DkbOqsTfvNAvHoRGU2zzP8cPoqys+xHTRDWW8L+/BA==" 144 | }, 145 | "node_modules/abbrev": { 146 | "version": "1.1.1", 147 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 148 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 149 | "dev": true 150 | }, 151 | "node_modules/acorn": { 152 | "version": "8.8.2", 153 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.8.2.tgz", 154 | "integrity": "sha512-xjIYgE8HBrkpd/sJqOGNspf8uHG+NOHGOw6a/Urj8taM2EXfdNAH2oFcPeIFfsv3+kz/mJrS5VuMqbNLjCa2vw==", 155 | "dev": true, 156 | "bin": { 157 | "acorn": "bin/acorn" 158 | }, 159 | "engines": { 160 | "node": ">=0.4.0" 161 | } 162 | }, 163 | "node_modules/acorn-walk": { 164 | "version": "8.2.0", 165 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", 166 | "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", 167 | "dev": true, 168 | "engines": { 169 | "node": ">=0.4.0" 170 | } 171 | }, 172 | "node_modules/agent-base": { 173 | "version": "6.0.2", 174 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 175 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 176 | "dependencies": { 177 | "debug": "4" 178 | }, 179 | "engines": { 180 | "node": ">= 6.0.0" 181 | } 182 | }, 183 | "node_modules/agent-base/node_modules/debug": { 184 | "version": "4.3.4", 185 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 186 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 187 | "dependencies": { 188 | "ms": "2.1.2" 189 | }, 190 | "engines": { 191 | "node": ">=6.0" 192 | }, 193 | "peerDependenciesMeta": { 194 | "supports-color": { 195 | "optional": true 196 | } 197 | } 198 | }, 199 | "node_modules/agent-base/node_modules/ms": { 200 | "version": "2.1.2", 201 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 202 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 203 | }, 204 | "node_modules/ansi-styles": { 205 | "version": "5.2.0", 206 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", 207 | "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", 208 | "engines": { 209 | "node": ">=10" 210 | }, 211 | "funding": { 212 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 213 | } 214 | }, 215 | "node_modules/anymatch": { 216 | "version": "3.1.3", 217 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 218 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 219 | "dev": true, 220 | "dependencies": { 221 | "normalize-path": "^3.0.0", 222 | "picomatch": "^2.0.4" 223 | }, 224 | "engines": { 225 | "node": ">= 8" 226 | } 227 | }, 228 | "node_modules/arg": { 229 | "version": "4.1.3", 230 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 231 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 232 | "dev": true 233 | }, 234 | "node_modules/asynckit": { 235 | "version": "0.4.0", 236 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 237 | "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" 238 | }, 239 | "node_modules/axios": { 240 | "version": "1.4.0", 241 | "resolved": "https://registry.npmjs.org/axios/-/axios-1.4.0.tgz", 242 | "integrity": "sha512-S4XCWMEmzvo64T9GfvQDOXgYRDJ/wsSZc7Jvdgx5u1sd0JwsuPLqb3SYmusag+edF6ziyMensPVqLTSc1PiSEA==", 243 | "dependencies": { 244 | "follow-redirects": "^1.15.0", 245 | "form-data": "^4.0.0", 246 | "proxy-from-env": "^1.1.0" 247 | } 248 | }, 249 | "node_modules/balanced-match": { 250 | "version": "1.0.2", 251 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 252 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 253 | "dev": true 254 | }, 255 | "node_modules/base64-js": { 256 | "version": "1.5.1", 257 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 258 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", 259 | "funding": [ 260 | { 261 | "type": "github", 262 | "url": "https://github.com/sponsors/feross" 263 | }, 264 | { 265 | "type": "patreon", 266 | "url": "https://www.patreon.com/feross" 267 | }, 268 | { 269 | "type": "consulting", 270 | "url": "https://feross.org/support" 271 | } 272 | ] 273 | }, 274 | "node_modules/binary-extensions": { 275 | "version": "2.2.0", 276 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 277 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 278 | "engines": { 279 | "node": ">=8" 280 | } 281 | }, 282 | "node_modules/binary-search": { 283 | "version": "1.3.6", 284 | "resolved": "https://registry.npmjs.org/binary-search/-/binary-search-1.3.6.tgz", 285 | "integrity": "sha512-nbE1WxOTTrUWIfsfZ4aHGYu5DOuNkbxGokjV6Z2kxfJK3uaAb8zNK1muzOeipoLHZjInT4Br88BHpzevc681xA==" 286 | }, 287 | "node_modules/boolbase": { 288 | "version": "1.0.0", 289 | "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz", 290 | "integrity": "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==" 291 | }, 292 | "node_modules/brace-expansion": { 293 | "version": "1.1.11", 294 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 295 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 296 | "dev": true, 297 | "dependencies": { 298 | "balanced-match": "^1.0.0", 299 | "concat-map": "0.0.1" 300 | } 301 | }, 302 | "node_modules/braces": { 303 | "version": "3.0.2", 304 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 305 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 306 | "dev": true, 307 | "dependencies": { 308 | "fill-range": "^7.0.1" 309 | }, 310 | "engines": { 311 | "node": ">=8" 312 | } 313 | }, 314 | "node_modules/cheerio": { 315 | "version": "1.0.0-rc.12", 316 | "resolved": "https://registry.npmjs.org/cheerio/-/cheerio-1.0.0-rc.12.tgz", 317 | "integrity": "sha512-VqR8m68vM46BNnuZ5NtnGBKIE/DfN0cRIzg9n40EIq9NOv90ayxLBXA8fXC5gquFRGJSTRqBq25Jt2ECLR431Q==", 318 | "dependencies": { 319 | "cheerio-select": "^2.1.0", 320 | "dom-serializer": "^2.0.0", 321 | "domhandler": "^5.0.3", 322 | "domutils": "^3.0.1", 323 | "htmlparser2": "^8.0.1", 324 | "parse5": "^7.0.0", 325 | "parse5-htmlparser2-tree-adapter": "^7.0.0" 326 | }, 327 | "engines": { 328 | "node": ">= 6" 329 | }, 330 | "funding": { 331 | "url": "https://github.com/cheeriojs/cheerio?sponsor=1" 332 | } 333 | }, 334 | "node_modules/cheerio-select": { 335 | "version": "2.1.0", 336 | "resolved": "https://registry.npmjs.org/cheerio-select/-/cheerio-select-2.1.0.tgz", 337 | "integrity": "sha512-9v9kG0LvzrlcungtnJtpGNxY+fzECQKhK4EGJX2vByejiMX84MFNQw4UxPJl3bFbTMw+Dfs37XaIkCwTZfLh4g==", 338 | "dependencies": { 339 | "boolbase": "^1.0.0", 340 | "css-select": "^5.1.0", 341 | "css-what": "^6.1.0", 342 | "domelementtype": "^2.3.0", 343 | "domhandler": "^5.0.3", 344 | "domutils": "^3.0.1" 345 | }, 346 | "funding": { 347 | "url": "https://github.com/sponsors/fb55" 348 | } 349 | }, 350 | "node_modules/chokidar": { 351 | "version": "3.5.3", 352 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 353 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 354 | "dev": true, 355 | "funding": [ 356 | { 357 | "type": "individual", 358 | "url": "https://paulmillr.com/funding/" 359 | } 360 | ], 361 | "dependencies": { 362 | "anymatch": "~3.1.2", 363 | "braces": "~3.0.2", 364 | "glob-parent": "~5.1.2", 365 | "is-binary-path": "~2.1.0", 366 | "is-glob": "~4.0.1", 367 | "normalize-path": "~3.0.0", 368 | "readdirp": "~3.6.0" 369 | }, 370 | "engines": { 371 | "node": ">= 8.10.0" 372 | }, 373 | "optionalDependencies": { 374 | "fsevents": "~2.3.2" 375 | } 376 | }, 377 | "node_modules/combined-stream": { 378 | "version": "1.0.8", 379 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 380 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 381 | "dependencies": { 382 | "delayed-stream": "~1.0.0" 383 | }, 384 | "engines": { 385 | "node": ">= 0.8" 386 | } 387 | }, 388 | "node_modules/concat-map": { 389 | "version": "0.0.1", 390 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 391 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 392 | "dev": true 393 | }, 394 | "node_modules/create-require": { 395 | "version": "1.1.1", 396 | "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", 397 | "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==", 398 | "dev": true 399 | }, 400 | "node_modules/cross-fetch": { 401 | "version": "3.1.6", 402 | "resolved": "https://registry.npmjs.org/cross-fetch/-/cross-fetch-3.1.6.tgz", 403 | "integrity": "sha512-riRvo06crlE8HiqOwIpQhxwdOk4fOeR7FVM/wXoxchFEqMNUjvbs3bfo4OTgMEMHzppd4DxFBDbyySj8Cv781g==", 404 | "dependencies": { 405 | "node-fetch": "^2.6.11" 406 | } 407 | }, 408 | "node_modules/css-select": { 409 | "version": "5.1.0", 410 | "resolved": "https://registry.npmjs.org/css-select/-/css-select-5.1.0.tgz", 411 | "integrity": "sha512-nwoRF1rvRRnnCqqY7updORDsuqKzqYJ28+oSMaJMMgOauh3fvwHqMS7EZpIPqK8GL+g9mKxF1vP/ZjSeNjEVHg==", 412 | "dependencies": { 413 | "boolbase": "^1.0.0", 414 | "css-what": "^6.1.0", 415 | "domhandler": "^5.0.2", 416 | "domutils": "^3.0.1", 417 | "nth-check": "^2.0.1" 418 | }, 419 | "funding": { 420 | "url": "https://github.com/sponsors/fb55" 421 | } 422 | }, 423 | "node_modules/css-what": { 424 | "version": "6.1.0", 425 | "resolved": "https://registry.npmjs.org/css-what/-/css-what-6.1.0.tgz", 426 | "integrity": "sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==", 427 | "engines": { 428 | "node": ">= 6" 429 | }, 430 | "funding": { 431 | "url": "https://github.com/sponsors/fb55" 432 | } 433 | }, 434 | "node_modules/cssstyle": { 435 | "version": "3.0.0", 436 | "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-3.0.0.tgz", 437 | "integrity": "sha512-N4u2ABATi3Qplzf0hWbVCdjenim8F3ojEXpBDF5hBpjzW182MjNGLqfmQ0SkSPeQ+V86ZXgeH8aXj6kayd4jgg==", 438 | "dependencies": { 439 | "rrweb-cssom": "^0.6.0" 440 | }, 441 | "engines": { 442 | "node": ">=14" 443 | } 444 | }, 445 | "node_modules/data-urls": { 446 | "version": "4.0.0", 447 | "resolved": "https://registry.npmjs.org/data-urls/-/data-urls-4.0.0.tgz", 448 | "integrity": "sha512-/mMTei/JXPqvFqQtfyTowxmJVwr2PVAeCcDxyFf6LhoOu/09TX2OX3kb2wzi4DMXcfj4OItwDOnhl5oziPnT6g==", 449 | "dependencies": { 450 | "abab": "^2.0.6", 451 | "whatwg-mimetype": "^3.0.0", 452 | "whatwg-url": "^12.0.0" 453 | }, 454 | "engines": { 455 | "node": ">=14" 456 | } 457 | }, 458 | "node_modules/data-urls/node_modules/tr46": { 459 | "version": "4.1.1", 460 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-4.1.1.tgz", 461 | "integrity": "sha512-2lv/66T7e5yNyhAAC4NaKe5nVavzuGJQVVtRYLyQ2OI8tsJ61PMLlelehb0wi2Hx6+hT/OJUWZcw8MjlSRnxvw==", 462 | "dependencies": { 463 | "punycode": "^2.3.0" 464 | }, 465 | "engines": { 466 | "node": ">=14" 467 | } 468 | }, 469 | "node_modules/data-urls/node_modules/webidl-conversions": { 470 | "version": "7.0.0", 471 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 472 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==", 473 | "engines": { 474 | "node": ">=12" 475 | } 476 | }, 477 | "node_modules/data-urls/node_modules/whatwg-url": { 478 | "version": "12.0.1", 479 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-12.0.1.tgz", 480 | "integrity": "sha512-Ed/LrqB8EPlGxjS+TrsXcpUond1mhccS3pchLhzSgPCnTimUCKj3IZE75pAs5m6heB2U2TMerKFUXheyHY+VDQ==", 481 | "dependencies": { 482 | "tr46": "^4.1.1", 483 | "webidl-conversions": "^7.0.0" 484 | }, 485 | "engines": { 486 | "node": ">=14" 487 | } 488 | }, 489 | "node_modules/debug": { 490 | "version": "3.2.7", 491 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 492 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 493 | "dev": true, 494 | "dependencies": { 495 | "ms": "^2.1.1" 496 | } 497 | }, 498 | "node_modules/decimal.js": { 499 | "version": "10.4.3", 500 | "resolved": "https://registry.npmjs.org/decimal.js/-/decimal.js-10.4.3.tgz", 501 | "integrity": "sha512-VBBaLc1MgL5XpzgIP7ny5Z6Nx3UrRkIViUkPUdtl9aya5amy3De1gsUUSB1g3+3sExYNjCAsAznmukyxCb1GRA==" 502 | }, 503 | "node_modules/delayed-stream": { 504 | "version": "1.0.0", 505 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 506 | "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", 507 | "engines": { 508 | "node": ">=0.4.0" 509 | } 510 | }, 511 | "node_modules/diff": { 512 | "version": "4.0.2", 513 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 514 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 515 | "dev": true, 516 | "engines": { 517 | "node": ">=0.3.1" 518 | } 519 | }, 520 | "node_modules/dom-serializer": { 521 | "version": "2.0.0", 522 | "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-2.0.0.tgz", 523 | "integrity": "sha512-wIkAryiqt/nV5EQKqQpo3SToSOV9J0DnbJqwK7Wv/Trc92zIAYZ4FlMu+JPFW1DfGFt81ZTCGgDEabffXeLyJg==", 524 | "dependencies": { 525 | "domelementtype": "^2.3.0", 526 | "domhandler": "^5.0.2", 527 | "entities": "^4.2.0" 528 | }, 529 | "funding": { 530 | "url": "https://github.com/cheeriojs/dom-serializer?sponsor=1" 531 | } 532 | }, 533 | "node_modules/domelementtype": { 534 | "version": "2.3.0", 535 | "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz", 536 | "integrity": "sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==", 537 | "funding": [ 538 | { 539 | "type": "github", 540 | "url": "https://github.com/sponsors/fb55" 541 | } 542 | ] 543 | }, 544 | "node_modules/domexception": { 545 | "version": "4.0.0", 546 | "resolved": "https://registry.npmjs.org/domexception/-/domexception-4.0.0.tgz", 547 | "integrity": "sha512-A2is4PLG+eeSfoTMA95/s4pvAoSo2mKtiM5jlHkAVewmiO8ISFTFKZjH7UAM1Atli/OT/7JHOrJRJiMKUZKYBw==", 548 | "dependencies": { 549 | "webidl-conversions": "^7.0.0" 550 | }, 551 | "engines": { 552 | "node": ">=12" 553 | } 554 | }, 555 | "node_modules/domexception/node_modules/webidl-conversions": { 556 | "version": "7.0.0", 557 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 558 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==", 559 | "engines": { 560 | "node": ">=12" 561 | } 562 | }, 563 | "node_modules/domhandler": { 564 | "version": "5.0.3", 565 | "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-5.0.3.tgz", 566 | "integrity": "sha512-cgwlv/1iFQiFnU96XXgROh8xTeetsnJiDsTc7TYCLFd9+/WNkIqPTxiM/8pSd8VIrhXGTf1Ny1q1hquVqDJB5w==", 567 | "dependencies": { 568 | "domelementtype": "^2.3.0" 569 | }, 570 | "engines": { 571 | "node": ">= 4" 572 | }, 573 | "funding": { 574 | "url": "https://github.com/fb55/domhandler?sponsor=1" 575 | } 576 | }, 577 | "node_modules/domutils": { 578 | "version": "3.1.0", 579 | "resolved": "https://registry.npmjs.org/domutils/-/domutils-3.1.0.tgz", 580 | "integrity": "sha512-H78uMmQtI2AhgDJjWeQmHwJJ2bLPD3GMmO7Zja/ZZh84wkm+4ut+IUnUdRa8uCGX88DiVx1j6FRe1XfxEgjEZA==", 581 | "dependencies": { 582 | "dom-serializer": "^2.0.0", 583 | "domelementtype": "^2.3.0", 584 | "domhandler": "^5.0.3" 585 | }, 586 | "funding": { 587 | "url": "https://github.com/fb55/domutils?sponsor=1" 588 | } 589 | }, 590 | "node_modules/dotenv": { 591 | "version": "16.0.3", 592 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.0.3.tgz", 593 | "integrity": "sha512-7GO6HghkA5fYG9TYnNxi14/7K9f5occMlp3zXAuSxn7CKCxt9xbNWG7yF8hTCSUchlfWSe3uLmlPfigevRItzQ==", 594 | "engines": { 595 | "node": ">=12" 596 | } 597 | }, 598 | "node_modules/entities": { 599 | "version": "4.5.0", 600 | "resolved": "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz", 601 | "integrity": "sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==", 602 | "engines": { 603 | "node": ">=0.12" 604 | }, 605 | "funding": { 606 | "url": "https://github.com/fb55/entities?sponsor=1" 607 | } 608 | }, 609 | "node_modules/eventemitter3": { 610 | "version": "4.0.7", 611 | "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz", 612 | "integrity": "sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw==" 613 | }, 614 | "node_modules/expr-eval": { 615 | "version": "2.0.2", 616 | "resolved": "https://registry.npmjs.org/expr-eval/-/expr-eval-2.0.2.tgz", 617 | "integrity": "sha512-4EMSHGOPSwAfBiibw3ndnP0AvjDWLsMvGOvWEZ2F96IGk0bIVdjQisOHxReSkE13mHcfbuCiXw+G4y0zv6N8Eg==" 618 | }, 619 | "node_modules/fill-range": { 620 | "version": "7.0.1", 621 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 622 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 623 | "dev": true, 624 | "dependencies": { 625 | "to-regex-range": "^5.0.1" 626 | }, 627 | "engines": { 628 | "node": ">=8" 629 | } 630 | }, 631 | "node_modules/flat": { 632 | "version": "5.0.2", 633 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 634 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 635 | "bin": { 636 | "flat": "cli.js" 637 | } 638 | }, 639 | "node_modules/follow-redirects": { 640 | "version": "1.15.2", 641 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.2.tgz", 642 | "integrity": "sha512-VQLG33o04KaQ8uYi2tVNbdrWp1QWxNNea+nmIB4EVM28v0hmP17z7aG1+wAkNzVq4KeXTq3221ye5qTJP91JwA==", 643 | "funding": [ 644 | { 645 | "type": "individual", 646 | "url": "https://github.com/sponsors/RubenVerborgh" 647 | } 648 | ], 649 | "engines": { 650 | "node": ">=4.0" 651 | }, 652 | "peerDependenciesMeta": { 653 | "debug": { 654 | "optional": true 655 | } 656 | } 657 | }, 658 | "node_modules/form-data": { 659 | "version": "4.0.0", 660 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", 661 | "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", 662 | "dependencies": { 663 | "asynckit": "^0.4.0", 664 | "combined-stream": "^1.0.8", 665 | "mime-types": "^2.1.12" 666 | }, 667 | "engines": { 668 | "node": ">= 6" 669 | } 670 | }, 671 | "node_modules/fsevents": { 672 | "version": "2.3.2", 673 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 674 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 675 | "dev": true, 676 | "hasInstallScript": true, 677 | "optional": true, 678 | "os": [ 679 | "darwin" 680 | ], 681 | "engines": { 682 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 683 | } 684 | }, 685 | "node_modules/glob-parent": { 686 | "version": "5.1.2", 687 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 688 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 689 | "dev": true, 690 | "dependencies": { 691 | "is-glob": "^4.0.1" 692 | }, 693 | "engines": { 694 | "node": ">= 6" 695 | } 696 | }, 697 | "node_modules/has-flag": { 698 | "version": "3.0.0", 699 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 700 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 701 | "dev": true, 702 | "engines": { 703 | "node": ">=4" 704 | } 705 | }, 706 | "node_modules/html-encoding-sniffer": { 707 | "version": "3.0.0", 708 | "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-3.0.0.tgz", 709 | "integrity": "sha512-oWv4T4yJ52iKrufjnyZPkrN0CH3QnrUqdB6In1g5Fe1mia8GmF36gnfNySxoZtxD5+NmYw1EElVXiBk93UeskA==", 710 | "dependencies": { 711 | "whatwg-encoding": "^2.0.0" 712 | }, 713 | "engines": { 714 | "node": ">=12" 715 | } 716 | }, 717 | "node_modules/htmlparser2": { 718 | "version": "8.0.2", 719 | "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-8.0.2.tgz", 720 | "integrity": "sha512-GYdjWKDkbRLkZ5geuHs5NY1puJ+PXwP7+fHPRz06Eirsb9ugf6d8kkXav6ADhcODhFFPMIXyxkxSuMf3D6NCFA==", 721 | "funding": [ 722 | "https://github.com/fb55/htmlparser2?sponsor=1", 723 | { 724 | "type": "github", 725 | "url": "https://github.com/sponsors/fb55" 726 | } 727 | ], 728 | "dependencies": { 729 | "domelementtype": "^2.3.0", 730 | "domhandler": "^5.0.3", 731 | "domutils": "^3.0.1", 732 | "entities": "^4.4.0" 733 | } 734 | }, 735 | "node_modules/http-proxy-agent": { 736 | "version": "5.0.0", 737 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-5.0.0.tgz", 738 | "integrity": "sha512-n2hY8YdoRE1i7r6M0w9DIw5GgZN0G25P8zLCRQ8rjXtTU3vsNFBI/vWK/UIeE6g5MUUz6avwAPXmL6Fy9D/90w==", 739 | "dependencies": { 740 | "@tootallnate/once": "2", 741 | "agent-base": "6", 742 | "debug": "4" 743 | }, 744 | "engines": { 745 | "node": ">= 6" 746 | } 747 | }, 748 | "node_modules/http-proxy-agent/node_modules/debug": { 749 | "version": "4.3.4", 750 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 751 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 752 | "dependencies": { 753 | "ms": "2.1.2" 754 | }, 755 | "engines": { 756 | "node": ">=6.0" 757 | }, 758 | "peerDependenciesMeta": { 759 | "supports-color": { 760 | "optional": true 761 | } 762 | } 763 | }, 764 | "node_modules/http-proxy-agent/node_modules/ms": { 765 | "version": "2.1.2", 766 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 767 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 768 | }, 769 | "node_modules/https-proxy-agent": { 770 | "version": "5.0.1", 771 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", 772 | "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", 773 | "dependencies": { 774 | "agent-base": "6", 775 | "debug": "4" 776 | }, 777 | "engines": { 778 | "node": ">= 6" 779 | } 780 | }, 781 | "node_modules/https-proxy-agent/node_modules/debug": { 782 | "version": "4.3.4", 783 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 784 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 785 | "dependencies": { 786 | "ms": "2.1.2" 787 | }, 788 | "engines": { 789 | "node": ">=6.0" 790 | }, 791 | "peerDependenciesMeta": { 792 | "supports-color": { 793 | "optional": true 794 | } 795 | } 796 | }, 797 | "node_modules/https-proxy-agent/node_modules/ms": { 798 | "version": "2.1.2", 799 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 800 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 801 | }, 802 | "node_modules/iconv-lite": { 803 | "version": "0.6.3", 804 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", 805 | "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", 806 | "dependencies": { 807 | "safer-buffer": ">= 2.1.2 < 3.0.0" 808 | }, 809 | "engines": { 810 | "node": ">=0.10.0" 811 | } 812 | }, 813 | "node_modules/ignore-by-default": { 814 | "version": "1.0.1", 815 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 816 | "integrity": "sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA==", 817 | "dev": true 818 | }, 819 | "node_modules/is-any-array": { 820 | "version": "2.0.1", 821 | "resolved": "https://registry.npmjs.org/is-any-array/-/is-any-array-2.0.1.tgz", 822 | "integrity": "sha512-UtilS7hLRu++wb/WBAw9bNuP1Eg04Ivn1vERJck8zJthEvXCBEBpGR/33u/xLKWEQf95803oalHrVDptcAvFdQ==" 823 | }, 824 | "node_modules/is-binary-path": { 825 | "version": "2.1.0", 826 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 827 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 828 | "dev": true, 829 | "dependencies": { 830 | "binary-extensions": "^2.0.0" 831 | }, 832 | "engines": { 833 | "node": ">=8" 834 | } 835 | }, 836 | "node_modules/is-extglob": { 837 | "version": "2.1.1", 838 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 839 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 840 | "dev": true, 841 | "engines": { 842 | "node": ">=0.10.0" 843 | } 844 | }, 845 | "node_modules/is-glob": { 846 | "version": "4.0.3", 847 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 848 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 849 | "dev": true, 850 | "dependencies": { 851 | "is-extglob": "^2.1.1" 852 | }, 853 | "engines": { 854 | "node": ">=0.10.0" 855 | } 856 | }, 857 | "node_modules/is-number": { 858 | "version": "7.0.0", 859 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 860 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 861 | "dev": true, 862 | "engines": { 863 | "node": ">=0.12.0" 864 | } 865 | }, 866 | "node_modules/is-potential-custom-element-name": { 867 | "version": "1.0.1", 868 | "resolved": "https://registry.npmjs.org/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.1.tgz", 869 | "integrity": "sha512-bCYeRA2rVibKZd+s2625gGnGF/t7DSqDs4dP7CrLA1m7jKWz6pps0LpYLJN8Q64HtmPKJ1hrN3nzPNKFEKOUiQ==" 870 | }, 871 | "node_modules/js-tiktoken": { 872 | "version": "1.0.6", 873 | "resolved": "https://registry.npmjs.org/js-tiktoken/-/js-tiktoken-1.0.6.tgz", 874 | "integrity": "sha512-lxHntEupgjWvSh37WxpAW4XN6UBXBtFJOpZZq5HN5oNjDfN7L/iJhHOKjyL/DFtuYXUwn5jfTciLtOWpgQmHjQ==", 875 | "dependencies": { 876 | "base64-js": "^1.5.1" 877 | } 878 | }, 879 | "node_modules/jsdom": { 880 | "version": "22.1.0", 881 | "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-22.1.0.tgz", 882 | "integrity": "sha512-/9AVW7xNbsBv6GfWho4TTNjEo9fe6Zhf9O7s0Fhhr3u+awPwAJMKwAMXnkk5vBxflqLW9hTHX/0cs+P3gW+cQw==", 883 | "dependencies": { 884 | "abab": "^2.0.6", 885 | "cssstyle": "^3.0.0", 886 | "data-urls": "^4.0.0", 887 | "decimal.js": "^10.4.3", 888 | "domexception": "^4.0.0", 889 | "form-data": "^4.0.0", 890 | "html-encoding-sniffer": "^3.0.0", 891 | "http-proxy-agent": "^5.0.0", 892 | "https-proxy-agent": "^5.0.1", 893 | "is-potential-custom-element-name": "^1.0.1", 894 | "nwsapi": "^2.2.4", 895 | "parse5": "^7.1.2", 896 | "rrweb-cssom": "^0.6.0", 897 | "saxes": "^6.0.0", 898 | "symbol-tree": "^3.2.4", 899 | "tough-cookie": "^4.1.2", 900 | "w3c-xmlserializer": "^4.0.0", 901 | "webidl-conversions": "^7.0.0", 902 | "whatwg-encoding": "^2.0.0", 903 | "whatwg-mimetype": "^3.0.0", 904 | "whatwg-url": "^12.0.1", 905 | "ws": "^8.13.0", 906 | "xml-name-validator": "^4.0.0" 907 | }, 908 | "engines": { 909 | "node": ">=16" 910 | }, 911 | "peerDependencies": { 912 | "canvas": "^2.5.0" 913 | }, 914 | "peerDependenciesMeta": { 915 | "canvas": { 916 | "optional": true 917 | } 918 | } 919 | }, 920 | "node_modules/jsdom/node_modules/tr46": { 921 | "version": "4.1.1", 922 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-4.1.1.tgz", 923 | "integrity": "sha512-2lv/66T7e5yNyhAAC4NaKe5nVavzuGJQVVtRYLyQ2OI8tsJ61PMLlelehb0wi2Hx6+hT/OJUWZcw8MjlSRnxvw==", 924 | "dependencies": { 925 | "punycode": "^2.3.0" 926 | }, 927 | "engines": { 928 | "node": ">=14" 929 | } 930 | }, 931 | "node_modules/jsdom/node_modules/webidl-conversions": { 932 | "version": "7.0.0", 933 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 934 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==", 935 | "engines": { 936 | "node": ">=12" 937 | } 938 | }, 939 | "node_modules/jsdom/node_modules/whatwg-url": { 940 | "version": "12.0.1", 941 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-12.0.1.tgz", 942 | "integrity": "sha512-Ed/LrqB8EPlGxjS+TrsXcpUond1mhccS3pchLhzSgPCnTimUCKj3IZE75pAs5m6heB2U2TMerKFUXheyHY+VDQ==", 943 | "dependencies": { 944 | "tr46": "^4.1.1", 945 | "webidl-conversions": "^7.0.0" 946 | }, 947 | "engines": { 948 | "node": ">=14" 949 | } 950 | }, 951 | "node_modules/jsonpointer": { 952 | "version": "5.0.1", 953 | "resolved": "https://registry.npmjs.org/jsonpointer/-/jsonpointer-5.0.1.tgz", 954 | "integrity": "sha512-p/nXbhSEcu3pZRdkW1OfJhpsVtW1gd4Wa1fnQc9YLiTfAjn0312eMKimbdIQzuZl9aa9xUGaRlP9T/CJE/ditQ==", 955 | "engines": { 956 | "node": ">=0.10.0" 957 | } 958 | }, 959 | "node_modules/langchain": { 960 | "version": "0.0.84", 961 | "resolved": "https://registry.npmjs.org/langchain/-/langchain-0.0.84.tgz", 962 | "integrity": "sha512-7b7CIwHE1vB973wRRC0GmU9Jj2bt/xN5SA17VeoHa6zuNunawC2wFUfjQzNtSw+RHtMX0VHUjoBOqQCKGktbXQ==", 963 | "dependencies": { 964 | "@anthropic-ai/sdk": "^0.4.3", 965 | "ansi-styles": "^5.0.0", 966 | "binary-extensions": "^2.2.0", 967 | "expr-eval": "^2.0.2", 968 | "flat": "^5.0.2", 969 | "js-tiktoken": "^1.0.6", 970 | "jsonpointer": "^5.0.1", 971 | "ml-distance": "^4.0.0", 972 | "object-hash": "^3.0.0", 973 | "openai": "^3.2.0", 974 | "p-queue": "^6.6.2", 975 | "p-retry": "4", 976 | "uuid": "^9.0.0", 977 | "yaml": "^2.2.1", 978 | "zod": "^3.21.4", 979 | "zod-to-json-schema": "^3.20.4" 980 | }, 981 | "engines": { 982 | "node": ">=18" 983 | }, 984 | "peerDependencies": { 985 | "@aws-sdk/client-dynamodb": "^3.310.0", 986 | "@aws-sdk/client-lambda": "^3.310.0", 987 | "@aws-sdk/client-s3": "^3.310.0", 988 | "@aws-sdk/client-sagemaker-runtime": "^3.310.0", 989 | "@clickhouse/client": "^0.0.14", 990 | "@getmetal/metal-sdk": "*", 991 | "@huggingface/inference": "^1.5.1", 992 | "@opensearch-project/opensearch": "*", 993 | "@pinecone-database/pinecone": "*", 994 | "@qdrant/js-client-rest": "^1.2.0", 995 | "@supabase/supabase-js": "^2.10.0", 996 | "@tensorflow-models/universal-sentence-encoder": "*", 997 | "@tensorflow/tfjs-converter": "*", 998 | "@tensorflow/tfjs-core": "*", 999 | "@tigrisdata/vector": "^1.1.0", 1000 | "@upstash/redis": "^1.20.6", 1001 | "@zilliz/milvus2-sdk-node": ">=2.2.7", 1002 | "apify-client": "^2.7.1", 1003 | "axios": "*", 1004 | "cheerio": "^1.0.0-rc.12", 1005 | "chromadb": "^1.4.2", 1006 | "cohere-ai": "^5.0.2", 1007 | "d3-dsv": "^2.0.0", 1008 | "epub2": "^3.0.1", 1009 | "faiss-node": "^0.2.0", 1010 | "google-auth-library": "^8.8.0", 1011 | "hnswlib-node": "^1.4.2", 1012 | "html-to-text": "^9.0.5", 1013 | "ignore": "^5.2.0", 1014 | "mammoth": "*", 1015 | "meriyah": "*", 1016 | "mongodb": "^5.2.0", 1017 | "pdf-parse": "1.1.1", 1018 | "pickleparser": "^0.1.0", 1019 | "playwright": "^1.32.1", 1020 | "puppeteer": "^19.7.2", 1021 | "redis": "^4.6.4", 1022 | "replicate": "^0.9.0", 1023 | "srt-parser-2": "^1.2.2", 1024 | "typeorm": "^0.3.12", 1025 | "weaviate-ts-client": "^1.0.0" 1026 | }, 1027 | "peerDependenciesMeta": { 1028 | "@aws-sdk/client-dynamodb": { 1029 | "optional": true 1030 | }, 1031 | "@aws-sdk/client-lambda": { 1032 | "optional": true 1033 | }, 1034 | "@aws-sdk/client-s3": { 1035 | "optional": true 1036 | }, 1037 | "@aws-sdk/client-sagemaker-runtime": { 1038 | "optional": true 1039 | }, 1040 | "@clickhouse/client": { 1041 | "optional": true 1042 | }, 1043 | "@getmetal/metal-sdk": { 1044 | "optional": true 1045 | }, 1046 | "@huggingface/inference": { 1047 | "optional": true 1048 | }, 1049 | "@opensearch-project/opensearch": { 1050 | "optional": true 1051 | }, 1052 | "@pinecone-database/pinecone": { 1053 | "optional": true 1054 | }, 1055 | "@qdrant/js-client-rest": { 1056 | "optional": true 1057 | }, 1058 | "@supabase/supabase-js": { 1059 | "optional": true 1060 | }, 1061 | "@tensorflow-models/universal-sentence-encoder": { 1062 | "optional": true 1063 | }, 1064 | "@tensorflow/tfjs-converter": { 1065 | "optional": true 1066 | }, 1067 | "@tensorflow/tfjs-core": { 1068 | "optional": true 1069 | }, 1070 | "@tigrisdata/vector": { 1071 | "optional": true 1072 | }, 1073 | "@upstash/redis": { 1074 | "optional": true 1075 | }, 1076 | "@zilliz/milvus2-sdk-node": { 1077 | "optional": true 1078 | }, 1079 | "apify-client": { 1080 | "optional": true 1081 | }, 1082 | "axios": { 1083 | "optional": true 1084 | }, 1085 | "cheerio": { 1086 | "optional": true 1087 | }, 1088 | "chromadb": { 1089 | "optional": true 1090 | }, 1091 | "cohere-ai": { 1092 | "optional": true 1093 | }, 1094 | "d3-dsv": { 1095 | "optional": true 1096 | }, 1097 | "epub2": { 1098 | "optional": true 1099 | }, 1100 | "faiss-node": { 1101 | "optional": true 1102 | }, 1103 | "google-auth-library": { 1104 | "optional": true 1105 | }, 1106 | "hnswlib-node": { 1107 | "optional": true 1108 | }, 1109 | "html-to-text": { 1110 | "optional": true 1111 | }, 1112 | "ignore": { 1113 | "optional": true 1114 | }, 1115 | "mammoth": { 1116 | "optional": true 1117 | }, 1118 | "meriyah": { 1119 | "optional": true 1120 | }, 1121 | "mongodb": { 1122 | "optional": true 1123 | }, 1124 | "pdf-parse": { 1125 | "optional": true 1126 | }, 1127 | "pickleparser": { 1128 | "optional": true 1129 | }, 1130 | "playwright": { 1131 | "optional": true 1132 | }, 1133 | "puppeteer": { 1134 | "optional": true 1135 | }, 1136 | "redis": { 1137 | "optional": true 1138 | }, 1139 | "replicate": { 1140 | "optional": true 1141 | }, 1142 | "srt-parser-2": { 1143 | "optional": true 1144 | }, 1145 | "typeorm": { 1146 | "optional": true 1147 | }, 1148 | "weaviate-ts-client": { 1149 | "optional": true 1150 | } 1151 | } 1152 | }, 1153 | "node_modules/make-error": { 1154 | "version": "1.3.6", 1155 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 1156 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 1157 | "dev": true 1158 | }, 1159 | "node_modules/mime-db": { 1160 | "version": "1.52.0", 1161 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 1162 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 1163 | "engines": { 1164 | "node": ">= 0.6" 1165 | } 1166 | }, 1167 | "node_modules/mime-types": { 1168 | "version": "2.1.35", 1169 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 1170 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 1171 | "dependencies": { 1172 | "mime-db": "1.52.0" 1173 | }, 1174 | "engines": { 1175 | "node": ">= 0.6" 1176 | } 1177 | }, 1178 | "node_modules/minimatch": { 1179 | "version": "3.1.2", 1180 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1181 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1182 | "dev": true, 1183 | "dependencies": { 1184 | "brace-expansion": "^1.1.7" 1185 | }, 1186 | "engines": { 1187 | "node": "*" 1188 | } 1189 | }, 1190 | "node_modules/ml-array-mean": { 1191 | "version": "1.1.6", 1192 | "resolved": "https://registry.npmjs.org/ml-array-mean/-/ml-array-mean-1.1.6.tgz", 1193 | "integrity": "sha512-MIdf7Zc8HznwIisyiJGRH9tRigg3Yf4FldW8DxKxpCCv/g5CafTw0RRu51nojVEOXuCQC7DRVVu5c7XXO/5joQ==", 1194 | "dependencies": { 1195 | "ml-array-sum": "^1.1.6" 1196 | } 1197 | }, 1198 | "node_modules/ml-array-sum": { 1199 | "version": "1.1.6", 1200 | "resolved": "https://registry.npmjs.org/ml-array-sum/-/ml-array-sum-1.1.6.tgz", 1201 | "integrity": "sha512-29mAh2GwH7ZmiRnup4UyibQZB9+ZLyMShvt4cH4eTK+cL2oEMIZFnSyB3SS8MlsTh6q/w/yh48KmqLxmovN4Dw==", 1202 | "dependencies": { 1203 | "is-any-array": "^2.0.0" 1204 | } 1205 | }, 1206 | "node_modules/ml-distance": { 1207 | "version": "4.0.0", 1208 | "resolved": "https://registry.npmjs.org/ml-distance/-/ml-distance-4.0.0.tgz", 1209 | "integrity": "sha512-zj7+UGZpHk3uL7n79XTfGNUjIGnhLn8xVvrxYvBHvXFxo3jq1q+/UjP311hZxnLVhbxbXCjUniThX8gozjacYA==", 1210 | "dependencies": { 1211 | "ml-array-mean": "^1.1.6", 1212 | "ml-distance-euclidean": "^2.0.0", 1213 | "ml-tree-similarity": "^1.0.0" 1214 | } 1215 | }, 1216 | "node_modules/ml-distance-euclidean": { 1217 | "version": "2.0.0", 1218 | "resolved": "https://registry.npmjs.org/ml-distance-euclidean/-/ml-distance-euclidean-2.0.0.tgz", 1219 | "integrity": "sha512-yC9/2o8QF0A3m/0IXqCTXCzz2pNEzvmcE/9HFKOZGnTjatvBbsn4lWYJkxENkA4Ug2fnYl7PXQxnPi21sgMy/Q==" 1220 | }, 1221 | "node_modules/ml-tree-similarity": { 1222 | "version": "1.0.0", 1223 | "resolved": "https://registry.npmjs.org/ml-tree-similarity/-/ml-tree-similarity-1.0.0.tgz", 1224 | "integrity": "sha512-XJUyYqjSuUQkNQHMscr6tcjldsOoAekxADTplt40QKfwW6nd++1wHWV9AArl0Zvw/TIHgNaZZNvr8QGvE8wLRg==", 1225 | "dependencies": { 1226 | "binary-search": "^1.3.5", 1227 | "num-sort": "^2.0.0" 1228 | } 1229 | }, 1230 | "node_modules/ms": { 1231 | "version": "2.1.3", 1232 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1233 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1234 | "dev": true 1235 | }, 1236 | "node_modules/node-fetch": { 1237 | "version": "2.6.11", 1238 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.11.tgz", 1239 | "integrity": "sha512-4I6pdBY1EthSqDmJkiNk3JIT8cswwR9nfeW/cPdUagJYEQG7R95WRH74wpz7ma8Gh/9dI9FP+OU+0E4FvtA55w==", 1240 | "dependencies": { 1241 | "whatwg-url": "^5.0.0" 1242 | }, 1243 | "engines": { 1244 | "node": "4.x || >=6.0.0" 1245 | }, 1246 | "peerDependencies": { 1247 | "encoding": "^0.1.0" 1248 | }, 1249 | "peerDependenciesMeta": { 1250 | "encoding": { 1251 | "optional": true 1252 | } 1253 | } 1254 | }, 1255 | "node_modules/nodemon": { 1256 | "version": "2.0.22", 1257 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.22.tgz", 1258 | "integrity": "sha512-B8YqaKMmyuCO7BowF1Z1/mkPqLk6cs/l63Ojtd6otKjMx47Dq1utxfRxcavH1I7VSaL8n5BUaoutadnsX3AAVQ==", 1259 | "dev": true, 1260 | "dependencies": { 1261 | "chokidar": "^3.5.2", 1262 | "debug": "^3.2.7", 1263 | "ignore-by-default": "^1.0.1", 1264 | "minimatch": "^3.1.2", 1265 | "pstree.remy": "^1.1.8", 1266 | "semver": "^5.7.1", 1267 | "simple-update-notifier": "^1.0.7", 1268 | "supports-color": "^5.5.0", 1269 | "touch": "^3.1.0", 1270 | "undefsafe": "^2.0.5" 1271 | }, 1272 | "bin": { 1273 | "nodemon": "bin/nodemon.js" 1274 | }, 1275 | "engines": { 1276 | "node": ">=8.10.0" 1277 | }, 1278 | "funding": { 1279 | "type": "opencollective", 1280 | "url": "https://opencollective.com/nodemon" 1281 | } 1282 | }, 1283 | "node_modules/nopt": { 1284 | "version": "1.0.10", 1285 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 1286 | "integrity": "sha512-NWmpvLSqUrgrAC9HCuxEvb+PSloHpqVu+FqcO4eeF2h5qYRhA7ev6KvelyQAKtegUbC6RypJnlEOhd8vloNKYg==", 1287 | "dev": true, 1288 | "dependencies": { 1289 | "abbrev": "1" 1290 | }, 1291 | "bin": { 1292 | "nopt": "bin/nopt.js" 1293 | }, 1294 | "engines": { 1295 | "node": "*" 1296 | } 1297 | }, 1298 | "node_modules/normalize-path": { 1299 | "version": "3.0.0", 1300 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1301 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1302 | "dev": true, 1303 | "engines": { 1304 | "node": ">=0.10.0" 1305 | } 1306 | }, 1307 | "node_modules/nth-check": { 1308 | "version": "2.1.1", 1309 | "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-2.1.1.tgz", 1310 | "integrity": "sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==", 1311 | "dependencies": { 1312 | "boolbase": "^1.0.0" 1313 | }, 1314 | "funding": { 1315 | "url": "https://github.com/fb55/nth-check?sponsor=1" 1316 | } 1317 | }, 1318 | "node_modules/num-sort": { 1319 | "version": "2.1.0", 1320 | "resolved": "https://registry.npmjs.org/num-sort/-/num-sort-2.1.0.tgz", 1321 | "integrity": "sha512-1MQz1Ed8z2yckoBeSfkQHHO9K1yDRxxtotKSJ9yvcTUUxSvfvzEq5GwBrjjHEpMlq/k5gvXdmJ1SbYxWtpNoVg==", 1322 | "engines": { 1323 | "node": ">=8" 1324 | }, 1325 | "funding": { 1326 | "url": "https://github.com/sponsors/sindresorhus" 1327 | } 1328 | }, 1329 | "node_modules/nwsapi": { 1330 | "version": "2.2.5", 1331 | "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.5.tgz", 1332 | "integrity": "sha512-6xpotnECFy/og7tKSBVmUNft7J3jyXAka4XvG6AUhFWRz+Q/Ljus7znJAA3bxColfQLdS+XsjoodtJfCgeTEFQ==" 1333 | }, 1334 | "node_modules/object-hash": { 1335 | "version": "3.0.0", 1336 | "resolved": "https://registry.npmjs.org/object-hash/-/object-hash-3.0.0.tgz", 1337 | "integrity": "sha512-RSn9F68PjH9HqtltsSnqYC1XXoWe9Bju5+213R98cNGttag9q9yAOTzdbsqvIa7aNm5WffBZFpWYr2aWrklWAw==", 1338 | "engines": { 1339 | "node": ">= 6" 1340 | } 1341 | }, 1342 | "node_modules/openai": { 1343 | "version": "3.2.1", 1344 | "resolved": "https://registry.npmjs.org/openai/-/openai-3.2.1.tgz", 1345 | "integrity": "sha512-762C9BNlJPbjjlWZi4WYK9iM2tAVAv0uUp1UmI34vb0CN5T2mjB/qM6RYBmNKMh/dN9fC+bxqPwWJZUTWW052A==", 1346 | "dependencies": { 1347 | "axios": "^0.26.0", 1348 | "form-data": "^4.0.0" 1349 | } 1350 | }, 1351 | "node_modules/openai/node_modules/axios": { 1352 | "version": "0.26.1", 1353 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.26.1.tgz", 1354 | "integrity": "sha512-fPwcX4EvnSHuInCMItEhAGnaSEXRBjtzh9fOtsE6E1G6p7vl7edEeZe11QHf18+6+9gR5PbKV/sGKNaD8YaMeA==", 1355 | "dependencies": { 1356 | "follow-redirects": "^1.14.8" 1357 | } 1358 | }, 1359 | "node_modules/p-finally": { 1360 | "version": "1.0.0", 1361 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", 1362 | "integrity": "sha512-LICb2p9CB7FS+0eR1oqWnHhp0FljGLZCWBE9aix0Uye9W8LTQPwMTYVGWQWIw9RdQiDg4+epXQODwIYJtSJaow==", 1363 | "engines": { 1364 | "node": ">=4" 1365 | } 1366 | }, 1367 | "node_modules/p-queue": { 1368 | "version": "6.6.2", 1369 | "resolved": "https://registry.npmjs.org/p-queue/-/p-queue-6.6.2.tgz", 1370 | "integrity": "sha512-RwFpb72c/BhQLEXIZ5K2e+AhgNVmIejGlTgiB9MzZ0e93GRvqZ7uSi0dvRF7/XIXDeNkra2fNHBxTyPDGySpjQ==", 1371 | "dependencies": { 1372 | "eventemitter3": "^4.0.4", 1373 | "p-timeout": "^3.2.0" 1374 | }, 1375 | "engines": { 1376 | "node": ">=8" 1377 | }, 1378 | "funding": { 1379 | "url": "https://github.com/sponsors/sindresorhus" 1380 | } 1381 | }, 1382 | "node_modules/p-retry": { 1383 | "version": "4.6.2", 1384 | "resolved": "https://registry.npmjs.org/p-retry/-/p-retry-4.6.2.tgz", 1385 | "integrity": "sha512-312Id396EbJdvRONlngUx0NydfrIQ5lsYu0znKVUzVvArzEIt08V1qhtyESbGVd1FGX7UKtiFp5uwKZdM8wIuQ==", 1386 | "dependencies": { 1387 | "@types/retry": "0.12.0", 1388 | "retry": "^0.13.1" 1389 | }, 1390 | "engines": { 1391 | "node": ">=8" 1392 | } 1393 | }, 1394 | "node_modules/p-timeout": { 1395 | "version": "3.2.0", 1396 | "resolved": "https://registry.npmjs.org/p-timeout/-/p-timeout-3.2.0.tgz", 1397 | "integrity": "sha512-rhIwUycgwwKcP9yTOOFK/AKsAopjjCakVqLHePO3CC6Mir1Z99xT+R63jZxAT5lFZLa2inS5h+ZS2GvR99/FBg==", 1398 | "dependencies": { 1399 | "p-finally": "^1.0.0" 1400 | }, 1401 | "engines": { 1402 | "node": ">=8" 1403 | } 1404 | }, 1405 | "node_modules/parse5": { 1406 | "version": "7.1.2", 1407 | "resolved": "https://registry.npmjs.org/parse5/-/parse5-7.1.2.tgz", 1408 | "integrity": "sha512-Czj1WaSVpaoj0wbhMzLmWD69anp2WH7FXMB9n1Sy8/ZFF9jolSQVMu1Ij5WIyGmcBmhk7EOndpO4mIpihVqAXw==", 1409 | "dependencies": { 1410 | "entities": "^4.4.0" 1411 | }, 1412 | "funding": { 1413 | "url": "https://github.com/inikulin/parse5?sponsor=1" 1414 | } 1415 | }, 1416 | "node_modules/parse5-htmlparser2-tree-adapter": { 1417 | "version": "7.0.0", 1418 | "resolved": "https://registry.npmjs.org/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-7.0.0.tgz", 1419 | "integrity": "sha512-B77tOZrqqfUfnVcOrUvfdLbz4pu4RopLD/4vmu3HUPswwTA8OH0EMW9BlWR2B0RCoiZRAHEUu7IxeP1Pd1UU+g==", 1420 | "dependencies": { 1421 | "domhandler": "^5.0.2", 1422 | "parse5": "^7.0.0" 1423 | }, 1424 | "funding": { 1425 | "url": "https://github.com/inikulin/parse5?sponsor=1" 1426 | } 1427 | }, 1428 | "node_modules/picomatch": { 1429 | "version": "2.3.1", 1430 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1431 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1432 | "dev": true, 1433 | "engines": { 1434 | "node": ">=8.6" 1435 | }, 1436 | "funding": { 1437 | "url": "https://github.com/sponsors/jonschlinkert" 1438 | } 1439 | }, 1440 | "node_modules/proxy-from-env": { 1441 | "version": "1.1.0", 1442 | "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", 1443 | "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" 1444 | }, 1445 | "node_modules/psl": { 1446 | "version": "1.9.0", 1447 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.9.0.tgz", 1448 | "integrity": "sha512-E/ZsdU4HLs/68gYzgGTkMicWTLPdAftJLfJFlLUAAKZGkStNU72sZjT66SnMDVOfOWY/YAoiD7Jxa9iHvngcag==" 1449 | }, 1450 | "node_modules/pstree.remy": { 1451 | "version": "1.1.8", 1452 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 1453 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==", 1454 | "dev": true 1455 | }, 1456 | "node_modules/punycode": { 1457 | "version": "2.3.0", 1458 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz", 1459 | "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==", 1460 | "engines": { 1461 | "node": ">=6" 1462 | } 1463 | }, 1464 | "node_modules/querystringify": { 1465 | "version": "2.2.0", 1466 | "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.2.0.tgz", 1467 | "integrity": "sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==" 1468 | }, 1469 | "node_modules/readdirp": { 1470 | "version": "3.6.0", 1471 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1472 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1473 | "dev": true, 1474 | "dependencies": { 1475 | "picomatch": "^2.2.1" 1476 | }, 1477 | "engines": { 1478 | "node": ">=8.10.0" 1479 | } 1480 | }, 1481 | "node_modules/requires-port": { 1482 | "version": "1.0.0", 1483 | "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", 1484 | "integrity": "sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ==" 1485 | }, 1486 | "node_modules/retry": { 1487 | "version": "0.13.1", 1488 | "resolved": "https://registry.npmjs.org/retry/-/retry-0.13.1.tgz", 1489 | "integrity": "sha512-XQBQ3I8W1Cge0Seh+6gjj03LbmRFWuoszgK9ooCpwYIrhhoO80pfq4cUkU5DkknwfOfFteRwlZ56PYOGYyFWdg==", 1490 | "engines": { 1491 | "node": ">= 4" 1492 | } 1493 | }, 1494 | "node_modules/rrweb-cssom": { 1495 | "version": "0.6.0", 1496 | "resolved": "https://registry.npmjs.org/rrweb-cssom/-/rrweb-cssom-0.6.0.tgz", 1497 | "integrity": "sha512-APM0Gt1KoXBz0iIkkdB/kfvGOwC4UuJFeG/c+yV7wSc7q96cG/kJ0HiYCnzivD9SB53cLV1MlHFNfOuPaadYSw==" 1498 | }, 1499 | "node_modules/safer-buffer": { 1500 | "version": "2.1.2", 1501 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1502 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1503 | }, 1504 | "node_modules/saxes": { 1505 | "version": "6.0.0", 1506 | "resolved": "https://registry.npmjs.org/saxes/-/saxes-6.0.0.tgz", 1507 | "integrity": "sha512-xAg7SOnEhrm5zI3puOOKyy1OMcMlIJZYNJY7xLBwSze0UjhPLnWfj2GF2EpT0jmzaJKIWKHLsaSSajf35bcYnA==", 1508 | "dependencies": { 1509 | "xmlchars": "^2.2.0" 1510 | }, 1511 | "engines": { 1512 | "node": ">=v12.22.7" 1513 | } 1514 | }, 1515 | "node_modules/semver": { 1516 | "version": "5.7.1", 1517 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1518 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1519 | "dev": true, 1520 | "bin": { 1521 | "semver": "bin/semver" 1522 | } 1523 | }, 1524 | "node_modules/simple-update-notifier": { 1525 | "version": "1.1.0", 1526 | "resolved": "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-1.1.0.tgz", 1527 | "integrity": "sha512-VpsrsJSUcJEseSbMHkrsrAVSdvVS5I96Qo1QAQ4FxQ9wXFcB+pjj7FB7/us9+GcgfW4ziHtYMc1J0PLczb55mg==", 1528 | "dev": true, 1529 | "dependencies": { 1530 | "semver": "~7.0.0" 1531 | }, 1532 | "engines": { 1533 | "node": ">=8.10.0" 1534 | } 1535 | }, 1536 | "node_modules/simple-update-notifier/node_modules/semver": { 1537 | "version": "7.0.0", 1538 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz", 1539 | "integrity": "sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A==", 1540 | "dev": true, 1541 | "bin": { 1542 | "semver": "bin/semver.js" 1543 | } 1544 | }, 1545 | "node_modules/supports-color": { 1546 | "version": "5.5.0", 1547 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1548 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1549 | "dev": true, 1550 | "dependencies": { 1551 | "has-flag": "^3.0.0" 1552 | }, 1553 | "engines": { 1554 | "node": ">=4" 1555 | } 1556 | }, 1557 | "node_modules/symbol-tree": { 1558 | "version": "3.2.4", 1559 | "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.4.tgz", 1560 | "integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==" 1561 | }, 1562 | "node_modules/to-regex-range": { 1563 | "version": "5.0.1", 1564 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1565 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1566 | "dev": true, 1567 | "dependencies": { 1568 | "is-number": "^7.0.0" 1569 | }, 1570 | "engines": { 1571 | "node": ">=8.0" 1572 | } 1573 | }, 1574 | "node_modules/touch": { 1575 | "version": "3.1.0", 1576 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 1577 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 1578 | "dev": true, 1579 | "dependencies": { 1580 | "nopt": "~1.0.10" 1581 | }, 1582 | "bin": { 1583 | "nodetouch": "bin/nodetouch.js" 1584 | } 1585 | }, 1586 | "node_modules/tough-cookie": { 1587 | "version": "4.1.2", 1588 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-4.1.2.tgz", 1589 | "integrity": "sha512-G9fqXWoYFZgTc2z8Q5zaHy/vJMjm+WV0AkAeHxVCQiEB1b+dGvWzFW6QV07cY5jQ5gRkeid2qIkzkxUnmoQZUQ==", 1590 | "dependencies": { 1591 | "psl": "^1.1.33", 1592 | "punycode": "^2.1.1", 1593 | "universalify": "^0.2.0", 1594 | "url-parse": "^1.5.3" 1595 | }, 1596 | "engines": { 1597 | "node": ">=6" 1598 | } 1599 | }, 1600 | "node_modules/tr46": { 1601 | "version": "0.0.3", 1602 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", 1603 | "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" 1604 | }, 1605 | "node_modules/ts-node": { 1606 | "version": "10.9.1", 1607 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.9.1.tgz", 1608 | "integrity": "sha512-NtVysVPkxxrwFGUUxGYhfux8k78pQB3JqYBXlLRZgdGUqTO5wU/UyHop5p70iEbGhB7q5KmiZiU0Y3KlJrScEw==", 1609 | "dev": true, 1610 | "dependencies": { 1611 | "@cspotcode/source-map-support": "^0.8.0", 1612 | "@tsconfig/node10": "^1.0.7", 1613 | "@tsconfig/node12": "^1.0.7", 1614 | "@tsconfig/node14": "^1.0.0", 1615 | "@tsconfig/node16": "^1.0.2", 1616 | "acorn": "^8.4.1", 1617 | "acorn-walk": "^8.1.1", 1618 | "arg": "^4.1.0", 1619 | "create-require": "^1.1.0", 1620 | "diff": "^4.0.1", 1621 | "make-error": "^1.1.1", 1622 | "v8-compile-cache-lib": "^3.0.1", 1623 | "yn": "3.1.1" 1624 | }, 1625 | "bin": { 1626 | "ts-node": "dist/bin.js", 1627 | "ts-node-cwd": "dist/bin-cwd.js", 1628 | "ts-node-esm": "dist/bin-esm.js", 1629 | "ts-node-script": "dist/bin-script.js", 1630 | "ts-node-transpile-only": "dist/bin-transpile.js", 1631 | "ts-script": "dist/bin-script-deprecated.js" 1632 | }, 1633 | "peerDependencies": { 1634 | "@swc/core": ">=1.2.50", 1635 | "@swc/wasm": ">=1.2.50", 1636 | "@types/node": "*", 1637 | "typescript": ">=2.7" 1638 | }, 1639 | "peerDependenciesMeta": { 1640 | "@swc/core": { 1641 | "optional": true 1642 | }, 1643 | "@swc/wasm": { 1644 | "optional": true 1645 | } 1646 | } 1647 | }, 1648 | "node_modules/typescript": { 1649 | "version": "5.0.4", 1650 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.0.4.tgz", 1651 | "integrity": "sha512-cW9T5W9xY37cc+jfEnaUvX91foxtHkza3Nw3wkoF4sSlKn0MONdkdEndig/qPBWXNkmplh3NzayQzCiHM4/hqw==", 1652 | "dev": true, 1653 | "bin": { 1654 | "tsc": "bin/tsc", 1655 | "tsserver": "bin/tsserver" 1656 | }, 1657 | "engines": { 1658 | "node": ">=12.20" 1659 | } 1660 | }, 1661 | "node_modules/undefsafe": { 1662 | "version": "2.0.5", 1663 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 1664 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==", 1665 | "dev": true 1666 | }, 1667 | "node_modules/universalify": { 1668 | "version": "0.2.0", 1669 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.2.0.tgz", 1670 | "integrity": "sha512-CJ1QgKmNg3CwvAv/kOFmtnEN05f0D/cn9QntgNOQlQF9dgvVTHj3t+8JPdjqawCHk7V/KA+fbUqzZ9XWhcqPUg==", 1671 | "engines": { 1672 | "node": ">= 4.0.0" 1673 | } 1674 | }, 1675 | "node_modules/url-parse": { 1676 | "version": "1.5.10", 1677 | "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.5.10.tgz", 1678 | "integrity": "sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ==", 1679 | "dependencies": { 1680 | "querystringify": "^2.1.1", 1681 | "requires-port": "^1.0.0" 1682 | } 1683 | }, 1684 | "node_modules/uuid": { 1685 | "version": "9.0.0", 1686 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-9.0.0.tgz", 1687 | "integrity": "sha512-MXcSTerfPa4uqyzStbRoTgt5XIe3x5+42+q1sDuy3R5MDk66URdLMOZe5aPX/SQd+kuYAh0FdP/pO28IkQyTeg==", 1688 | "bin": { 1689 | "uuid": "dist/bin/uuid" 1690 | } 1691 | }, 1692 | "node_modules/v8-compile-cache-lib": { 1693 | "version": "3.0.1", 1694 | "resolved": "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz", 1695 | "integrity": "sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg==", 1696 | "dev": true 1697 | }, 1698 | "node_modules/w3c-xmlserializer": { 1699 | "version": "4.0.0", 1700 | "resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-4.0.0.tgz", 1701 | "integrity": "sha512-d+BFHzbiCx6zGfz0HyQ6Rg69w9k19nviJspaj4yNscGjrHu94sVP+aRm75yEbCh+r2/yR+7q6hux9LVtbuTGBw==", 1702 | "dependencies": { 1703 | "xml-name-validator": "^4.0.0" 1704 | }, 1705 | "engines": { 1706 | "node": ">=14" 1707 | } 1708 | }, 1709 | "node_modules/webidl-conversions": { 1710 | "version": "3.0.1", 1711 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", 1712 | "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" 1713 | }, 1714 | "node_modules/whatwg-encoding": { 1715 | "version": "2.0.0", 1716 | "resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-2.0.0.tgz", 1717 | "integrity": "sha512-p41ogyeMUrw3jWclHWTQg1k05DSVXPLcVxRTYsXUk+ZooOCZLcoYgPZ/HL/D/N+uQPOtcp1me1WhBEaX02mhWg==", 1718 | "dependencies": { 1719 | "iconv-lite": "0.6.3" 1720 | }, 1721 | "engines": { 1722 | "node": ">=12" 1723 | } 1724 | }, 1725 | "node_modules/whatwg-mimetype": { 1726 | "version": "3.0.0", 1727 | "resolved": "https://registry.npmjs.org/whatwg-mimetype/-/whatwg-mimetype-3.0.0.tgz", 1728 | "integrity": "sha512-nt+N2dzIutVRxARx1nghPKGv1xHikU7HKdfafKkLNLindmPU/ch3U31NOCGGA/dmPcmb1VlofO0vnKAcsm0o/Q==", 1729 | "engines": { 1730 | "node": ">=12" 1731 | } 1732 | }, 1733 | "node_modules/whatwg-url": { 1734 | "version": "5.0.0", 1735 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", 1736 | "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", 1737 | "dependencies": { 1738 | "tr46": "~0.0.3", 1739 | "webidl-conversions": "^3.0.0" 1740 | } 1741 | }, 1742 | "node_modules/ws": { 1743 | "version": "8.13.0", 1744 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.13.0.tgz", 1745 | "integrity": "sha512-x9vcZYTrFPC7aSIbj7sRCYo7L/Xb8Iy+pW0ng0wt2vCJv7M9HOMy0UoN3rr+IFC7hb7vXoqS+P9ktyLLLhO+LA==", 1746 | "engines": { 1747 | "node": ">=10.0.0" 1748 | }, 1749 | "peerDependencies": { 1750 | "bufferutil": "^4.0.1", 1751 | "utf-8-validate": ">=5.0.2" 1752 | }, 1753 | "peerDependenciesMeta": { 1754 | "bufferutil": { 1755 | "optional": true 1756 | }, 1757 | "utf-8-validate": { 1758 | "optional": true 1759 | } 1760 | } 1761 | }, 1762 | "node_modules/xml-name-validator": { 1763 | "version": "4.0.0", 1764 | "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-4.0.0.tgz", 1765 | "integrity": "sha512-ICP2e+jsHvAj2E2lIHxa5tjXRlKDJo4IdvPvCXbXQGdzSfmSpNVyIKMvoZHjDY9DP0zV17iI85o90vRFXNccRw==", 1766 | "engines": { 1767 | "node": ">=12" 1768 | } 1769 | }, 1770 | "node_modules/xmlchars": { 1771 | "version": "2.2.0", 1772 | "resolved": "https://registry.npmjs.org/xmlchars/-/xmlchars-2.2.0.tgz", 1773 | "integrity": "sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw==" 1774 | }, 1775 | "node_modules/yaml": { 1776 | "version": "2.3.1", 1777 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.3.1.tgz", 1778 | "integrity": "sha512-2eHWfjaoXgTBC2jNM1LRef62VQa0umtvRiDSk6HSzW7RvS5YtkabJrwYLLEKWBc8a5U2PTSCs+dJjUTJdlHsWQ==", 1779 | "engines": { 1780 | "node": ">= 14" 1781 | } 1782 | }, 1783 | "node_modules/yn": { 1784 | "version": "3.1.1", 1785 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 1786 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 1787 | "dev": true, 1788 | "engines": { 1789 | "node": ">=6" 1790 | } 1791 | }, 1792 | "node_modules/zod": { 1793 | "version": "3.21.4", 1794 | "resolved": "https://registry.npmjs.org/zod/-/zod-3.21.4.tgz", 1795 | "integrity": "sha512-m46AKbrzKVzOzs/DZgVnG5H55N1sv1M8qZU3A8RIKbs3mrACDNeIOeilDymVb2HdmP8uwshOCF4uJ8uM9rCqJw==", 1796 | "funding": { 1797 | "url": "https://github.com/sponsors/colinhacks" 1798 | } 1799 | }, 1800 | "node_modules/zod-to-json-schema": { 1801 | "version": "3.21.1", 1802 | "resolved": "https://registry.npmjs.org/zod-to-json-schema/-/zod-to-json-schema-3.21.1.tgz", 1803 | "integrity": "sha512-y5g0MPxDq+YG/T+cHGPYH4PcBpyCqwK6wxeJ76MR563y0gk/14HKfebq8xHiItY7lkc9GDFygCnkvNDTvAhYAg==", 1804 | "peerDependencies": { 1805 | "zod": "^3.21.4" 1806 | } 1807 | } 1808 | } 1809 | } 1810 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "test-web-langchain", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "src/index.js", 6 | "scripts": { 7 | "start:dev": "npx nodemon", 8 | "build": "rimraf ./build && tsc", 9 | "start": "npm run build && node build/index.js", 10 | "test": "echo \"Error: no test specified\" && exit 1" 11 | }, 12 | "author": "", 13 | "license": "ISC", 14 | "devDependencies": { 15 | "@types/jsdom": "^21.1.1", 16 | "@types/node": "^20.2.5", 17 | "nodemon": "^2.0.22", 18 | "ts-node": "^10.9.1", 19 | "typescript": "^5.0.4" 20 | }, 21 | "dependencies": { 22 | "axios": "^1.4.0", 23 | "cheerio": "^1.0.0-rc.12", 24 | "dotenv": "^16.0.3", 25 | "jsdom": "^22.1.0", 26 | "langchain": "^0.0.84" 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /src/StyleTool.ts: -------------------------------------------------------------------------------- 1 | import axios from "axios"; 2 | import { DynamicTool } from "langchain/tools"; 3 | import { JSDOM } from "jsdom"; 4 | 5 | 6 | const systemColors = { 7 | 'ActiveBorder': 'rgb(212,208,200)', 8 | 'ActiveCaption': 'rgb(10,36,106)', 9 | 'AppWorkspace': 'rgb(128,128,128)', 10 | 'Background': 'rgb(58,110,165)', 11 | 'ButtonFace': 'rgb(236,233,216)', 12 | 'ButtonHighlight': 'rgb(255,255,255)', 13 | 'ButtonShadow': 'rgb(172,168,153)', 14 | 'ButtonText': 'rgb(0,0,0)', 15 | 'CaptionText': 'rgb(255,255,255)', 16 | 'GrayText': 'rgb(172,168,153)', 17 | 'Highlight': 'rgb(10,36,106)', 18 | 'HighlightText': 'rgb(255,255,255)', 19 | 'InactiveBorder': 'rgb(212,208,200)', 20 | 'InactiveCaption': 'rgb(122,150,223)', 21 | 'InactiveCaptionText': 'rgb(216,228,248)', 22 | 'InfoBackground': 'rgb(255,255,225)', 23 | 'InfoText': 'rgb(0,0,0)', 24 | 'Menu': 'rgb(255,255,255)', 25 | 'MenuText': 'rgb(0,0,0)', 26 | 'Scrollbar': 'rgb(212,208,200)', 27 | 'ThreeDDarkShadow': 'rgb(113,111,100)', 28 | 'ThreeDFace': 'rgb(236,233,216)', 29 | 'ThreeDHighlight': 'rgb(255,255,255)', 30 | 'ThreeDLightShadow': 'rgb(241,239,226)', 31 | 'ThreeDShadow': 'rgb(172,168,153)', 32 | 'Window': 'rgb(255,255,255)', 33 | 'WindowFrame': 'rgb(0,0,0)', 34 | 'WindowText': 'rgb(0,0,0)' 35 | } as Record; 36 | 37 | const selectors = ["button", "input", "a", "p", "span", "img", "h1", "h2", "h3", "h4", "h5", "h6", "textarea", "select", "option", "label", "form", "table", "tr", "td", "th", "ul", "ol", "li", "nav", "header", "footer", "section", "article", "main", "aside", "div"]; 38 | 39 | const relevantProperties = [ 40 | 'color', 'background', 'background-color', 'background-image', 'font-family', 'font-size', 41 | 'margin', 'margin-block', 'margin-inline', 42 | 'padding', 'padding-block', 'padding-inline', 43 | 'width', 'height', 'min-width', 'min-height', 'max-width', 'max-height', 44 | 'border-radius', 45 | 'border', 'border-width', 'border-top-width', 'border-bottom-width', 'border-left-width', 'border-right-width', 46 | 'box-shadow', 47 | ]; 48 | 49 | const valueRegexesToIgnore = [ 50 | /url\(data:image/, 51 | /url\(http/, 52 | ]; 53 | 54 | interface ParsedInput { 55 | url: string; 56 | // selectors: string[]; 57 | } 58 | 59 | // Helper function to fetch and process styles 60 | const fetchAndProcessStyles = async (input: string): Promise => { 61 | try { 62 | const { url } = parseInput(input); 63 | 64 | // Fetch the HTML of the webpage 65 | const response = await axios.get(url); 66 | const html = response.data; 67 | 68 | // Parse the HTML and extract the CSS styles 69 | const dom = new JSDOM(html, { url, resources: "usable", runScripts: "outside-only" }); 70 | const document = dom.window.document; 71 | 72 | const loaderPromise = new Promise((resolve, reject) => { 73 | dom.window.addEventListener('load', function () { 74 | // All resources are loaded, you can start manipulating the DOM here. 75 | resolve("Success!"); 76 | }); 77 | // Set a timeout to reject the promise after a certain amount of time to prevent hanging forever in case the 'load' event never fires. 78 | setTimeout(() => reject('Timeout'), 10000); 79 | }); 80 | await loaderPromise; 81 | 82 | // Extract the styles from the selectors 83 | const styleCounts: Record>> = {}; 84 | 85 | // Extract the styles from the selectors 86 | for (const selector of selectors) { 87 | const elements = document.querySelectorAll(selector) as any as Element[]; 88 | for (const element of elements) { 89 | const computedStyle = dom.window.getComputedStyle(element); 90 | const elementStyles = Array.from(computedStyle) 91 | .filter((key) => relevantProperties.includes(key)) // Only consider the relevant properties 92 | .reduce((acc, key) => { 93 | const fieldValue = computedStyle.getPropertyValue(key); 94 | 95 | // ignore if in valueRegexesToIgnore 96 | if (valueRegexesToIgnore.some((regex) => regex.test(fieldValue))) { 97 | return acc; 98 | } 99 | acc[key] = fieldValue; 100 | //if css variable then look up the value 101 | if (acc[key].startsWith("var(")) { 102 | const cssVar = acc[key].replace("var(", "").replace(")", "").trim(); 103 | const varLav = computedStyle.getPropertyValue(cssVar); 104 | if (varLav) { 105 | acc[key] = varLav; 106 | } 107 | } 108 | 109 | 110 | return acc; 111 | }, {} as Record); 112 | 113 | // Add the element's styles to styleCounts 114 | for (const [property, value] of Object.entries(elementStyles)) { 115 | let finalValue = value; 116 | if (systemColors[value]) { 117 | finalValue = systemColors[value]; 118 | } 119 | if (!styleCounts[selector]) { 120 | styleCounts[selector] = {}; 121 | } 122 | if (!styleCounts[selector][property]) { 123 | styleCounts[selector][property] = {}; 124 | } 125 | if (!styleCounts[selector][property][finalValue]) { 126 | styleCounts[selector][property][finalValue] = 0; 127 | } 128 | styleCounts[selector][property][finalValue]++; 129 | } 130 | } 131 | } 132 | 133 | const sortedStyles: Record> = {}; 134 | 135 | for (const [selector, properties] of Object.entries(styleCounts)) { 136 | sortedStyles[selector] = {}; 137 | for (const [property, counts] of Object.entries(properties)) { 138 | sortedStyles[selector][property] = Object.entries(counts).sort((a, b) => b[1] - a[1]).map(([value]) => [value]); 139 | } 140 | } 141 | 142 | console.log(JSON.stringify(sortedStyles, null, 2)); 143 | 144 | if (Object.keys(sortedStyles).length === 0) { 145 | return "No styles found for the given selectors."; 146 | } 147 | const safeLength = 7000; 148 | const stylesSafeLength = JSON.stringify(sortedStyles).slice(0, safeLength); 149 | return stylesSafeLength; 150 | } catch (error: any) { 151 | console.error(error); 152 | return `Error: ${ error.message }`; 153 | } 154 | }; 155 | 156 | // Helper function to parse input 157 | const parseInput = (input: string): ParsedInput => { 158 | input = input.replace(/^"(.*)"$/, '$1'); 159 | return { url: input } 160 | }; 161 | 162 | 163 | // Define the tool 164 | const styleTool = new DynamicTool({ 165 | name: "StyleExtractorTool", 166 | description: `Return JSON representation of the most common CSS style properties for elements on a webpage and their counts from a given URL. 167 | Input should be a single valid url. Example: "https://www.google.com"`, 168 | func: fetchAndProcessStyles, 169 | }); 170 | 171 | export default styleTool; -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | import 'dotenv/config'; 2 | import { ChatOpenAI } from "langchain/chat_models/openai"; 3 | import { initializeAgentExecutorWithOptions } from "langchain/agents"; 4 | import StyleTool from "./StyleTool"; 5 | 6 | // Define the URL and input message as constants for better readability 7 | const URL = "https://www.airbnb.ca/"; 8 | 9 | const ELEMENT_DESCRIPTION = "a design system - with a small set of reusible core components and styles that match the brand style"; 10 | 11 | const inputMessage = `With the aid of the StyleExtractorTool, our task is to construct an HTML page featuring a ${ELEMENT_DESCRIPTION}. The style of this element should be inspired by the aesthetics of ${URL}. We will restrict the use of the tool to only one instance. Your output should exclusively consist of valid HTML and CSS code, and any other information or output should be omitted. Please refrain from utilizing CSS variables such as var(--box-shadow). And refrain from linking to external style sheets. For text content, Lorem Ipsum should be used. For image URLs, please use the following placeholder: http://via.placeholder.com/640x360. It's crucial to ensure a high contrast between the background and foreground to maintain legibility. 12 | `; 13 | 14 | async function run() { 15 | // Initialize the model with desired parameters 16 | const model = new ChatOpenAI({ 17 | modelName:"gpt-3.5-turbo", 18 | temperature: 0.4, 19 | verbose: true, 20 | timeout: 5 * 60 * 1000 21 | }); 22 | 23 | // Add StyleTool to the tools array 24 | const tools = [StyleTool]; 25 | 26 | // Initialize the executor with the tools and model 27 | const executor = await initializeAgentExecutorWithOptions(tools, model, { 28 | agentType: "chat-zero-shot-react-description", 29 | maxIterations: 6, 30 | }); 31 | 32 | console.log(`Executing agent with input "${ inputMessage }"...`); 33 | 34 | // Call the executor with the input message 35 | const result = await executor.call({ input: inputMessage }); 36 | 37 | 38 | console.log(`Got output ${ result.output }`); 39 | 40 | } 41 | 42 | // Run the async function 43 | run().catch(error => console.error(error)); -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es2015", 4 | "module": "commonjs", 5 | "lib": ["es6"], 6 | "allowJs": true, 7 | "outDir": "build", 8 | "rootDir": "src", 9 | "strict": true, 10 | "noImplicitAny": true, 11 | "esModuleInterop": true, 12 | "resolveJsonModule": true, 13 | } 14 | } 15 | --------------------------------------------------------------------------------