From 9a831e92d03acb6ab0fe95d027145ea9d1184f77 Mon Sep 17 00:00:00 2001
From: iPromKnight <156901906+iPromKnight@users.noreply.github.com>
Date: Mon, 25 Mar 2024 23:32:28 +0000
Subject: [PATCH] Producer / Consumer / Collector rewrite (#160)
* Converted metadata service to redis
* move to postgres instead
* fix global usings
* [skip ci] optimize wolverine by prebuilding static types
* [skip ci] Stop indexing mac folder indexes
* [skip ci] producer, metadata and migrations
removed mongodb
added redis cache
imdb meta in postgres
Enable pgtrm
Create trigrams index
Add search meta postgres function
* [skip ci] get rid of node folder, replace mongo with redis in consumer
also wire up postgres metadata searches
* [skip ci] change mongo to redis in the addon
* [skip ci] jackettio to redis
* Rest of mongo removed...
* Cleaner rerunning of metadata - without conflicts
* Add akas import as well as basic metadata
* Include episodes file too
* cascade truncate pre-import
* reverse order to avoid cascadeing
* separate out clean to separate handler
* Switch producer to use metadata matching pre-preocessing dmm
* More work
* Still porting PTN
* PTN port, adding tests
* [skip ci] Codec tests
* [skip ci] Complete Collection handler tests
* [skip ci] container tests
* [skip ci] Convert handlers tests
* [skip ci] DateHandler tests
* [skip ci] Dual Audio matching tests
* [skip ci] episode code tests
* [skip ci] Extended handler tests
* [skip ci] group handler tests
* [skip ci] some broken stuff right now
* [skip ci] more ptn
* [skip ci] PTN now in a separate nuget package, rebased this on the redis changes - i need them.
* [skip ci] Wire up PTN port. Tired - will test tomorrow
* [skip ci] Needs a lot of work - too many titles being missed now
* cleaner. done?
* Handle the date in the imdb search
- add integer function to confirm its a valid integer
- use the input date as a range of -+1 year
* [skip ci] Start of collector service for RD
[skip ci] WIP
Implemented metadata saga, along with channels to process up to a maximum of 100 infohashes each time
The saga will rety for each infohas by requeuing up to three times, before just marking as complete for that infoHash - meaning no data will be updated in the db for that torrent.
[skip ci] Ready to test with queue publishing
Will provision a fanout exchange if it doesn't exist, and create and bind a queue to it. Listens to the queue with 50 prefetch count.
Still needs PTN rewrite bringing in to parse the filename response from real debrid, and extract season and episode numbers if the file is a tvshow
[skip ci] Add Debrid Collector Build Job
Debrid Collector ready for testing
New consumer, new collector, producer has meta lookup and anti porn measures
[skip ci] WIP - moving from wolverine to MassTransit.
not happy that wolverine cannot effectively control saga concurrency. we need to really.
[skip ci] Producer and new Consumer moved to MassTransit
Just the debrid collector to go now, then to write the optional qbit collector.
Collector now switched to mass transit too
hide porn titles in logs, clean up cache name in redis for imdb titles
[skip ci] Allow control of queues
[skip ci] Update deployment
Remove old consumer, fix deployment files, fix dockerfiles for shared project import
fix base deployment
* Add collector missing env var
* edits to kick off builds
* Add optional qbit deployment which qbit collector will use
* Qbit collector done
* reorder compose, and bring both qbit and qbitcollector into the compose, with 0 replicas as default
* Clean up compose file
* Ensure debrid collector errors if no debrid api key
---
.github/workflows/base_image_workflow.yaml | 12 +-
.github/workflows/build_addon.yaml | 5 +-
.github/workflows/build_consumer.yaml | 5 +-
.github/workflows/build_debrid_collector.yaml | 16 +
.github/workflows/build_jackett-addon.yaml | 5 +-
.github/workflows/build_metadata.yaml | 1 +
.github/workflows/build_migrator.yaml | 1 +
.github/workflows/build_producer.yaml | 3 +-
.github/workflows/build_qbit_collector.yaml | 16 +
.github/workflows/build_tissue.yaml | 1 +
.gitignore | 5 +-
deployment/docker/.env.example | 37 +-
.../components/config/qbit/qbittorrent.conf | 58 +
.../docker/components/infrastructure.yaml | 89 +
.../docker/components/knightcrawler.yaml | 71 +
deployment/docker/components/network.yaml | 4 +
deployment/docker/components/volumes.yaml | 4 +
deployment/docker/compose.override.yaml | 7 +
deployment/docker/compose.yaml | 7 +
deployment/docker/docker-compose.yaml | 139 -
src/{node => }/addon-jackett/.dockerignore | 0
src/{node => }/addon-jackett/.eslintignore | 0
src/{node => }/addon-jackett/.eslintrc.cjs | 0
src/{node => }/addon-jackett/Dockerfile | 0
src/{node => }/addon-jackett/README.md | 0
src/{node => }/addon-jackett/build.sh | 0
.../addon-jackett/ecosystem.config.cjs | 0
src/{node => }/addon-jackett/esbuild.js | 0
src/{node => }/addon-jackett/jsconfig.json | 0
.../addon-jackett/package-lock.json | 1111 +-
src/{node => }/addon-jackett/package.json | 7 +-
src/{node => }/addon-jackett/src/addon.js | 0
src/{node => }/addon-jackett/src/index.js | 0
.../addon-jackett/src/jackett/jacketParser.js | 0
.../addon-jackett/src/jackett/jackett.js | 0
.../src/jackett/jackettQueries.js | 0
src/{node => }/addon-jackett/src/lib/cache.js | 38 +-
.../addon-jackett/src/lib/cinemetaProvider.js | 0
.../addon-jackett/src/lib/configuration.js | 0
.../addon-jackett/src/lib/extension.js | 0
.../addon-jackett/src/lib/landingTemplate.js | 0
.../addon-jackett/src/lib/magnetHelper.js | 0
.../addon-jackett/src/lib/manifest.js | 0
.../addon-jackett/src/lib/promises.js | 0
.../addon-jackett/src/lib/requestHelper.js | 0
.../addon-jackett/src/lib/settings.js | 2 +-
src/{node => }/addon-jackett/src/lib/sort.js | 0
.../addon-jackett/src/lib/streamInfo.js | 0
src/{node => }/addon-jackett/src/lib/types.js | 0
.../addon-jackett/src/moch/alldebrid.js | 0
.../addon-jackett/src/moch/debridlink.js | 0
src/{node => }/addon-jackett/src/moch/moch.js | 0
.../addon-jackett/src/moch/mochHelper.js | 0
.../addon-jackett/src/moch/offcloud.js | 0
.../addon-jackett/src/moch/options.js | 0
.../addon-jackett/src/moch/premiumize.js | 0
.../addon-jackett/src/moch/putio.js | 0
.../addon-jackett/src/moch/realdebrid.js | 0
.../addon-jackett/src/moch/static.js | 0
.../addon-jackett/src/serverless.js | 0
.../static/videos/download_failed_v2.mp4 | Bin
.../static/videos/downloading_v2.mp4 | Bin
.../static/videos/failed_access_v2.mp4 | Bin
.../static/videos/failed_infringement_v2.mp4 | Bin
.../static/videos/failed_opening_v2.mp4 | Bin
.../static/videos/failed_rar_v2.mp4 | Bin
.../static/videos/failed_unexpected_v2.mp4 | Bin
src/{node => }/addon/.dockerignore | 0
src/{node => }/addon/.eslintignore | 0
src/{node => }/addon/.eslintrc.cjs | 0
src/{node => }/addon/Dockerfile | 0
src/{node => }/addon/ecosystem.config.cjs | 0
src/{node => }/addon/esbuild.js | 0
src/{node => }/addon/jsconfig.json | 0
src/{node => }/addon/package-lock.json | 1025 +-
src/{node => }/addon/package.json | 7 +-
src/{node => }/addon/src/addon.js | 0
src/{node => }/addon/src/index.js | 0
src/{node => }/addon/src/lib/cache.js | 16 +-
src/{node => }/addon/src/lib/config.js | 12 +-
src/{node => }/addon/src/lib/configuration.js | 0
src/{node => }/addon/src/lib/extension.js | 0
src/{node => }/addon/src/lib/filter.js | 0
.../addon/src/lib/landingTemplate.js | 0
src/{node => }/addon/src/lib/languages.js | 0
src/{node => }/addon/src/lib/magnetHelper.js | 0
src/{node => }/addon/src/lib/manifest.js | 0
src/{node => }/addon/src/lib/promises.js | 0
src/{node => }/addon/src/lib/repository.js | 0
src/{node => }/addon/src/lib/requestHelper.js | 0
src/{node => }/addon/src/lib/sort.js | 0
src/{node => }/addon/src/lib/streamInfo.js | 0
src/{node => }/addon/src/lib/subtitles.js | 0
src/{node => }/addon/src/lib/titleHelper.js | 0
src/{node => }/addon/src/lib/types.js | 0
src/{node => }/addon/src/moch/alldebrid.js | 0
src/{node => }/addon/src/moch/debridlink.js | 0
src/{node => }/addon/src/moch/moch.js | 0
src/{node => }/addon/src/moch/mochHelper.js | 0
src/{node => }/addon/src/moch/offcloud.js | 0
src/{node => }/addon/src/moch/options.js | 0
src/{node => }/addon/src/moch/premiumize.js | 0
src/{node => }/addon/src/moch/putio.js | 0
src/{node => }/addon/src/moch/realdebrid.js | 0
src/{node => }/addon/src/moch/static.js | 0
src/{node => }/addon/src/serverless.js | 0
.../static/videos/download_failed_v2.mp4 | Bin
.../addon/static/videos/downloading_v2.mp4 | Bin
.../addon/static/videos/failed_access_v2.mp4 | Bin
.../static/videos/failed_infringement_v2.mp4 | Bin
.../addon/static/videos/failed_opening_v2.mp4 | Bin
.../addon/static/videos/failed_rar_v2.mp4 | Bin
.../static/videos/failed_unexpected_v2.mp4 | Bin
.../Configuration/logging.json | 36 +
src/debrid-collector/DebridCollector.csproj | 38 +
src/debrid-collector/DebridCollector.sln | 27 +
src/debrid-collector/Dockerfile | 20 +
.../Extensions/ServiceCollectionExtensions.cs | 73 +
.../DebridCollectorConfiguration.cs | 8 +
.../Features/Debrid/DebridRequestProcessor.cs | 64 +
.../Features/Debrid/IDebridHttpClient.cs | 6 +
.../Features/Debrid/ProcessorChannel.cs | 12 +
.../Features/Debrid/RealDebridClient.cs | 65 +
.../Features/Debrid/RealDebridResponse.cs | 24 +
.../Debrid/ServiceCollectionExtensions.cs | 32 +
.../Worker/DebridMetaToTorrentMeta.cs | 82 +
.../Features/Worker/Filetypes.cs | 104 +
.../Worker/InfohashMetadataSagaState.cs | 14 +
.../InfohashMetadataSagaStateMachine.cs | 63 +
.../Worker/PerformMetadataRequestConsumer.cs | 10 +
.../Features/Worker/Requests.cs | 22 +
.../Worker/TorrentMetadataResponse.cs | 4 +
.../Features/Worker/WriteMetadataConsumer.cs | 25 +
src/debrid-collector/GlobalUsings.cs | 20 +
src/debrid-collector/Program.cs | 17 +
.../Extensions/ServiceCollectionExtensions.cs | 31 +-
.../WebApplicationBuilderExtensions.cs | 2 +
.../ClearExistingImdbDataRequest.cs | 3 +
.../ClearExistingImdbDataRequestHandler.cs | 16 +
.../Configuration/JobConfiguration.cs | 13 -
.../Configuration/MongoConfiguration.cs | 20 -
.../Configuration}/PostgresConfiguration.cs | 2 +-
.../Configuration/ServiceConfiguration.cs | 9 +
.../DeleteDownloadedImdbDataRequest.cs | 2 +-
.../DeleteDownloadedImdbDataRequestHandler.cs | 24 +-
.../DownloadImdbData/DownloadImdbDataJob.cs | 8 -
.../GetImdbDataRequestHandler.cs | 26 +-
.../DownloadImdbData/IImdbFileDownloader.cs | 6 +
.../DownloadImdbData/ImdbFileDownloader.cs | 24 +
src/metadata/Features/Files/AkasFile.cs | 89 +
src/metadata/Features/Files/BasicsFile.cs | 86 +
src/metadata/Features/Files/EpisodesFile.cs | 83 +
src/metadata/Features/Files/IFileImport.cs | 6 +
src/metadata/Features/Files/ImdbAkaEntry.cs | 13 +
src/metadata/Features/Files/ImdbBasicEntry.cs | 10 +
.../Features/Files/ImdbEpisodeEntry.cs | 9 +
.../Features/ImportImdbData/ImdbDbService.cs | 174 +
.../Features/ImportImdbData/ImdbEntry.cs | 15 -
.../ImportImdbData/ImdbMongoDbService.cs | 64 -
.../ImportImdbData/ImportImdbDataRequest.cs | 2 +-
.../ImportImdbDataRequestHandler.cs | 99 +-
.../Features/ImportImdbData/TableNames.cs | 8 +
.../IndexImdbData/IndexImdbDataRequest.cs | 3 +
.../IndexImdbDataRequestHandler.cs | 13 +
src/metadata/Features/Jobs/BaseJob.cs | 10 -
.../Features/Jobs/DownloadImdbDataJob.cs | 9 +
src/metadata/Features/Jobs/IMetadataJob.cs | 7 -
src/metadata/Features/Jobs/JobScheduler.cs | 34 -
src/metadata/GlobalUsings.cs | 13 +-
...xistingImdbDataRequestHandler2085209125.cs | 47 +
...ownloadedImdbDataRequestHandler52235941.cs | 37 +
.../GetImdbDataRequestHandler1674247617.cs | 47 +
.../ImportImdbDataRequestHandler968947017.cs | 56 +
.../IndexImdbDataRequestHandler411355483.cs | 47 +
src/metadata/Metadata.csproj | 6 +-
src/metadata/Program.cs | 6 +-
src/migrator/migrations/002_add_metadata.sql | 8 +
src/migrator/migrations/003_enable_pgtrm.sql | 2 +
.../migrations/004_imdb_metadata_query.sql | 14 +
.../migrations/005_add_metadata_akas.sql | 14 +
.../migrations/006_add_metadata_episodes.sql | 10 +
.../007_add_is_integer_function.sql | 8 +
...change_imdb_search_year_plus_minus_one.sql | 20 +
src/node/consumer/.dockerignore | 16 -
src/node/consumer/.eslintignore | 3 -
src/node/consumer/.eslintrc | 84 -
src/node/consumer/.nvmrc | 1 -
src/node/consumer/Dockerfile | 34 -
src/node/consumer/esbuild.ts | 47 -
src/node/consumer/jest.config.ts | 14 -
src/node/consumer/package-lock.json | 10094 -
src/node/consumer/package.json | 61 -
.../consumer/src/lib/enums/cache_types.ts | 4 -
.../consumer/src/lib/enums/torrent_types.ts | 5 -
.../src/lib/helpers/boolean_helpers.ts | 18 -
.../src/lib/helpers/extension_helpers.ts | 66 -
.../src/lib/helpers/promises_helpers.ts | 37 -
.../src/lib/interfaces/cache_options.ts | 3 -
.../src/lib/interfaces/cache_service.ts | 11 -
.../src/lib/interfaces/cinemeta_metadata.ts | 84 -
.../lib/interfaces/common_video_metadata.ts | 9 -
.../lib/interfaces/ingested_rabbit_message.ts | 15 -
.../lib/interfaces/kitsu_catalog_metadata.ts | 23 -
.../src/lib/interfaces/kitsu_metadata.ts | 49 -
.../src/lib/interfaces/logging_service.ts | 12 -
.../src/lib/interfaces/metadata_query.ts | 9 -
.../src/lib/interfaces/metadata_response.ts | 15 -
.../src/lib/interfaces/metadata_service.ts | 14 -
.../interfaces/parse_torrent_title_result.ts | 36 -
.../src/lib/interfaces/parsed_torrent.ts | 18 -
.../lib/interfaces/process_torrents_job.ts | 3 -
.../interfaces/torrent_download_service.ts | 6 -
.../lib/interfaces/torrent_entries_service.ts | 18 -
.../lib/interfaces/torrent_file_collection.ts | 9 -
.../lib/interfaces/torrent_file_service.ts | 8 -
.../interfaces/torrent_processing_service.ts | 5 -
.../interfaces/torrent_subtitle_service.ts | 5 -
.../src/lib/interfaces/tracker_service.ts | 3 -
.../src/lib/jobs/process_torrents_job.ts | 63 -
.../lib/models/configuration/cache_config.ts | 15 -
.../models/configuration/database_config.ts | 14 -
.../lib/models/configuration/job_config.ts | 6 -
.../models/configuration/metadata_config.ts | 5 -
.../lib/models/configuration/rabbit_config.ts | 13 -
.../models/configuration/torrent_config.ts | 4 -
.../models/configuration/tracker_config.ts | 7 -
.../mongo/interfaces/imdb_entry_attributes.ts | 13 -
.../mongo/interfaces/mongo_metadata_query.ts | 5 -
.../lib/mongo/interfaces/mongo_repository.ts | 4 -
.../lib/mongo/models/imdb_entries_model.ts | 18 -
.../src/lib/mongo/mongo_repository.ts | 63 -
.../src/lib/repository/database_repository.ts | 260 -
.../interfaces/content_attributes.ts | 11 -
.../interfaces/database_repository.ts | 64 -
.../repository/interfaces/file_attributes.ts | 22 -
.../interfaces/ingested_page_attributes.ts | 6 -
.../interfaces/ingested_torrent_attributes.ts | 17 -
.../interfaces/provider_attributes.ts | 10 -
.../interfaces/skip_torrent_attributes.ts | 8 -
.../interfaces/subtitle_attributes.ts | 12 -
.../interfaces/torrent_attributes.ts | 26 -
.../src/lib/repository/models/content.ts | 22 -
.../src/lib/repository/models/file.ts | 59 -
.../src/lib/repository/models/ingestedPage.ts | 16 -
.../lib/repository/models/ingestedTorrent.ts | 40 -
.../src/lib/repository/models/provider.ts | 15 -
.../src/lib/repository/models/skipTorrent.ts | 9 -
.../src/lib/repository/models/subtitle.ts | 38 -
.../src/lib/repository/models/torrent.ts | 56 -
.../src/lib/services/cache_service.ts | 116 -
.../src/lib/services/configuration_service.ts | 17 -
.../src/lib/services/logging_service.ts | 32 -
.../src/lib/services/metadata_service.ts | 218 -
.../lib/services/torrent_download_service.ts | 164 -
.../lib/services/torrent_entries_service.ts | 298 -
.../src/lib/services/torrent_file_service.ts | 312 -
.../services/torrent_processing_service.ts | 59 -
.../lib/services/torrent_subtitle_service.ts | 107 -
.../src/lib/services/tracker_service.ts | 42 -
src/node/consumer/src/main.ts | 9 -
.../consumer/src/setup/composition_root.ts | 25 -
.../consumer/src/setup/inversify_config.ts | 45 -
src/node/consumer/src/setup/ioc_types.ts | 19 -
.../test/helpers/boolean_helpers.test.ts | 31 -
.../test/helpers/extension_helpers.test.ts | 33 -
.../test/helpers/promise_helpers.test.ts | 55 -
.../assets/cinemeta-query-response.json | 21006 --
.../assets/flash-episode-list.json | 232 -
.../assets/kitsu-naruto-full.json | 2491 -
.../assets/name-to-imdb-flash.json | 111 -
.../assets/test-cinemata-theflash.json | 373 -
.../assets/test-kitsu-search-id-naruto.json | 1060 -
.../mock-responses/metadata_mock_responses.ts | 40 -
.../mock-responses/trackers_mock_responses.ts | 5 -
.../test/services/cache_service.test.ts | 124 -
.../services/configuration_service.test.ts | 148 -
.../test/services/logging_service.test.ts | 46 -
.../test/services/metadata_service.test.ts | 133 -
.../test/services/mongo_repository.test.ts | 100 -
.../test/services/process_torrent_job.test.ts | 137 -
.../services/torrent_download_service.test.ts | 148 -
.../services/torrent_entries_service.test.ts | 360 -
.../services/torrent_file_service.test.ts | 225 -
.../services/torrent_subtitle_service.test.ts | 102 -
.../test/services/tracker_service.test.ts | 62 -
src/node/consumer/tsconfig.json | 67 -
src/producer/Data/adult-compound-words.txt | 3003 -
src/producer/Data/adult-stars.txt | 17681 --
src/producer/Data/adult-words.txt | 1672 -
src/producer/Data/common-words.txt | 172964 -----------
src/producer/Data/jav.txt | 234602 ---------------
.../ConfigureHostBuilderExtensions.cs | 8 -
.../Features/Amqp/IMessagePublisher.cs | 6 -
.../Amqp/ServiceCollectionExtensions.cs | 24 -
.../DataProcessing/DapperDataStorage.cs | 133 -
.../Features/DataProcessing/IDataStorage.cs | 10 -
.../Features/DataProcessing/ImdbEntry.cs | 15 -
.../DataProcessing/ImdbMongoDbService.cs | 83 -
.../ParseTorrentTitle/AudioChannels.cs | 13 -
.../ParseTorrentTitle/AudioChannelsParser.cs | 50 -
.../Features/ParseTorrentTitle/AudioCodecs.cs | 22 -
.../ParseTorrentTitle/AudioCodecsParser.cs | 138 -
.../Features/ParseTorrentTitle/BaseParsed.cs | 19 -
.../Features/ParseTorrentTitle/Complete.cs | 14 -
.../Features/ParseTorrentTitle/Edition.cs | 26 -
.../ParseTorrentTitle/EditionParser.cs | 101 -
.../ParseTorrentTitle/FileExtensionParser.cs | 78 -
.../Features/ParseTorrentTitle/GroupParser.cs | 71 -
.../ParseTorrentTitle/IParsingService.cs | 24 -
.../ParseTorrentTitle/ITorrentTitleParser.cs | 7 -
.../Features/ParseTorrentTitle/Language.cs | 50 -
.../ParseTorrentTitle/LanguageParser.cs | 340 -
.../ParseTorrentTitle/ParsedFilename.cs | 10 -
.../Features/ParseTorrentTitle/ParsedMovie.cs | 5 -
.../Features/ParseTorrentTitle/ParsedTv.cs | 15 -
.../ParseTorrentTitle/ParsingService.Regex.cs | 29 -
.../ParseTorrentTitle/ParsingService.cs | 353 -
.../ParseTorrentTitle/QualityModel.cs | 9 -
.../ParseTorrentTitle/QualityModifier.cs | 10 -
.../ParseTorrentTitle/QualityParser.cs | 230 -
.../Features/ParseTorrentTitle/Resolution.cs | 13 -
.../ParseTorrentTitle/ResolutionParser.cs | 55 -
.../Features/ParseTorrentTitle/Revision.cs | 7 -
.../Features/ParseTorrentTitle/Season.cs | 16 -
.../SeasonParser.RejectRegex.cs | 44 -
.../SeasonParser.ValidRegex.cs | 248 -
.../ParseTorrentTitle/SeasonParser.cs | 307 -
.../ServiceCollectionExtensions.cs | 12 -
.../Features/ParseTorrentTitle/Source.cs | 20 -
.../ParseTorrentTitle/SourceParser.cs | 151 -
.../Features/ParseTorrentTitle/TitleParser.cs | 197 -
.../ParseTorrentTitle/TorrentTitleParser.cs | 142 -
.../Features/ParseTorrentTitle/TorrentType.cs | 7 -
.../Features/ParseTorrentTitle/VideoCodecs.cs | 16 -
.../ParseTorrentTitle/VideoCodecsParser.cs | 89 -
.../Features/Wordlists/IWordCollections.cs | 16 -
.../Features/Wordlists/PopulationService.cs | 21 -
.../Wordlists/ServiceCollectionExtensions.cs | 12 -
.../Features/Wordlists/WordCollections.cs | 65 -
src/producer/Producer.sln | 27 +
src/producer/src/Configuration/logging.json | 37 +
.../{ => src}/Configuration/scrapers.json | 0
.../{ => src}/Configuration/torrentio.json | 2 +-
src/producer/{ => src}/Dockerfile | 13 +-
.../src/Extensions/ConfigurationExtensions.cs | 22 +
.../src/Features/Amqp/IMessagePublisher.cs | 6 +
.../{ => src}/Features/Amqp/PublisherJob.cs | 18 +-
.../Amqp/ServiceCollectionExtensions.cs | 32 +
.../Features/Amqp/TorrentPublisher.cs | 25 +-
.../Features/CrawlerSupport/BaseCrawler.cs | 12 +-
.../CrawlerSupport/BaseJsonCrawler.cs | 4 +-
.../Features/CrawlerSupport/BaseXmlCrawler.cs | 4 +-
.../CrawlerSupport/CrawlerProvider.cs | 0
.../Features/CrawlerSupport/ICrawler.cs | 0
.../CrawlerSupport/ICrawlerProvider.cs | 0
.../Features/CrawlerSupport/Literals.cs | 0
.../Features/CrawlerSupport/Scraper.cs | 0
.../ServiceCollectionExtensions.cs | 0
.../Crawlers/Dmm/DebridMediaManagerCrawler.cs | 142 +-
.../Crawlers/Dmm/GithubConfiguration.cs | 0
.../Features/Crawlers/Dmm/SyncDmmJob.cs | 0
.../Features/Crawlers/EzTv/EzTvCrawler.cs | 26 +-
.../Features/Crawlers/EzTv/SyncEzTvJob.cs | 0
.../Features/Crawlers/Nyaa/NyaaCrawler.cs | 22 +-
.../Features/Crawlers/Nyaa/SyncNyaaJob.cs | 0
.../Features/Crawlers/Tgx/SyncTgxJob.cs | 0
.../Features/Crawlers/Tgx/TgxCrawler.cs | 16 +-
.../Crawlers/Torrentio/SyncTorrentioJob.cs | 0
.../Torrentio/TorrentioConfiguration.cs | 0
.../Crawlers/Torrentio/TorrentioCrawler.cs | 40 +-
.../Crawlers/Torrentio/TorrentioInstance.cs | 0
.../Torrentio/TorrentioInstanceExtensions.cs | 0
.../Crawlers/Torrentio/TorrentioRateLimit.cs | 2 +-
.../Torrentio/TorrentioScrapeInstance.cs | 2 +-
.../Features/Crawlers/Tpb/SyncTpbJob.cs | 0
.../Features/Crawlers/Tpb/TpbCrawler.cs | 16 +-
.../Features/Crawlers/Yts/SyncYtsJob.cs | 0
.../Features/Crawlers/Yts/YtsCrawler.cs | 16 +-
.../ServiceCollectionExtensions.cs | 11 +-
.../{ => src}/Features/JobSupport/BaseJob.cs | 0
.../Features/JobSupport/ICrawlerJob.cs | 0
.../{ => src}/Features/JobSupport/Literals.cs | 0
.../ManualJobRegistrationAttribute.cs | 0
.../JobSupport/ScrapeConfiguration.cs | 0
.../JobSupport/ServiceCollectionExtensions.cs | 1 +
src/producer/{ => src}/GlobalUsings.cs | 20 +-
src/producer/{ => src}/Producer.csproj | 14 +-
src/producer/{ => src}/Program.cs | 9 +-
src/qbit-collector/Configuration/logging.json | 36 +
src/qbit-collector/Dockerfile | 20 +
.../Extensions/ServiceCollectionExtensions.cs | 112 +
.../Features/Qbit/QBitRequestProcessor.cs | 56 +
.../Features/Qbit/QbitConfiguration.cs | 9 +
.../Features/Trackers/ITrackersService.cs | 6 +
.../Trackers/TrackersBackgroundService.cs | 8 +
.../Features/Trackers/TrackersService.cs | 55 +
.../Features/Worker/Filetypes.cs | 104 +
.../PerformQbitMetadataRequestConsumer.cs | 21 +
.../Features/Worker/QBitMetadataResponse.cs | 4 +
.../Features/Worker/QbitMetaToTorrentMeta.cs | 78 +
.../Features/Worker/QbitMetadataSagaState.cs | 13 +
.../Worker/QbitMetadataSagaStateMachine.cs | 63 +
.../Features/Worker/Requests.cs | 22 +
.../Worker/WriteQbitMetadataConsumer.cs | 25 +
src/qbit-collector/GlobalUsings.cs | 24 +
src/qbit-collector/Program.cs | 18 +
src/qbit-collector/QBitCollector.csproj | 40 +
src/qbit-collector/QBitCollector.sln | 27 +
.../Configuration/PostgresConfiguration.cs} | 17 +-
.../Configuration}/RabbitMqConfiguration.cs | 16 +-
.../Configuration/RedisConfiguration.cs | 9 +
src/shared/Dapper/BaseDapperStorage.cs | 53 +
src/shared/Dapper/DapperDataStorage.cs | 189 +
src/shared/Dapper/DapperResult.cs | 21 +
src/shared/Dapper/IDataStorage.cs | 17 +
.../Dapper}/Results.cs | 2 +-
.../Extensions/ConfigurationExtensions.cs | 19 +-
.../Extensions/EnvironmentExtensions.cs | 2 +-
.../Extensions/HostBuilderExtensions.cs | 8 +
.../Extensions/JsonSerializerExtensions.cs | 6 +
.../RabbitMqBusFactoryExtensions.cs | 44 +
.../Extensions/StringExtensions.cs | 19 +-
.../WebApplicationBuilderExtensions.cs | 13 +
src/shared/GlobalUsings.cs | 16 +
src/shared/Models/ImdbEntry.cs | 10 +
.../Models/IngestedTorrent.cs} | 6 +-
src/shared/Models/SubtitleFile.cs | 10 +
src/shared/Models/Torrent.cs | 20 +
src/shared/Models/TorrentFile.cs | 15 +
src/shared/Requests/CollectMetadata.cs | 3 +
src/shared/Requests/IngestTorrent.cs | 3 +
src/shared/SharedContracts.csproj | 25 +
.../Configuration/logging.json | 3 +-
src/torrent-consumer/Dockerfile | 20 +
.../Extensions/ServiceCollectionExtensions.cs | 92 +
.../PerformIngestionConsumer.cs | 26 +
.../Features/TorrentIngestion/Requests.cs | 7 +
.../TorrentIngestionSagaStateMachine.cs | 45 +
.../TorrentIngestion/TorrentIngestionState.cs | 12 +
src/torrent-consumer/GlobalUsings.cs | 16 +
src/torrent-consumer/Program.cs | 17 +
src/torrent-consumer/TorrentConsumer.csproj | 38 +
src/torrent-consumer/TorrentConsumer.sln | 27 +
443 files changed, 4154 insertions(+), 476262 deletions(-)
create mode 100644 .github/workflows/build_debrid_collector.yaml
create mode 100644 .github/workflows/build_qbit_collector.yaml
create mode 100644 deployment/docker/components/config/qbit/qbittorrent.conf
create mode 100644 deployment/docker/components/infrastructure.yaml
create mode 100644 deployment/docker/components/knightcrawler.yaml
create mode 100644 deployment/docker/components/network.yaml
create mode 100644 deployment/docker/components/volumes.yaml
create mode 100644 deployment/docker/compose.override.yaml
create mode 100644 deployment/docker/compose.yaml
delete mode 100644 deployment/docker/docker-compose.yaml
rename src/{node => }/addon-jackett/.dockerignore (100%)
rename src/{node => }/addon-jackett/.eslintignore (100%)
rename src/{node => }/addon-jackett/.eslintrc.cjs (100%)
rename src/{node => }/addon-jackett/Dockerfile (100%)
rename src/{node => }/addon-jackett/README.md (100%)
rename src/{node => }/addon-jackett/build.sh (100%)
rename src/{node => }/addon-jackett/ecosystem.config.cjs (100%)
rename src/{node => }/addon-jackett/esbuild.js (100%)
rename src/{node => }/addon-jackett/jsconfig.json (100%)
rename src/{node => }/addon-jackett/package-lock.json (83%)
rename src/{node => }/addon-jackett/package.json (90%)
rename src/{node => }/addon-jackett/src/addon.js (100%)
rename src/{node => }/addon-jackett/src/index.js (100%)
rename src/{node => }/addon-jackett/src/jackett/jacketParser.js (100%)
rename src/{node => }/addon-jackett/src/jackett/jackett.js (100%)
rename src/{node => }/addon-jackett/src/jackett/jackettQueries.js (100%)
rename src/{node => }/addon-jackett/src/lib/cache.js (79%)
rename src/{node => }/addon-jackett/src/lib/cinemetaProvider.js (100%)
rename src/{node => }/addon-jackett/src/lib/configuration.js (100%)
rename src/{node => }/addon-jackett/src/lib/extension.js (100%)
rename src/{node => }/addon-jackett/src/lib/landingTemplate.js (100%)
rename src/{node => }/addon-jackett/src/lib/magnetHelper.js (100%)
rename src/{node => }/addon-jackett/src/lib/manifest.js (100%)
rename src/{node => }/addon-jackett/src/lib/promises.js (100%)
rename src/{node => }/addon-jackett/src/lib/requestHelper.js (100%)
rename src/{node => }/addon-jackett/src/lib/settings.js (95%)
rename src/{node => }/addon-jackett/src/lib/sort.js (100%)
rename src/{node => }/addon-jackett/src/lib/streamInfo.js (100%)
rename src/{node => }/addon-jackett/src/lib/types.js (100%)
rename src/{node => }/addon-jackett/src/moch/alldebrid.js (100%)
rename src/{node => }/addon-jackett/src/moch/debridlink.js (100%)
rename src/{node => }/addon-jackett/src/moch/moch.js (100%)
rename src/{node => }/addon-jackett/src/moch/mochHelper.js (100%)
rename src/{node => }/addon-jackett/src/moch/offcloud.js (100%)
rename src/{node => }/addon-jackett/src/moch/options.js (100%)
rename src/{node => }/addon-jackett/src/moch/premiumize.js (100%)
rename src/{node => }/addon-jackett/src/moch/putio.js (100%)
rename src/{node => }/addon-jackett/src/moch/realdebrid.js (100%)
rename src/{node => }/addon-jackett/src/moch/static.js (100%)
rename src/{node => }/addon-jackett/src/serverless.js (100%)
rename src/{node => }/addon-jackett/static/videos/download_failed_v2.mp4 (100%)
rename src/{node => }/addon-jackett/static/videos/downloading_v2.mp4 (100%)
rename src/{node => }/addon-jackett/static/videos/failed_access_v2.mp4 (100%)
rename src/{node => }/addon-jackett/static/videos/failed_infringement_v2.mp4 (100%)
rename src/{node => }/addon-jackett/static/videos/failed_opening_v2.mp4 (100%)
rename src/{node => }/addon-jackett/static/videos/failed_rar_v2.mp4 (100%)
rename src/{node => }/addon-jackett/static/videos/failed_unexpected_v2.mp4 (100%)
rename src/{node => }/addon/.dockerignore (100%)
rename src/{node => }/addon/.eslintignore (100%)
rename src/{node => }/addon/.eslintrc.cjs (100%)
rename src/{node => }/addon/Dockerfile (100%)
rename src/{node => }/addon/ecosystem.config.cjs (100%)
rename src/{node => }/addon/esbuild.js (100%)
rename src/{node => }/addon/jsconfig.json (100%)
rename src/{node => }/addon/package-lock.json (85%)
rename src/{node => }/addon/package.json (89%)
rename src/{node => }/addon/src/addon.js (100%)
rename src/{node => }/addon/src/index.js (100%)
rename src/{node => }/addon/src/lib/cache.js (86%)
rename src/{node => }/addon/src/lib/config.js (57%)
rename src/{node => }/addon/src/lib/configuration.js (100%)
rename src/{node => }/addon/src/lib/extension.js (100%)
rename src/{node => }/addon/src/lib/filter.js (100%)
rename src/{node => }/addon/src/lib/landingTemplate.js (100%)
rename src/{node => }/addon/src/lib/languages.js (100%)
rename src/{node => }/addon/src/lib/magnetHelper.js (100%)
rename src/{node => }/addon/src/lib/manifest.js (100%)
rename src/{node => }/addon/src/lib/promises.js (100%)
rename src/{node => }/addon/src/lib/repository.js (100%)
rename src/{node => }/addon/src/lib/requestHelper.js (100%)
rename src/{node => }/addon/src/lib/sort.js (100%)
rename src/{node => }/addon/src/lib/streamInfo.js (100%)
rename src/{node => }/addon/src/lib/subtitles.js (100%)
rename src/{node => }/addon/src/lib/titleHelper.js (100%)
rename src/{node => }/addon/src/lib/types.js (100%)
rename src/{node => }/addon/src/moch/alldebrid.js (100%)
rename src/{node => }/addon/src/moch/debridlink.js (100%)
rename src/{node => }/addon/src/moch/moch.js (100%)
rename src/{node => }/addon/src/moch/mochHelper.js (100%)
rename src/{node => }/addon/src/moch/offcloud.js (100%)
rename src/{node => }/addon/src/moch/options.js (100%)
rename src/{node => }/addon/src/moch/premiumize.js (100%)
rename src/{node => }/addon/src/moch/putio.js (100%)
rename src/{node => }/addon/src/moch/realdebrid.js (100%)
rename src/{node => }/addon/src/moch/static.js (100%)
rename src/{node => }/addon/src/serverless.js (100%)
rename src/{node => }/addon/static/videos/download_failed_v2.mp4 (100%)
rename src/{node => }/addon/static/videos/downloading_v2.mp4 (100%)
rename src/{node => }/addon/static/videos/failed_access_v2.mp4 (100%)
rename src/{node => }/addon/static/videos/failed_infringement_v2.mp4 (100%)
rename src/{node => }/addon/static/videos/failed_opening_v2.mp4 (100%)
rename src/{node => }/addon/static/videos/failed_rar_v2.mp4 (100%)
rename src/{node => }/addon/static/videos/failed_unexpected_v2.mp4 (100%)
create mode 100644 src/debrid-collector/Configuration/logging.json
create mode 100644 src/debrid-collector/DebridCollector.csproj
create mode 100644 src/debrid-collector/DebridCollector.sln
create mode 100644 src/debrid-collector/Dockerfile
create mode 100644 src/debrid-collector/Extensions/ServiceCollectionExtensions.cs
create mode 100644 src/debrid-collector/Features/Configuration/DebridCollectorConfiguration.cs
create mode 100644 src/debrid-collector/Features/Debrid/DebridRequestProcessor.cs
create mode 100644 src/debrid-collector/Features/Debrid/IDebridHttpClient.cs
create mode 100644 src/debrid-collector/Features/Debrid/ProcessorChannel.cs
create mode 100644 src/debrid-collector/Features/Debrid/RealDebridClient.cs
create mode 100644 src/debrid-collector/Features/Debrid/RealDebridResponse.cs
create mode 100644 src/debrid-collector/Features/Debrid/ServiceCollectionExtensions.cs
create mode 100644 src/debrid-collector/Features/Worker/DebridMetaToTorrentMeta.cs
create mode 100644 src/debrid-collector/Features/Worker/Filetypes.cs
create mode 100644 src/debrid-collector/Features/Worker/InfohashMetadataSagaState.cs
create mode 100644 src/debrid-collector/Features/Worker/InfohashMetadataSagaStateMachine.cs
create mode 100644 src/debrid-collector/Features/Worker/PerformMetadataRequestConsumer.cs
create mode 100644 src/debrid-collector/Features/Worker/Requests.cs
create mode 100644 src/debrid-collector/Features/Worker/TorrentMetadataResponse.cs
create mode 100644 src/debrid-collector/Features/Worker/WriteMetadataConsumer.cs
create mode 100644 src/debrid-collector/GlobalUsings.cs
create mode 100644 src/debrid-collector/Program.cs
create mode 100644 src/metadata/Features/ClearExistingImdbData/ClearExistingImdbDataRequest.cs
create mode 100644 src/metadata/Features/ClearExistingImdbData/ClearExistingImdbDataRequestHandler.cs
delete mode 100644 src/metadata/Features/Configuration/JobConfiguration.cs
delete mode 100644 src/metadata/Features/Configuration/MongoConfiguration.cs
rename src/{producer/Features/DataProcessing => metadata/Features/Configuration}/PostgresConfiguration.cs (95%)
create mode 100644 src/metadata/Features/Configuration/ServiceConfiguration.cs
delete mode 100644 src/metadata/Features/DownloadImdbData/DownloadImdbDataJob.cs
create mode 100644 src/metadata/Features/DownloadImdbData/IImdbFileDownloader.cs
create mode 100644 src/metadata/Features/DownloadImdbData/ImdbFileDownloader.cs
create mode 100644 src/metadata/Features/Files/AkasFile.cs
create mode 100644 src/metadata/Features/Files/BasicsFile.cs
create mode 100644 src/metadata/Features/Files/EpisodesFile.cs
create mode 100644 src/metadata/Features/Files/IFileImport.cs
create mode 100644 src/metadata/Features/Files/ImdbAkaEntry.cs
create mode 100644 src/metadata/Features/Files/ImdbBasicEntry.cs
create mode 100644 src/metadata/Features/Files/ImdbEpisodeEntry.cs
create mode 100644 src/metadata/Features/ImportImdbData/ImdbDbService.cs
delete mode 100644 src/metadata/Features/ImportImdbData/ImdbEntry.cs
delete mode 100644 src/metadata/Features/ImportImdbData/ImdbMongoDbService.cs
create mode 100644 src/metadata/Features/ImportImdbData/TableNames.cs
create mode 100644 src/metadata/Features/IndexImdbData/IndexImdbDataRequest.cs
create mode 100644 src/metadata/Features/IndexImdbData/IndexImdbDataRequestHandler.cs
delete mode 100644 src/metadata/Features/Jobs/BaseJob.cs
create mode 100644 src/metadata/Features/Jobs/DownloadImdbDataJob.cs
delete mode 100644 src/metadata/Features/Jobs/IMetadataJob.cs
delete mode 100644 src/metadata/Features/Jobs/JobScheduler.cs
create mode 100644 src/metadata/Internal/Generated/WolverineHandlers/ClearExistingImdbDataRequestHandler2085209125.cs
create mode 100644 src/metadata/Internal/Generated/WolverineHandlers/DeleteDownloadedImdbDataRequestHandler52235941.cs
create mode 100644 src/metadata/Internal/Generated/WolverineHandlers/GetImdbDataRequestHandler1674247617.cs
create mode 100644 src/metadata/Internal/Generated/WolverineHandlers/ImportImdbDataRequestHandler968947017.cs
create mode 100644 src/metadata/Internal/Generated/WolverineHandlers/IndexImdbDataRequestHandler411355483.cs
create mode 100644 src/migrator/migrations/002_add_metadata.sql
create mode 100644 src/migrator/migrations/003_enable_pgtrm.sql
create mode 100644 src/migrator/migrations/004_imdb_metadata_query.sql
create mode 100644 src/migrator/migrations/005_add_metadata_akas.sql
create mode 100644 src/migrator/migrations/006_add_metadata_episodes.sql
create mode 100644 src/migrator/migrations/007_add_is_integer_function.sql
create mode 100644 src/migrator/migrations/008_change_imdb_search_year_plus_minus_one.sql
delete mode 100644 src/node/consumer/.dockerignore
delete mode 100644 src/node/consumer/.eslintignore
delete mode 100644 src/node/consumer/.eslintrc
delete mode 100644 src/node/consumer/.nvmrc
delete mode 100644 src/node/consumer/Dockerfile
delete mode 100644 src/node/consumer/esbuild.ts
delete mode 100644 src/node/consumer/jest.config.ts
delete mode 100644 src/node/consumer/package-lock.json
delete mode 100644 src/node/consumer/package.json
delete mode 100644 src/node/consumer/src/lib/enums/cache_types.ts
delete mode 100644 src/node/consumer/src/lib/enums/torrent_types.ts
delete mode 100644 src/node/consumer/src/lib/helpers/boolean_helpers.ts
delete mode 100644 src/node/consumer/src/lib/helpers/extension_helpers.ts
delete mode 100644 src/node/consumer/src/lib/helpers/promises_helpers.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/cache_options.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/cache_service.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/cinemeta_metadata.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/common_video_metadata.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/ingested_rabbit_message.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/kitsu_catalog_metadata.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/kitsu_metadata.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/logging_service.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/metadata_query.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/metadata_response.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/metadata_service.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/parse_torrent_title_result.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/parsed_torrent.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/process_torrents_job.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/torrent_download_service.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/torrent_entries_service.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/torrent_file_collection.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/torrent_file_service.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/torrent_processing_service.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/torrent_subtitle_service.ts
delete mode 100644 src/node/consumer/src/lib/interfaces/tracker_service.ts
delete mode 100644 src/node/consumer/src/lib/jobs/process_torrents_job.ts
delete mode 100644 src/node/consumer/src/lib/models/configuration/cache_config.ts
delete mode 100644 src/node/consumer/src/lib/models/configuration/database_config.ts
delete mode 100644 src/node/consumer/src/lib/models/configuration/job_config.ts
delete mode 100644 src/node/consumer/src/lib/models/configuration/metadata_config.ts
delete mode 100644 src/node/consumer/src/lib/models/configuration/rabbit_config.ts
delete mode 100644 src/node/consumer/src/lib/models/configuration/torrent_config.ts
delete mode 100644 src/node/consumer/src/lib/models/configuration/tracker_config.ts
delete mode 100644 src/node/consumer/src/lib/mongo/interfaces/imdb_entry_attributes.ts
delete mode 100644 src/node/consumer/src/lib/mongo/interfaces/mongo_metadata_query.ts
delete mode 100644 src/node/consumer/src/lib/mongo/interfaces/mongo_repository.ts
delete mode 100644 src/node/consumer/src/lib/mongo/models/imdb_entries_model.ts
delete mode 100644 src/node/consumer/src/lib/mongo/mongo_repository.ts
delete mode 100644 src/node/consumer/src/lib/repository/database_repository.ts
delete mode 100644 src/node/consumer/src/lib/repository/interfaces/content_attributes.ts
delete mode 100644 src/node/consumer/src/lib/repository/interfaces/database_repository.ts
delete mode 100644 src/node/consumer/src/lib/repository/interfaces/file_attributes.ts
delete mode 100644 src/node/consumer/src/lib/repository/interfaces/ingested_page_attributes.ts
delete mode 100644 src/node/consumer/src/lib/repository/interfaces/ingested_torrent_attributes.ts
delete mode 100644 src/node/consumer/src/lib/repository/interfaces/provider_attributes.ts
delete mode 100644 src/node/consumer/src/lib/repository/interfaces/skip_torrent_attributes.ts
delete mode 100644 src/node/consumer/src/lib/repository/interfaces/subtitle_attributes.ts
delete mode 100644 src/node/consumer/src/lib/repository/interfaces/torrent_attributes.ts
delete mode 100644 src/node/consumer/src/lib/repository/models/content.ts
delete mode 100644 src/node/consumer/src/lib/repository/models/file.ts
delete mode 100644 src/node/consumer/src/lib/repository/models/ingestedPage.ts
delete mode 100644 src/node/consumer/src/lib/repository/models/ingestedTorrent.ts
delete mode 100644 src/node/consumer/src/lib/repository/models/provider.ts
delete mode 100644 src/node/consumer/src/lib/repository/models/skipTorrent.ts
delete mode 100644 src/node/consumer/src/lib/repository/models/subtitle.ts
delete mode 100644 src/node/consumer/src/lib/repository/models/torrent.ts
delete mode 100644 src/node/consumer/src/lib/services/cache_service.ts
delete mode 100644 src/node/consumer/src/lib/services/configuration_service.ts
delete mode 100644 src/node/consumer/src/lib/services/logging_service.ts
delete mode 100644 src/node/consumer/src/lib/services/metadata_service.ts
delete mode 100644 src/node/consumer/src/lib/services/torrent_download_service.ts
delete mode 100644 src/node/consumer/src/lib/services/torrent_entries_service.ts
delete mode 100644 src/node/consumer/src/lib/services/torrent_file_service.ts
delete mode 100644 src/node/consumer/src/lib/services/torrent_processing_service.ts
delete mode 100644 src/node/consumer/src/lib/services/torrent_subtitle_service.ts
delete mode 100644 src/node/consumer/src/lib/services/tracker_service.ts
delete mode 100644 src/node/consumer/src/main.ts
delete mode 100644 src/node/consumer/src/setup/composition_root.ts
delete mode 100644 src/node/consumer/src/setup/inversify_config.ts
delete mode 100644 src/node/consumer/src/setup/ioc_types.ts
delete mode 100644 src/node/consumer/test/helpers/boolean_helpers.test.ts
delete mode 100644 src/node/consumer/test/helpers/extension_helpers.test.ts
delete mode 100644 src/node/consumer/test/helpers/promise_helpers.test.ts
delete mode 100644 src/node/consumer/test/mock-responses/assets/cinemeta-query-response.json
delete mode 100644 src/node/consumer/test/mock-responses/assets/flash-episode-list.json
delete mode 100644 src/node/consumer/test/mock-responses/assets/kitsu-naruto-full.json
delete mode 100644 src/node/consumer/test/mock-responses/assets/name-to-imdb-flash.json
delete mode 100644 src/node/consumer/test/mock-responses/assets/test-cinemata-theflash.json
delete mode 100644 src/node/consumer/test/mock-responses/assets/test-kitsu-search-id-naruto.json
delete mode 100644 src/node/consumer/test/mock-responses/metadata_mock_responses.ts
delete mode 100644 src/node/consumer/test/mock-responses/trackers_mock_responses.ts
delete mode 100644 src/node/consumer/test/services/cache_service.test.ts
delete mode 100644 src/node/consumer/test/services/configuration_service.test.ts
delete mode 100644 src/node/consumer/test/services/logging_service.test.ts
delete mode 100644 src/node/consumer/test/services/metadata_service.test.ts
delete mode 100644 src/node/consumer/test/services/mongo_repository.test.ts
delete mode 100644 src/node/consumer/test/services/process_torrent_job.test.ts
delete mode 100644 src/node/consumer/test/services/torrent_download_service.test.ts
delete mode 100644 src/node/consumer/test/services/torrent_entries_service.test.ts
delete mode 100644 src/node/consumer/test/services/torrent_file_service.test.ts
delete mode 100644 src/node/consumer/test/services/torrent_subtitle_service.test.ts
delete mode 100644 src/node/consumer/test/services/tracker_service.test.ts
delete mode 100644 src/node/consumer/tsconfig.json
delete mode 100644 src/producer/Data/adult-compound-words.txt
delete mode 100644 src/producer/Data/adult-stars.txt
delete mode 100644 src/producer/Data/adult-words.txt
delete mode 100644 src/producer/Data/common-words.txt
delete mode 100644 src/producer/Data/jav.txt
delete mode 100644 src/producer/Extensions/ConfigureHostBuilderExtensions.cs
delete mode 100644 src/producer/Features/Amqp/IMessagePublisher.cs
delete mode 100644 src/producer/Features/Amqp/ServiceCollectionExtensions.cs
delete mode 100644 src/producer/Features/DataProcessing/DapperDataStorage.cs
delete mode 100644 src/producer/Features/DataProcessing/IDataStorage.cs
delete mode 100644 src/producer/Features/DataProcessing/ImdbEntry.cs
delete mode 100644 src/producer/Features/DataProcessing/ImdbMongoDbService.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/AudioChannels.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/AudioChannelsParser.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/AudioCodecs.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/AudioCodecsParser.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/BaseParsed.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/Complete.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/Edition.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/EditionParser.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/FileExtensionParser.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/GroupParser.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/IParsingService.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/ITorrentTitleParser.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/Language.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/LanguageParser.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/ParsedFilename.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/ParsedMovie.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/ParsedTv.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/ParsingService.Regex.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/ParsingService.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/QualityModel.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/QualityModifier.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/QualityParser.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/Resolution.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/ResolutionParser.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/Revision.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/Season.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/SeasonParser.RejectRegex.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/SeasonParser.ValidRegex.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/SeasonParser.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/ServiceCollectionExtensions.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/Source.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/SourceParser.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/TitleParser.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/TorrentTitleParser.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/TorrentType.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/VideoCodecs.cs
delete mode 100644 src/producer/Features/ParseTorrentTitle/VideoCodecsParser.cs
delete mode 100644 src/producer/Features/Wordlists/IWordCollections.cs
delete mode 100644 src/producer/Features/Wordlists/PopulationService.cs
delete mode 100644 src/producer/Features/Wordlists/ServiceCollectionExtensions.cs
delete mode 100644 src/producer/Features/Wordlists/WordCollections.cs
create mode 100644 src/producer/Producer.sln
create mode 100644 src/producer/src/Configuration/logging.json
rename src/producer/{ => src}/Configuration/scrapers.json (100%)
rename src/producer/{ => src}/Configuration/torrentio.json (90%)
rename src/producer/{ => src}/Dockerfile (66%)
create mode 100644 src/producer/src/Extensions/ConfigurationExtensions.cs
create mode 100644 src/producer/src/Features/Amqp/IMessagePublisher.cs
rename src/producer/{ => src}/Features/Amqp/PublisherJob.cs (71%)
create mode 100644 src/producer/src/Features/Amqp/ServiceCollectionExtensions.cs
rename src/producer/{ => src}/Features/Amqp/TorrentPublisher.cs (71%)
rename src/producer/{ => src}/Features/CrawlerSupport/BaseCrawler.cs (76%)
rename src/producer/{ => src}/Features/CrawlerSupport/BaseJsonCrawler.cs (87%)
rename src/producer/{ => src}/Features/CrawlerSupport/BaseXmlCrawler.cs (86%)
rename src/producer/{ => src}/Features/CrawlerSupport/CrawlerProvider.cs (100%)
rename src/producer/{ => src}/Features/CrawlerSupport/ICrawler.cs (100%)
rename src/producer/{ => src}/Features/CrawlerSupport/ICrawlerProvider.cs (100%)
rename src/producer/{ => src}/Features/CrawlerSupport/Literals.cs (100%)
rename src/producer/{ => src}/Features/CrawlerSupport/Scraper.cs (100%)
rename src/producer/{ => src}/Features/CrawlerSupport/ServiceCollectionExtensions.cs (100%)
rename src/producer/{ => src}/Features/Crawlers/Dmm/DebridMediaManagerCrawler.cs (55%)
rename src/producer/{ => src}/Features/Crawlers/Dmm/GithubConfiguration.cs (100%)
rename src/producer/{ => src}/Features/Crawlers/Dmm/SyncDmmJob.cs (100%)
rename src/producer/{ => src}/Features/Crawlers/EzTv/EzTvCrawler.cs (51%)
rename src/producer/{ => src}/Features/Crawlers/EzTv/SyncEzTvJob.cs (100%)
rename src/producer/{ => src}/Features/Crawlers/Nyaa/NyaaCrawler.cs (58%)
rename src/producer/{ => src}/Features/Crawlers/Nyaa/SyncNyaaJob.cs (100%)
rename src/producer/{ => src}/Features/Crawlers/Tgx/SyncTgxJob.cs (100%)
rename src/producer/{ => src}/Features/Crawlers/Tgx/TgxCrawler.cs (87%)
rename src/producer/{ => src}/Features/Crawlers/Torrentio/SyncTorrentioJob.cs (100%)
rename src/producer/{ => src}/Features/Crawlers/Torrentio/TorrentioConfiguration.cs (100%)
rename src/producer/{ => src}/Features/Crawlers/Torrentio/TorrentioCrawler.cs (86%)
rename src/producer/{ => src}/Features/Crawlers/Torrentio/TorrentioInstance.cs (100%)
rename src/producer/{ => src}/Features/Crawlers/Torrentio/TorrentioInstanceExtensions.cs (100%)
rename src/producer/{ => src}/Features/Crawlers/Torrentio/TorrentioRateLimit.cs (86%)
rename src/producer/{ => src}/Features/Crawlers/Torrentio/TorrentioScrapeInstance.cs (81%)
rename src/producer/{ => src}/Features/Crawlers/Tpb/SyncTpbJob.cs (100%)
rename src/producer/{ => src}/Features/Crawlers/Tpb/TpbCrawler.cs (86%)
rename src/producer/{ => src}/Features/Crawlers/Yts/SyncYtsJob.cs (100%)
rename src/producer/{ => src}/Features/Crawlers/Yts/YtsCrawler.cs (66%)
rename src/producer/{ => src}/Features/DataProcessing/ServiceCollectionExtensions.cs (52%)
rename src/producer/{ => src}/Features/JobSupport/BaseJob.cs (100%)
rename src/producer/{ => src}/Features/JobSupport/ICrawlerJob.cs (100%)
rename src/producer/{ => src}/Features/JobSupport/Literals.cs (100%)
rename src/producer/{ => src}/Features/JobSupport/ManualJobRegistrationAttribute.cs (100%)
rename src/producer/{ => src}/Features/JobSupport/ScrapeConfiguration.cs (100%)
rename src/producer/{ => src}/Features/JobSupport/ServiceCollectionExtensions.cs (98%)
rename src/producer/{ => src}/GlobalUsings.cs (65%)
rename src/producer/{ => src}/Producer.csproj (75%)
rename src/producer/{ => src}/Program.cs (71%)
create mode 100644 src/qbit-collector/Configuration/logging.json
create mode 100644 src/qbit-collector/Dockerfile
create mode 100644 src/qbit-collector/Extensions/ServiceCollectionExtensions.cs
create mode 100644 src/qbit-collector/Features/Qbit/QBitRequestProcessor.cs
create mode 100644 src/qbit-collector/Features/Qbit/QbitConfiguration.cs
create mode 100644 src/qbit-collector/Features/Trackers/ITrackersService.cs
create mode 100644 src/qbit-collector/Features/Trackers/TrackersBackgroundService.cs
create mode 100644 src/qbit-collector/Features/Trackers/TrackersService.cs
create mode 100644 src/qbit-collector/Features/Worker/Filetypes.cs
create mode 100644 src/qbit-collector/Features/Worker/PerformQbitMetadataRequestConsumer.cs
create mode 100644 src/qbit-collector/Features/Worker/QBitMetadataResponse.cs
create mode 100644 src/qbit-collector/Features/Worker/QbitMetaToTorrentMeta.cs
create mode 100644 src/qbit-collector/Features/Worker/QbitMetadataSagaState.cs
create mode 100644 src/qbit-collector/Features/Worker/QbitMetadataSagaStateMachine.cs
create mode 100644 src/qbit-collector/Features/Worker/Requests.cs
create mode 100644 src/qbit-collector/Features/Worker/WriteQbitMetadataConsumer.cs
create mode 100644 src/qbit-collector/GlobalUsings.cs
create mode 100644 src/qbit-collector/Program.cs
create mode 100644 src/qbit-collector/QBitCollector.csproj
create mode 100644 src/qbit-collector/QBitCollector.sln
rename src/{producer/Features/DataProcessing/MongoConfiguration.cs => shared/Configuration/PostgresConfiguration.cs} (51%)
rename src/{producer/Features/Amqp => shared/Configuration}/RabbitMqConfiguration.cs (71%)
create mode 100644 src/shared/Configuration/RedisConfiguration.cs
create mode 100644 src/shared/Dapper/BaseDapperStorage.cs
create mode 100644 src/shared/Dapper/DapperDataStorage.cs
create mode 100644 src/shared/Dapper/DapperResult.cs
create mode 100644 src/shared/Dapper/IDataStorage.cs
rename src/{producer/Features/CrawlerSupport => shared/Dapper}/Results.cs (86%)
rename src/{producer => shared}/Extensions/ConfigurationExtensions.cs (63%)
rename src/{producer => shared}/Extensions/EnvironmentExtensions.cs (98%)
create mode 100644 src/shared/Extensions/HostBuilderExtensions.cs
create mode 100644 src/shared/Extensions/JsonSerializerExtensions.cs
create mode 100644 src/shared/Extensions/RabbitMqBusFactoryExtensions.cs
rename src/{producer => shared}/Extensions/StringExtensions.cs (52%)
create mode 100644 src/shared/Extensions/WebApplicationBuilderExtensions.cs
create mode 100644 src/shared/GlobalUsings.cs
create mode 100644 src/shared/Models/ImdbEntry.cs
rename src/{producer/Features/CrawlerSupport/Torrent.cs => shared/Models/IngestedTorrent.cs} (78%)
create mode 100644 src/shared/Models/SubtitleFile.cs
create mode 100644 src/shared/Models/Torrent.cs
create mode 100644 src/shared/Models/TorrentFile.cs
create mode 100644 src/shared/Requests/CollectMetadata.cs
create mode 100644 src/shared/Requests/IngestTorrent.cs
create mode 100644 src/shared/SharedContracts.csproj
rename src/{producer => torrent-consumer}/Configuration/logging.json (92%)
create mode 100644 src/torrent-consumer/Dockerfile
create mode 100644 src/torrent-consumer/Extensions/ServiceCollectionExtensions.cs
create mode 100644 src/torrent-consumer/Features/TorrentIngestion/PerformIngestionConsumer.cs
create mode 100644 src/torrent-consumer/Features/TorrentIngestion/Requests.cs
create mode 100644 src/torrent-consumer/Features/TorrentIngestion/TorrentIngestionSagaStateMachine.cs
create mode 100644 src/torrent-consumer/Features/TorrentIngestion/TorrentIngestionState.cs
create mode 100644 src/torrent-consumer/GlobalUsings.cs
create mode 100644 src/torrent-consumer/Program.cs
create mode 100644 src/torrent-consumer/TorrentConsumer.csproj
create mode 100644 src/torrent-consumer/TorrentConsumer.sln
diff --git a/.github/workflows/base_image_workflow.yaml b/.github/workflows/base_image_workflow.yaml
index 61a2701..0195c72 100644
--- a/.github/workflows/base_image_workflow.yaml
+++ b/.github/workflows/base_image_workflow.yaml
@@ -6,12 +6,16 @@ on:
CONTEXT:
required: true
type: string
+ DOCKERFILE:
+ required: true
+ type: string
IMAGE_NAME:
required: true
type: string
env:
CONTEXT: ${{ inputs.CONTEXT }}
+ DOCKERFILE: ${{ inputs.DOCKERFILE }}
IMAGE_NAME: ${{ inputs.IMAGE_NAME }}
PLATFORMS: linux/amd64,linux/arm64
@@ -21,11 +25,13 @@ jobs:
steps:
- name: Setting variables
run: |
- echo "CONTEXT=${{ env.CONTEXT }}
- echo "IMAGE_NAME=${{ env.IMAGE_NAME }}
+ echo "CONTEXT=${{ env.CONTEXT }}"
+ echo "DOCKERFILE=${{ env.DOCKERFILE }}"
+ echo "IMAGE_NAME=${{ env.IMAGE_NAME }}"
echo "PLATFORMS=${{ env.PLATFORMS }}"
outputs:
CONTEXT: ${{ env.CONTEXT }}
+ DOCKERFILE: ${{ env.DOCKERFILE }}
IMAGE_NAME: ${{ env.IMAGE_NAME }}
PLATFORMS: ${{ env.PLATFORMS }}
@@ -80,6 +86,7 @@ jobs:
uses: docker/build-push-action@v5
with:
context: ${{ needs.set-vars.outputs.CONTEXT }}
+ file: ${{ needs.set-vars.outputs.DOCKERFILE }}
push: true
provenance: false
tags: localhost:5000/dockle-examine-image:test
@@ -136,6 +143,7 @@ jobs:
uses: docker/build-push-action@v5
with:
context: ${{ needs.set-vars.outputs.CONTEXT }}
+ file: ${{ needs.set-vars.outputs.DOCKERFILE }}
push: true
provenance: false
tags: ${{ steps.docker-metadata.outputs.tags }}
diff --git a/.github/workflows/build_addon.yaml b/.github/workflows/build_addon.yaml
index 0c09087..6dda21b 100644
--- a/.github/workflows/build_addon.yaml
+++ b/.github/workflows/build_addon.yaml
@@ -3,7 +3,7 @@ name: Build and Push Addon Service
on:
push:
paths:
- - 'src/node/addon/**'
+ - 'src/addon/**'
tags:
- 'v*.*.*'
workflow_dispatch:
@@ -13,5 +13,6 @@ jobs:
uses: ./.github/workflows/base_image_workflow.yaml
secrets: inherit
with:
- CONTEXT: ./src/node/addon/
+ CONTEXT: ./src/addon/
+ DOCKERFILE: ./src/addon/Dockerfile
IMAGE_NAME: knightcrawler-addon
diff --git a/.github/workflows/build_consumer.yaml b/.github/workflows/build_consumer.yaml
index fc35a99..102c147 100644
--- a/.github/workflows/build_consumer.yaml
+++ b/.github/workflows/build_consumer.yaml
@@ -3,7 +3,7 @@ name: Build and Push Consumer Service
on:
push:
paths:
- - 'src/node/consumer/**'
+ - 'src/torrent-consumer/**'
tags:
- 'v*.*.*'
workflow_dispatch:
@@ -13,5 +13,6 @@ jobs:
uses: ./.github/workflows/base_image_workflow.yaml
secrets: inherit
with:
- CONTEXT: ./src/node/consumer/
+ CONTEXT: ./src/
+ DOCKERFILE: ./src/torrent-consumer/Dockerfile
IMAGE_NAME: knightcrawler-consumer
diff --git a/.github/workflows/build_debrid_collector.yaml b/.github/workflows/build_debrid_collector.yaml
new file mode 100644
index 0000000..564dc2b
--- /dev/null
+++ b/.github/workflows/build_debrid_collector.yaml
@@ -0,0 +1,16 @@
+name: Build and Push Debrid Collector Service
+
+on:
+ push:
+ paths:
+ - 'src/debrid-collector/**'
+ workflow_dispatch:
+
+jobs:
+ process:
+ uses: ./.github/workflows/base_image_workflow.yaml
+ secrets: inherit
+ with:
+ CONTEXT: ./src/
+ DOCKERFILE: ./src/debrid-collector/Dockerfile
+ IMAGE_NAME: knightcrawler-debrid-collector
diff --git a/.github/workflows/build_jackett-addon.yaml b/.github/workflows/build_jackett-addon.yaml
index 6174baf..966db0e 100644
--- a/.github/workflows/build_jackett-addon.yaml
+++ b/.github/workflows/build_jackett-addon.yaml
@@ -3,7 +3,7 @@ name: Build and Push Jackett Addon Service
on:
push:
paths:
- - 'src/node/addon-jackett/**'
+ - 'src/addon-jackett/**'
tags:
- 'v*.*.*'
workflow_dispatch:
@@ -13,5 +13,6 @@ jobs:
uses: ./.github/workflows/base_image_workflow.yaml
secrets: inherit
with:
- CONTEXT: ./src/node/addon-jackett/
+ CONTEXT: ./src/addon-jackett/
+ DOCKERFILE: ./src/addon-jackett/Dockerfile
IMAGE_NAME: knightcrawler-addon-jackett
diff --git a/.github/workflows/build_metadata.yaml b/.github/workflows/build_metadata.yaml
index 9b48e1c..f6ecf3b 100644
--- a/.github/workflows/build_metadata.yaml
+++ b/.github/workflows/build_metadata.yaml
@@ -14,4 +14,5 @@ jobs:
secrets: inherit
with:
CONTEXT: ./src/metadata/
+ DOCKERFILE: ./src/metadata/Dockerfile
IMAGE_NAME: knightcrawler-metadata
diff --git a/.github/workflows/build_migrator.yaml b/.github/workflows/build_migrator.yaml
index 81679c4..7a1a157 100644
--- a/.github/workflows/build_migrator.yaml
+++ b/.github/workflows/build_migrator.yaml
@@ -14,4 +14,5 @@ jobs:
secrets: inherit
with:
CONTEXT: ./src/migrator/
+ DOCKERFILE: ./src/migrator/Dockerfile
IMAGE_NAME: knightcrawler-migrator
diff --git a/.github/workflows/build_producer.yaml b/.github/workflows/build_producer.yaml
index feb0894..f1c2810 100644
--- a/.github/workflows/build_producer.yaml
+++ b/.github/workflows/build_producer.yaml
@@ -13,5 +13,6 @@ jobs:
uses: ./.github/workflows/base_image_workflow.yaml
secrets: inherit
with:
- CONTEXT: ./src/producer/
+ CONTEXT: ./src/
+ DOCKERFILE: ./src/producer/src/Dockerfile
IMAGE_NAME: knightcrawler-producer
diff --git a/.github/workflows/build_qbit_collector.yaml b/.github/workflows/build_qbit_collector.yaml
new file mode 100644
index 0000000..9e340f8
--- /dev/null
+++ b/.github/workflows/build_qbit_collector.yaml
@@ -0,0 +1,16 @@
+name: Build and Push Qbit Collector Service
+
+on:
+ push:
+ paths:
+ - 'src/qbit-collector/**'
+ workflow_dispatch:
+
+jobs:
+ process:
+ uses: ./.github/workflows/base_image_workflow.yaml
+ secrets: inherit
+ with:
+ CONTEXT: ./src/
+ DOCKERFILE: ./src/qbit-collector/Dockerfile
+ IMAGE_NAME: knightcrawler-qbit-collector
diff --git a/.github/workflows/build_tissue.yaml b/.github/workflows/build_tissue.yaml
index c1194ed..6a62f33 100644
--- a/.github/workflows/build_tissue.yaml
+++ b/.github/workflows/build_tissue.yaml
@@ -14,4 +14,5 @@ jobs:
secrets: inherit
with:
CONTEXT: ./src/tissue/
+ DOCKERFILE: ./src/tissue/Dockerfile
IMAGE_NAME: knightcrawler-tissue
diff --git a/.gitignore b/.gitignore
index b324383..3bedd7c 100644
--- a/.gitignore
+++ b/.gitignore
@@ -395,8 +395,6 @@ dist/
downloads/
eggs/
.eggs/
-lib/
-lib64/
parts/
sdist/
var/
@@ -610,3 +608,6 @@ fabric.properties
# Caddy logs
!**/caddy/logs/.gitkeep
**/caddy/logs/**
+
+# Mac directory indexes
+.DS_Store
\ No newline at end of file
diff --git a/deployment/docker/.env.example b/deployment/docker/.env.example
index 419e860..67fb079 100644
--- a/deployment/docker/.env.example
+++ b/deployment/docker/.env.example
@@ -8,48 +8,29 @@ POSTGRES_USER=postgres
POSTGRES_PASSWORD=postgres
POSTGRES_DB=knightcrawler
-# MongoDB
-MONGODB_HOST=mongodb
-MONGODB_PORT=27017
-MONGODB_DB=knightcrawler
-MONGODB_USER=mongo
-MONGODB_PASSWORD=mongo
+# Redis
+REDIS_CONNECTION_STRING=redis:6379
# RabbitMQ
RABBITMQ_HOST=rabbitmq
RABBITMQ_USER=guest
RABBITMQ_PASSWORD=guest
-RABBITMQ_QUEUE_NAME=ingested
+RABBITMQ_CONSUMER_QUEUE_NAME=ingested
RABBITMQ_DURABLE=true
RABBITMQ_MAX_QUEUE_SIZE=0
RABBITMQ_MAX_PUBLISH_BATCH_SIZE=500
RABBITMQ_PUBLISH_INTERVAL_IN_SECONDS=10
# Metadata
-## Only used if DATA_ONCE is set to false. If true, the schedule is ignored
-METADATA_DOWNLOAD_IMDB_DATA_SCHEDULE="0 0 1 * *"
-## If true, the metadata will be downloaded once and then the schedule will be ignored
-METADATA_DOWNLOAD_IMDB_DATA_ONCE=true
-## Controls the amount of records processed in memory at any given time during import, higher values will consume more memory
-METADATA_INSERT_BATCH_SIZE=25000
+METADATA_INSERT_BATCH_SIZE=50000
+
+# Collectors
+COLLECTOR_QBIT_ENABLED=false
+COLLECTOR_DEBRID_ENABLED=true
+COLLECTOR_REAL_DEBRID_API_KEY=
# Addon
DEBUG_MODE=false
-# Consumer
-JOB_CONCURRENCY=5
-JOBS_ENABLED=true
-## can be debug for extra verbosity (a lot more verbosity - useful for development)
-LOG_LEVEL=info
-MAX_CONNECTIONS_PER_TORRENT=10
-MAX_CONNECTIONS_OVERALL=100
-TORRENT_TIMEOUT=30000
-UDP_TRACKERS_ENABLED=true
-CONSUMER_REPLICAS=3
-## Fix for #66 - toggle on for development
-AUTO_CREATE_AND_APPLY_MIGRATIONS=false
-## Allows control of the threshold for matching titles to the IMDB dataset. The closer to 0, the more strict the matching.
-TITLE_MATCH_THRESHOLD=0.25
-
# Producer
GITHUB_PAT=
diff --git a/deployment/docker/components/config/qbit/qbittorrent.conf b/deployment/docker/components/config/qbit/qbittorrent.conf
new file mode 100644
index 0000000..20ffb9c
--- /dev/null
+++ b/deployment/docker/components/config/qbit/qbittorrent.conf
@@ -0,0 +1,58 @@
+[Application]
+FileLogger\Age=1
+FileLogger\AgeType=1
+FileLogger\Backup=true
+FileLogger\DeleteOld=true
+FileLogger\Enabled=true
+FileLogger\MaxSizeBytes=66560
+FileLogger\Path=/config/qBittorrent/logs
+
+[AutoRun]
+enabled=false
+program=
+
+[BitTorrent]
+Session\DefaultSavePath=/downloads/
+Session\ExcludedFileNames=
+Session\MaxActiveDownloads=10
+Session\MaxActiveTorrents=50
+Session\MaxActiveUploads=50
+Session\MaxConnections=2000
+Session\Port=6881
+Session\QueueingSystemEnabled=true
+Session\TempPath=/downloads/incomplete/
+Session\TorrentStopCondition=MetadataReceived
+
+[Core]
+AutoDeleteAddedTorrentFile=Never
+
+[LegalNotice]
+Accepted=true
+
+[Meta]
+MigrationVersion=6
+
+[Network]
+PortForwardingEnabled=true
+Proxy\HostnameLookupEnabled=false
+Proxy\Profiles\BitTorrent=true
+Proxy\Profiles\Misc=true
+Proxy\Profiles\RSS=true
+
+[Preferences]
+Connection\PortRangeMin=6881
+Connection\ResolvePeerCountries=false
+Connection\UPnP=false
+Downloads\SavePath=/downloads/
+Downloads\TempPath=/downloads/incomplete/
+General\Locale=en
+MailNotification\req_auth=true
+WebUI\Address=*
+WebUI\AuthSubnetWhitelist=0.0.0.0/0
+WebUI\AuthSubnetWhitelistEnabled=true
+WebUI\LocalHostAuth=false
+WebUI\ServerDomains=*
+
+[RSS]
+AutoDownloader\DownloadRepacks=true
+AutoDownloader\SmartEpisodeFilter=s(\\d+)e(\\d+), (\\d+)x(\\d+), "(\\d{4}[.\\-]\\d{1,2}[.\\-]\\d{1,2})", "(\\d{1,2}[.\\-]\\d{1,2}[.\\-]\\d{4})"
diff --git a/deployment/docker/components/infrastructure.yaml b/deployment/docker/components/infrastructure.yaml
new file mode 100644
index 0000000..23eb22c
--- /dev/null
+++ b/deployment/docker/components/infrastructure.yaml
@@ -0,0 +1,89 @@
+x-basehealth: &base-health
+ interval: 10s
+ timeout: 10s
+ retries: 3
+ start_period: 10s
+
+x-rabbithealth: &rabbitmq-health
+ test: rabbitmq-diagnostics -q ping
+ <<: *base-health
+
+x-redishealth: &redis-health
+ test: redis-cli ping
+ <<: *base-health
+
+x-postgreshealth: &postgresdb-health
+ test: pg_isready
+ <<: *base-health
+
+x-qbit: &qbit-health
+ test: "curl --fail http://localhost:8080"
+ <<: *base-health
+
+services:
+
+ postgres:
+ image: postgres:latest
+ environment:
+ PGUSER: postgres # needed for healthcheck.
+ # # If you need the database to be accessible from outside, please open the below port.
+ # # Furthermore, please, please, please, change the username and password in the .env file.
+ # # If you want to enhance your security even more, create a new user for the database with a strong password.
+ # ports:
+ # - "5432:5432"
+ volumes:
+ - postgres:/var/lib/postgresql/data
+ healthcheck: *postgresdb-health
+ restart: unless-stopped
+ env_file: ../.env
+ networks:
+ - knightcrawler-network
+
+ redis:
+ image: redis/redis-stack:latest
+ # # If you need redis to be accessible from outside, please open the below port.
+ # ports:
+ # - "6379:6379"
+ volumes:
+ - redis:/data
+ restart: unless-stopped
+ healthcheck: *redis-health
+ env_file: ../.env
+ networks:
+ - knightcrawler-network
+
+ rabbitmq:
+ image: rabbitmq:3-management
+ # # If you need the database to be accessible from outside, please open the below port.
+ # # Furthermore, please, please, please, look at the documentation for rabbit on how to secure the service.
+ # ports:
+ # - "5672:5672"
+ # - "15672:15672"
+ # - "15692:15692"
+ volumes:
+ - rabbitmq:/var/lib/rabbitmq
+ restart: unless-stopped
+ healthcheck: *rabbitmq-health
+ env_file: ../.env
+ networks:
+ - knightcrawler-network
+
+ ## QBitTorrent is a torrent client that can be used to download torrents. In this case its used to download metadata.
+ ## The QBit collector requires this.
+ qbittorrent:
+ image: lscr.io/linuxserver/qbittorrent:latest
+ environment:
+ - PUID=1000
+ - PGID=1000
+ - WEBUI_PORT=8080
+ - TORRENTING_PORT=6881
+ ports:
+ - 6881:6881
+ - 6881:6881/udp
+ env_file: ../.env
+ networks:
+ - knightcrawler-network
+ restart: unless-stopped
+ healthcheck: *qbit-health
+ volumes:
+ - ./config/qbit/qbittorrent.conf:/config/qBittorrent/qBittorrent.conf
\ No newline at end of file
diff --git a/deployment/docker/components/knightcrawler.yaml b/deployment/docker/components/knightcrawler.yaml
new file mode 100644
index 0000000..33624c2
--- /dev/null
+++ b/deployment/docker/components/knightcrawler.yaml
@@ -0,0 +1,71 @@
+x-apps: &knightcrawler-app
+ labels:
+ logging: "promtail"
+ env_file: ../.env
+ networks:
+ - knightcrawler-network
+
+x-depends: &knightcrawler-app-depends
+ depends_on:
+ redis:
+ condition: service_healthy
+ postgres:
+ condition: service_healthy
+ rabbitmq:
+ condition: service_healthy
+ migrator:
+ condition: service_completed_successfully
+ metadata:
+ condition: service_completed_successfully
+
+services:
+ metadata:
+ image: gabisonfire/knightcrawler-metadata:2.0.0
+ env_file: ../.env
+ networks:
+ - knightcrawler-network
+ restart: no
+ depends_on:
+ migrator:
+ condition: service_completed_successfully
+
+ migrator:
+ image: gabisonfire/knightcrawler-migrator:2.0.0
+ env_file: ../.env
+ networks:
+ - knightcrawler-network
+ restart: no
+ depends_on:
+ postgres:
+ condition: service_healthy
+
+ addon:
+ image: gabisonfire/knightcrawler-addon:2.0.0
+ <<: [*knightcrawler-app, *knightcrawler-app-depends]
+ restart: unless-stopped
+ hostname: knightcrawler-addon
+ ports:
+ - "7000:7000"
+
+ consumer:
+ image: gabisonfire/knightcrawler-consumer:2.0.0
+ <<: [*knightcrawler-app, *knightcrawler-app-depends]
+ restart: unless-stopped
+
+ debridcollector:
+ image: gabisonfire/knightcrawler-debridcollector:2.0.0
+ <<: [*knightcrawler-app, *knightcrawler-app-depends]
+ restart: unless-stopped
+
+ producer:
+ image: gabisonfire/knightcrawler-producer:2.0.0
+ <<: [*knightcrawler-app, *knightcrawler-app-depends]
+ restart: unless-stopped
+
+ qbitcollector:
+ image: gabisonfire/knightcrawler-qbitcollector:2.0.0
+ <<: [*knightcrawler-app, *knightcrawler-app-depends]
+ restart: unless-stopped
+ depends_on:
+ qbittorrent:
+ condition: service_healthy
\ No newline at end of file
diff --git a/deployment/docker/components/network.yaml b/deployment/docker/components/network.yaml
new file mode 100644
index 0000000..01395a2
--- /dev/null
+++ b/deployment/docker/components/network.yaml
@@ -0,0 +1,4 @@
+networks:
+ knightcrawler-network:
+ driver: bridge
+ name: knightcrawler-network
\ No newline at end of file
diff --git a/deployment/docker/components/volumes.yaml b/deployment/docker/components/volumes.yaml
new file mode 100644
index 0000000..b6fa654
--- /dev/null
+++ b/deployment/docker/components/volumes.yaml
@@ -0,0 +1,4 @@
+volumes:
+ postgres:
+ redis:
+ rabbitmq:
\ No newline at end of file
diff --git a/deployment/docker/compose.override.yaml b/deployment/docker/compose.override.yaml
new file mode 100644
index 0000000..d050e34
--- /dev/null
+++ b/deployment/docker/compose.override.yaml
@@ -0,0 +1,7 @@
+services:
+ qbittorrent:
+ deploy:
+ replicas: 0
+ qbitcollector:
+ deploy:
+ replicas: 0
\ No newline at end of file
diff --git a/deployment/docker/compose.yaml b/deployment/docker/compose.yaml
new file mode 100644
index 0000000..ab80725
--- /dev/null
+++ b/deployment/docker/compose.yaml
@@ -0,0 +1,7 @@
+version: "3.9"
+name: "knightcrawler"
+include:
+ - components/network.yaml
+ - components/volumes.yaml
+ - components/infrastructure.yaml
+ - components/knightcrawler.yaml
\ No newline at end of file
diff --git a/deployment/docker/docker-compose.yaml b/deployment/docker/docker-compose.yaml
deleted file mode 100644
index 5c6f0c9..0000000
--- a/deployment/docker/docker-compose.yaml
+++ /dev/null
@@ -1,139 +0,0 @@
-name: knightcrawler
-
-x-restart: &restart-policy "unless-stopped"
-
-x-basehealth: &base-health
- interval: 10s
- timeout: 10s
- retries: 3
- start_period: 10s
-
-x-rabbithealth: &rabbitmq-health
- test: rabbitmq-diagnostics -q ping
- <<: *base-health
-
-x-mongohealth: &mongodb-health
- test: ["CMD", "mongosh", "--eval", "db.adminCommand('ping')"]
- <<: *base-health
-
-x-postgreshealth: &postgresdb-health
- test: pg_isready
- <<: *base-health
-
-x-apps: &knightcrawler-app
- depends_on:
- mongodb:
- condition: service_healthy
- postgres:
- condition: service_healthy
- rabbitmq:
- condition: service_healthy
- restart: *restart-policy
-
-services:
- postgres:
- image: postgres:latest
- env_file: .env
- environment:
- PGUSER: postgres # needed for healthcheck.
- # # If you need the database to be accessible from outside, please open the below port.
- # # Furthermore, please, please, please, change the username and password in the .env file.
- # # If you want to enhance your security even more, create a new user for the database with a strong password.
- # ports:
- # - "5432:5432"
- volumes:
- - postgres:/var/lib/postgresql/data
- healthcheck: *postgresdb-health
- restart: *restart-policy
- networks:
- - knightcrawler-network
-
- mongodb:
- image: mongo:latest
- env_file: .env
- environment:
- MONGO_INITDB_ROOT_USERNAME: ${MONGODB_USER:?Variable MONGODB_USER not set}
- MONGO_INITDB_ROOT_PASSWORD: ${MONGODB_PASSWORD:?Variable MONGODB_PASSWORD not set}
- # # If you need the database to be accessible from outside, please open the below port.
- # # Furthermore, please, please, please, change the username and password in the .env file.
- # ports:
- # - "27017:27017"
- volumes:
- - mongo:/data/db
- restart: *restart-policy
- healthcheck: *mongodb-health
- networks:
- - knightcrawler-network
-
- rabbitmq:
- image: rabbitmq:3-management
- # # If you need the database to be accessible from outside, please open the below port.
- # # Furthermore, please, please, please, look at the documentation for rabbit on how to secure the service.
- # ports:
- # - "5672:5672"
- # - "15672:15672"
- # - "15692:15692"
- volumes:
- - rabbitmq:/var/lib/rabbitmq
- hostname: ${RABBITMQ_HOST}
- restart: *restart-policy
- healthcheck: *rabbitmq-health
- networks:
- - knightcrawler-network
-
- producer:
- image: gabisonfire/knightcrawler-producer:1.0.1
- labels:
- logging: "promtail"
- env_file: .env
- <<: *knightcrawler-app
- networks:
- - knightcrawler-network
-
- consumer:
- image: gabisonfire/knightcrawler-consumer:1.0.1
- env_file: .env
- labels:
- logging: "promtail"
- deploy:
- replicas: ${CONSUMER_REPLICAS}
- <<: *knightcrawler-app
- networks:
- - knightcrawler-network
-
- metadata:
- image: gabisonfire/knightcrawler-metadata:1.0.1
- env_file: .env
- labels:
- logging: "promtail"
- restart: no
- networks:
- - knightcrawler-network
-
- addon:
- <<: *knightcrawler-app
- env_file: .env
- hostname: knightcrawler-addon
- image: gabisonfire/knightcrawler-addon:1.0.1
- labels:
- logging: "promtail"
- networks:
- - knightcrawler-network
- # - caddy
- ports:
- - "7000:7000"
-
-
-networks:
- knightcrawler-network:
- driver: bridge
- name: knightcrawler-network
-
- # caddy:
- # name: caddy
- # external: true
-
-volumes:
- postgres:
- mongo:
- rabbitmq:
diff --git a/src/node/addon-jackett/.dockerignore b/src/addon-jackett/.dockerignore
similarity index 100%
rename from src/node/addon-jackett/.dockerignore
rename to src/addon-jackett/.dockerignore
diff --git a/src/node/addon-jackett/.eslintignore b/src/addon-jackett/.eslintignore
similarity index 100%
rename from src/node/addon-jackett/.eslintignore
rename to src/addon-jackett/.eslintignore
diff --git a/src/node/addon-jackett/.eslintrc.cjs b/src/addon-jackett/.eslintrc.cjs
similarity index 100%
rename from src/node/addon-jackett/.eslintrc.cjs
rename to src/addon-jackett/.eslintrc.cjs
diff --git a/src/node/addon-jackett/Dockerfile b/src/addon-jackett/Dockerfile
similarity index 100%
rename from src/node/addon-jackett/Dockerfile
rename to src/addon-jackett/Dockerfile
diff --git a/src/node/addon-jackett/README.md b/src/addon-jackett/README.md
similarity index 100%
rename from src/node/addon-jackett/README.md
rename to src/addon-jackett/README.md
diff --git a/src/node/addon-jackett/build.sh b/src/addon-jackett/build.sh
similarity index 100%
rename from src/node/addon-jackett/build.sh
rename to src/addon-jackett/build.sh
diff --git a/src/node/addon-jackett/ecosystem.config.cjs b/src/addon-jackett/ecosystem.config.cjs
similarity index 100%
rename from src/node/addon-jackett/ecosystem.config.cjs
rename to src/addon-jackett/ecosystem.config.cjs
diff --git a/src/node/addon-jackett/esbuild.js b/src/addon-jackett/esbuild.js
similarity index 100%
rename from src/node/addon-jackett/esbuild.js
rename to src/addon-jackett/esbuild.js
diff --git a/src/node/addon-jackett/jsconfig.json b/src/addon-jackett/jsconfig.json
similarity index 100%
rename from src/node/addon-jackett/jsconfig.json
rename to src/addon-jackett/jsconfig.json
diff --git a/src/node/addon-jackett/package-lock.json b/src/addon-jackett/package-lock.json
similarity index 83%
rename from src/node/addon-jackett/package-lock.json
rename to src/addon-jackett/package-lock.json
index 431f1f5..f50cde1 100644
--- a/src/node/addon-jackett/package-lock.json
+++ b/src/addon-jackett/package-lock.json
@@ -9,11 +9,14 @@
"version": "0.0.1",
"dependencies": {
"@putdotio/api-client": "^8.42.0",
+ "@redis/client": "^1.5.14",
+ "@redis/json": "^1.0.6",
+ "@redis/search": "^1.1.6",
"all-debrid-api": "^1.1.0",
"axios": "^1.6.1",
"bottleneck": "^2.19.5",
"cache-manager": "^3.4.4",
- "cache-manager-mongodb": "^0.3.0",
+ "cache-manager-redis-store": "^2.0.0",
"cors": "^2.8.5",
"debrid-link-api": "^1.0.1",
"express": "^4.18.2",
@@ -40,13 +43,8 @@
"esbuild": "^0.19.12",
"esbuild-plugin-copy": "^2.1.1",
"eslint": "^8.56.0",
- "eslint-config-prettier": "^9.1.0",
"eslint-plugin-import": "^2.29.1",
"eslint-plugin-import-helpers": "^1.3.1",
- "eslint-plugin-prettier": "^5.1.3",
- "husky": "^9.0.6",
- "lint-staged": "^15.2.0",
- "prettier": "^3.2.4",
"tsx": "^4.7.0"
}
},
@@ -642,18 +640,6 @@
"node": ">= 8"
}
},
- "node_modules/@pkgr/core": {
- "version": "0.1.1",
- "resolved": "https://registry.npmjs.org/@pkgr/core/-/core-0.1.1.tgz",
- "integrity": "sha512-cq8o4cWH0ibXh9VGi5P20Tu9XF/0fFXl9EUinr9QfTM7a7p0oTA4iJRCQWppXR1Pg8dSM0UCItCkPwsk9qWWYA==",
- "dev": true,
- "engines": {
- "node": "^12.20.0 || ^14.18.0 || >=16.0.0"
- },
- "funding": {
- "url": "https://opencollective.com/unts"
- }
- },
"node_modules/@putdotio/api-client": {
"version": "8.42.0",
"resolved": "https://registry.npmjs.org/@putdotio/api-client/-/api-client-8.42.0.tgz",
@@ -677,6 +663,35 @@
"follow-redirects": "^1.14.0"
}
},
+ "node_modules/@redis/client": {
+ "version": "1.5.14",
+ "resolved": "https://registry.npmjs.org/@redis/client/-/client-1.5.14.tgz",
+ "integrity": "sha512-YGn0GqsRBFUQxklhY7v562VMOP0DcmlrHHs3IV1mFE3cbxe31IITUkqhBcIhVSI/2JqtWAJXg5mjV4aU+zD0HA==",
+ "dependencies": {
+ "cluster-key-slot": "1.1.2",
+ "generic-pool": "3.9.0",
+ "yallist": "4.0.0"
+ },
+ "engines": {
+ "node": ">=14"
+ }
+ },
+ "node_modules/@redis/json": {
+ "version": "1.0.6",
+ "resolved": "https://registry.npmjs.org/@redis/json/-/json-1.0.6.tgz",
+ "integrity": "sha512-rcZO3bfQbm2zPRpqo82XbW8zg4G/w4W3tI7X8Mqleq9goQjAGLL7q/1n1ZX4dXEAmORVZ4s1+uKLaUOg7LrUhw==",
+ "peerDependencies": {
+ "@redis/client": "^1.0.0"
+ }
+ },
+ "node_modules/@redis/search": {
+ "version": "1.1.6",
+ "resolved": "https://registry.npmjs.org/@redis/search/-/search-1.1.6.tgz",
+ "integrity": "sha512-mZXCxbTYKBQ3M2lZnEddwEAks0Kc7nauire8q20oA0oA/LoA+E/b5Y5KZn232ztPb1FkIGqo12vh3Lf+Vw5iTw==",
+ "peerDependencies": {
+ "@redis/client": "^1.0.0"
+ }
+ },
"node_modules/@types/json5": {
"version": "0.0.29",
"resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz",
@@ -1024,20 +1039,6 @@
"node": ">=8"
}
},
- "node_modules/bl": {
- "version": "2.2.1",
- "resolved": "https://registry.npmjs.org/bl/-/bl-2.2.1.tgz",
- "integrity": "sha512-6Pesp1w0DEX1N550i/uGV/TqucVL4AM/pgThFSN/Qq9si1/DF9aIHs1BxD8V/QU0HoeHO6cQRTAuYnLPKq1e4g==",
- "dependencies": {
- "readable-stream": "^2.3.5",
- "safe-buffer": "^5.1.1"
- }
- },
- "node_modules/bluebird": {
- "version": "3.7.2",
- "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz",
- "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg=="
- },
"node_modules/body-parser": {
"version": "1.20.1",
"resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz",
@@ -1078,14 +1079,6 @@
"node": ">=8"
}
},
- "node_modules/bson": {
- "version": "1.1.6",
- "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.6.tgz",
- "integrity": "sha512-EvVNVeGo4tHxwi8L6bPj3y3itEvStdwvvlojVxxbyYfoaxJ6keLgrTuKdyfEAszFK+H3olzBuafE0yoh0D1gdg==",
- "engines": {
- "node": ">=0.6.19"
- }
- },
"node_modules/bytes": {
"version": "3.1.2",
"resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz",
@@ -1104,46 +1097,17 @@
"lru-cache": "6.0.0"
}
},
- "node_modules/cache-manager-mongodb": {
- "version": "0.3.0",
- "resolved": "https://registry.npmjs.org/cache-manager-mongodb/-/cache-manager-mongodb-0.3.0.tgz",
- "integrity": "sha512-r+piWvu8XD8ceBWflZBEQZKemksoaL1V5zSHWyviVTXiGBSVQAf18b4S1v5UwGZMJnrMk8YNFgpBlugF0nuhvg==",
+ "node_modules/cache-manager-redis-store": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/cache-manager-redis-store/-/cache-manager-redis-store-2.0.0.tgz",
+ "integrity": "sha512-bWLWlUg6nCYHiJLCCYxY2MgvwvKnvlWwrbuynrzpjEIhfArD2GC9LtutIHFEPeyGVQN6C+WEw+P3r+BFBwhswg==",
"dependencies": {
- "bluebird": "^3.5.3",
- "cache-manager": "^2.9.0",
- "lodash": "^4.17.15",
- "mongodb": "^3.6.3"
+ "redis": "^3.0.2"
+ },
+ "engines": {
+ "node": ">= 8.3"
}
},
- "node_modules/cache-manager-mongodb/node_modules/async": {
- "version": "1.5.2",
- "resolved": "https://registry.npmjs.org/async/-/async-1.5.2.tgz",
- "integrity": "sha512-nSVgobk4rv61R9PUSDtYt7mPVB2olxNR5RWJcAsH676/ef11bUZwvu7+RGYrYauVdDPcO519v68wRhXQtxsV9w=="
- },
- "node_modules/cache-manager-mongodb/node_modules/cache-manager": {
- "version": "2.11.1",
- "resolved": "https://registry.npmjs.org/cache-manager/-/cache-manager-2.11.1.tgz",
- "integrity": "sha512-XhUuc9eYwkzpK89iNewFwtvcDYMUsvtwzHeyEOPJna/WsVsXcrzsA1ft2M0QqPNunEzLhNCYPo05tEfG+YuNow==",
- "dependencies": {
- "async": "1.5.2",
- "lodash.clonedeep": "4.5.0",
- "lru-cache": "4.0.0"
- }
- },
- "node_modules/cache-manager-mongodb/node_modules/lru-cache": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.0.0.tgz",
- "integrity": "sha512-WKhDkjlLwzE8jAQdQlsxLUQTPXLCKX/4cJk6s5AlRtJkDBk0IKH5O51bVDH61K9N4bhbbyvLM6EiOuE8ovApPA==",
- "dependencies": {
- "pseudomap": "^1.0.1",
- "yallist": "^2.0.0"
- }
- },
- "node_modules/cache-manager-mongodb/node_modules/yallist": {
- "version": "2.1.2",
- "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz",
- "integrity": "sha512-ncTzHV7NvsQZkYe1DW7cbDLm0YpzHmZF5r/iyP3ZnQtMiJ+pjzisCiMNI+Sj+xQF5pXhSHxSB3uDbsBTzY/c2A=="
- },
"node_modules/call-bind": {
"version": "1.0.5",
"resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.5.tgz",
@@ -1239,77 +1203,19 @@
"node": ">=4"
}
},
- "node_modules/cli-truncate": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-4.0.0.tgz",
- "integrity": "sha512-nPdaFdQ0h/GEigbPClz11D0v/ZJEwxmeVZGeMo3Z5StPtUTkA9o1lD6QwoirYiSDzbcwn2XcjwmCp68W1IS4TA==",
- "dev": true,
- "dependencies": {
- "slice-ansi": "^5.0.0",
- "string-width": "^7.0.0"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/cli-truncate/node_modules/ansi-regex": {
- "version": "6.0.1",
- "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz",
- "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/ansi-regex?sponsor=1"
- }
- },
- "node_modules/cli-truncate/node_modules/emoji-regex": {
- "version": "10.3.0",
- "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.3.0.tgz",
- "integrity": "sha512-QpLs9D9v9kArv4lfDEgg1X/gN5XLnf/A6l9cs8SPZLRZR3ZkY9+kwIQTxm+fsSej5UMYGE8fdoaZVIBlqG0XTw==",
- "dev": true
- },
- "node_modules/cli-truncate/node_modules/string-width": {
- "version": "7.1.0",
- "resolved": "https://registry.npmjs.org/string-width/-/string-width-7.1.0.tgz",
- "integrity": "sha512-SEIJCWiX7Kg4c129n48aDRwLbFb2LJmXXFrWBG4NGaRtMQ3myKPKbwrD1BKqQn74oCoNMBVrfDEr5M9YxCsrkw==",
- "dev": true,
- "dependencies": {
- "emoji-regex": "^10.3.0",
- "get-east-asian-width": "^1.0.0",
- "strip-ansi": "^7.1.0"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/cli-truncate/node_modules/strip-ansi": {
- "version": "7.1.0",
- "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz",
- "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==",
- "dev": true,
- "dependencies": {
- "ansi-regex": "^6.0.1"
- },
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/strip-ansi?sponsor=1"
- }
- },
"node_modules/cli-width": {
"version": "2.2.0",
"resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz",
"integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk="
},
+ "node_modules/cluster-key-slot": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/cluster-key-slot/-/cluster-key-slot-1.1.2.tgz",
+ "integrity": "sha512-RMr0FhtfXemyinomL4hrWcYJxmX6deFdCxpJzhDttxgO1+bcCnkk+9drydLVDmAMG7NE6aN/fl4F7ucU/90gAA==",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
"node_modules/color-convert": {
"version": "1.9.3",
"resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
@@ -1323,12 +1229,6 @@
"resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
"integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU="
},
- "node_modules/colorette": {
- "version": "2.0.20",
- "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.20.tgz",
- "integrity": "sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w==",
- "dev": true
- },
"node_modules/combined-stream": {
"version": "1.0.8",
"resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz",
@@ -1340,15 +1240,6 @@
"node": ">= 0.8"
}
},
- "node_modules/commander": {
- "version": "11.1.0",
- "resolved": "https://registry.npmjs.org/commander/-/commander-11.1.0.tgz",
- "integrity": "sha512-yPVavfyCcRhmorC7rWlkHn15b4wDVgVmBA7kV4QVBsF7kv/9TKJAbAXVTxvTnwP8HHKjRCJDClKbciiYS7p0DQ==",
- "dev": true,
- "engines": {
- "node": ">=16"
- }
- },
"node_modules/concat-map": {
"version": "0.0.1",
"resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
@@ -1905,18 +1796,6 @@
"url": "https://opencollective.com/eslint"
}
},
- "node_modules/eslint-config-prettier": {
- "version": "9.1.0",
- "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-9.1.0.tgz",
- "integrity": "sha512-NSWl5BFQWEPi1j4TjVNItzYV7dZXZ+wP6I6ZhrBGpChQhZRUaElihE9uRRkcbRnNb76UMKDF3r+WTmNcGPKsqw==",
- "dev": true,
- "bin": {
- "eslint-config-prettier": "bin/cli.js"
- },
- "peerDependencies": {
- "eslint": ">=7.0.0"
- }
- },
"node_modules/eslint-import-resolver-node": {
"version": "0.3.9",
"resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.9.tgz",
@@ -2051,36 +1930,6 @@
"semver": "bin/semver.js"
}
},
- "node_modules/eslint-plugin-prettier": {
- "version": "5.1.3",
- "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-5.1.3.tgz",
- "integrity": "sha512-C9GCVAs4Eq7ZC/XFQHITLiHJxQngdtraXaM+LoUFoFp/lHNl2Zn8f3WQbe9HvTBBQ9YnKFB0/2Ajdqwo5D1EAw==",
- "dev": true,
- "dependencies": {
- "prettier-linter-helpers": "^1.0.0",
- "synckit": "^0.8.6"
- },
- "engines": {
- "node": "^14.18.0 || >=16.0.0"
- },
- "funding": {
- "url": "https://opencollective.com/eslint-plugin-prettier"
- },
- "peerDependencies": {
- "@types/eslint": ">=8.0.0",
- "eslint": ">=8.0.0",
- "eslint-config-prettier": "*",
- "prettier": ">=3.0.0"
- },
- "peerDependenciesMeta": {
- "@types/eslint": {
- "optional": true
- },
- "eslint-config-prettier": {
- "optional": true
- }
- }
- },
"node_modules/eslint-scope": {
"version": "7.2.2",
"resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz",
@@ -2417,86 +2266,6 @@
"es5-ext": "~0.10.14"
}
},
- "node_modules/eventemitter3": {
- "version": "5.0.1",
- "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-5.0.1.tgz",
- "integrity": "sha512-GWkBvjiSZK87ELrYOSESUYeVIc9mvLLf/nXalMOS5dYrgZq9o5OVkbZAVM06CVxYsCwH9BDZFPlQTlPA1j4ahA==",
- "dev": true
- },
- "node_modules/execa": {
- "version": "8.0.1",
- "resolved": "https://registry.npmjs.org/execa/-/execa-8.0.1.tgz",
- "integrity": "sha512-VyhnebXciFV2DESc+p6B+y0LjSm0krU4OgJN44qFAhBY0TJ+1V61tYD2+wHusZ6F9n5K+vl8k0sTy7PEfV4qpg==",
- "dev": true,
- "dependencies": {
- "cross-spawn": "^7.0.3",
- "get-stream": "^8.0.1",
- "human-signals": "^5.0.0",
- "is-stream": "^3.0.0",
- "merge-stream": "^2.0.0",
- "npm-run-path": "^5.1.0",
- "onetime": "^6.0.0",
- "signal-exit": "^4.1.0",
- "strip-final-newline": "^3.0.0"
- },
- "engines": {
- "node": ">=16.17"
- },
- "funding": {
- "url": "https://github.com/sindresorhus/execa?sponsor=1"
- }
- },
- "node_modules/execa/node_modules/is-stream": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-3.0.0.tgz",
- "integrity": "sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA==",
- "dev": true,
- "engines": {
- "node": "^12.20.0 || ^14.13.1 || >=16.0.0"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/execa/node_modules/mimic-fn": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-4.0.0.tgz",
- "integrity": "sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/execa/node_modules/onetime": {
- "version": "6.0.0",
- "resolved": "https://registry.npmjs.org/onetime/-/onetime-6.0.0.tgz",
- "integrity": "sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ==",
- "dev": true,
- "dependencies": {
- "mimic-fn": "^4.0.0"
- },
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/execa/node_modules/signal-exit": {
- "version": "4.1.0",
- "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz",
- "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==",
- "dev": true,
- "engines": {
- "node": ">=14"
- },
- "funding": {
- "url": "https://github.com/sponsors/isaacs"
- }
- },
"node_modules/express": {
"version": "4.18.2",
"resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz",
@@ -2593,12 +2362,6 @@
"resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
"integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q=="
},
- "node_modules/fast-diff": {
- "version": "1.3.0",
- "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.3.0.tgz",
- "integrity": "sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw==",
- "dev": true
- },
"node_modules/fast-glob": {
"version": "3.3.2",
"resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz",
@@ -2853,16 +2616,12 @@
"url": "https://github.com/sponsors/ljharb"
}
},
- "node_modules/get-east-asian-width": {
- "version": "1.2.0",
- "resolved": "https://registry.npmjs.org/get-east-asian-width/-/get-east-asian-width-1.2.0.tgz",
- "integrity": "sha512-2nk+7SIVb14QrgXFHcm84tD4bKQz0RxPuMT8Ag5KPOq7J5fEmAg0UbXdTOSHqNuHSU28k55qnceesxXRZGzKWA==",
- "dev": true,
+ "node_modules/generic-pool": {
+ "version": "3.9.0",
+ "resolved": "https://registry.npmjs.org/generic-pool/-/generic-pool-3.9.0.tgz",
+ "integrity": "sha512-hymDOu5B53XvN4QT9dBmZxPX4CWhBPPLguTZ9MMFeFa/Kg0xWVfylOVNlJji/E7yTZWFd/q9GO5TxDLq156D7g==",
"engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
+ "node": ">= 4"
}
},
"node_modules/get-intrinsic": {
@@ -2879,18 +2638,6 @@
"url": "https://github.com/sponsors/ljharb"
}
},
- "node_modules/get-stream": {
- "version": "8.0.1",
- "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-8.0.1.tgz",
- "integrity": "sha512-VaUJspBffn/LMCJVoMvSAdmscJyS1auj5Zulnn5UoYcY531UWmdwhRWkcGKnGU93m5HSXP9LP2usOryrBtQowA==",
- "dev": true,
- "engines": {
- "node": ">=16"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
"node_modules/get-symbol-description": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz",
@@ -3143,30 +2890,6 @@
"npm": ">=1.3.7"
}
},
- "node_modules/human-signals": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-5.0.0.tgz",
- "integrity": "sha512-AXcZb6vzzrFAUE61HnN4mpLqd/cSIwNQjtNWR0euPm6y0iqx3G4gOXaIDdtdDwZmhwe82LA6+zinmW4UBWVePQ==",
- "dev": true,
- "engines": {
- "node": ">=16.17.0"
- }
- },
- "node_modules/husky": {
- "version": "9.0.7",
- "resolved": "https://registry.npmjs.org/husky/-/husky-9.0.7.tgz",
- "integrity": "sha512-vWdusw+y12DUEeoZqW1kplOFqk3tedGV8qlga8/SF6a3lOiWLqGZZQvfWvY0fQYdfiRi/u1DFNpudTSV9l1aCg==",
- "dev": true,
- "bin": {
- "husky": "bin.js"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/sponsors/typicode"
- }
- },
"node_modules/iconv-lite": {
"version": "0.4.24",
"resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
@@ -3551,11 +3274,6 @@
"node": ">=4"
}
},
- "node_modules/isarray": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
- "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ=="
- },
"node_modules/isexe": {
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
@@ -3652,182 +3370,6 @@
"node": ">= 0.8.0"
}
},
- "node_modules/lilconfig": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-3.0.0.tgz",
- "integrity": "sha512-K2U4W2Ff5ibV7j7ydLr+zLAkIg5JJ4lPn1Ltsdt+Tz/IjQ8buJ55pZAxoP34lqIiwtF9iAvtLv3JGv7CAyAg+g==",
- "dev": true,
- "engines": {
- "node": ">=14"
- }
- },
- "node_modules/lint-staged": {
- "version": "15.2.1",
- "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-15.2.1.tgz",
- "integrity": "sha512-dhwAPnM85VdshybV9FWI/9ghTvMLoQLEXgVMx+ua2DN7mdfzd/tRfoU2yhMcBac0RHkofoxdnnJUokr8s4zKmQ==",
- "dev": true,
- "dependencies": {
- "chalk": "5.3.0",
- "commander": "11.1.0",
- "debug": "4.3.4",
- "execa": "8.0.1",
- "lilconfig": "3.0.0",
- "listr2": "8.0.1",
- "micromatch": "4.0.5",
- "pidtree": "0.6.0",
- "string-argv": "0.3.2",
- "yaml": "2.3.4"
- },
- "bin": {
- "lint-staged": "bin/lint-staged.js"
- },
- "engines": {
- "node": ">=18.12.0"
- },
- "funding": {
- "url": "https://opencollective.com/lint-staged"
- }
- },
- "node_modules/lint-staged/node_modules/chalk": {
- "version": "5.3.0",
- "resolved": "https://registry.npmjs.org/chalk/-/chalk-5.3.0.tgz",
- "integrity": "sha512-dLitG79d+GV1Nb/VYcCDFivJeK1hiukt9QjRNVOsUtTy1rR1YJsmpGGTZ3qJos+uw7WmWF4wUwBd9jxjocFC2w==",
- "dev": true,
- "engines": {
- "node": "^12.17.0 || ^14.13 || >=16.0.0"
- },
- "funding": {
- "url": "https://github.com/chalk/chalk?sponsor=1"
- }
- },
- "node_modules/lint-staged/node_modules/debug": {
- "version": "4.3.4",
- "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz",
- "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==",
- "dev": true,
- "dependencies": {
- "ms": "2.1.2"
- },
- "engines": {
- "node": ">=6.0"
- },
- "peerDependenciesMeta": {
- "supports-color": {
- "optional": true
- }
- }
- },
- "node_modules/lint-staged/node_modules/ms": {
- "version": "2.1.2",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
- "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==",
- "dev": true
- },
- "node_modules/lint-staged/node_modules/yaml": {
- "version": "2.3.4",
- "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.3.4.tgz",
- "integrity": "sha512-8aAvwVUSHpfEqTQ4w/KMlf3HcRdt50E5ODIQJBw1fQ5RL34xabzxtUlzTXVqc4rkZsPbvrXKWnABCD7kWSmocA==",
- "dev": true,
- "engines": {
- "node": ">= 14"
- }
- },
- "node_modules/listr2": {
- "version": "8.0.1",
- "resolved": "https://registry.npmjs.org/listr2/-/listr2-8.0.1.tgz",
- "integrity": "sha512-ovJXBXkKGfq+CwmKTjluEqFi3p4h8xvkxGQQAQan22YCgef4KZ1mKGjzfGh6PL6AW5Csw0QiQPNuQyH+6Xk3hA==",
- "dev": true,
- "dependencies": {
- "cli-truncate": "^4.0.0",
- "colorette": "^2.0.20",
- "eventemitter3": "^5.0.1",
- "log-update": "^6.0.0",
- "rfdc": "^1.3.0",
- "wrap-ansi": "^9.0.0"
- },
- "engines": {
- "node": ">=18.0.0"
- }
- },
- "node_modules/listr2/node_modules/ansi-regex": {
- "version": "6.0.1",
- "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz",
- "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/ansi-regex?sponsor=1"
- }
- },
- "node_modules/listr2/node_modules/ansi-styles": {
- "version": "6.2.1",
- "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz",
- "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/ansi-styles?sponsor=1"
- }
- },
- "node_modules/listr2/node_modules/emoji-regex": {
- "version": "10.3.0",
- "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.3.0.tgz",
- "integrity": "sha512-QpLs9D9v9kArv4lfDEgg1X/gN5XLnf/A6l9cs8SPZLRZR3ZkY9+kwIQTxm+fsSej5UMYGE8fdoaZVIBlqG0XTw==",
- "dev": true
- },
- "node_modules/listr2/node_modules/string-width": {
- "version": "7.1.0",
- "resolved": "https://registry.npmjs.org/string-width/-/string-width-7.1.0.tgz",
- "integrity": "sha512-SEIJCWiX7Kg4c129n48aDRwLbFb2LJmXXFrWBG4NGaRtMQ3myKPKbwrD1BKqQn74oCoNMBVrfDEr5M9YxCsrkw==",
- "dev": true,
- "dependencies": {
- "emoji-regex": "^10.3.0",
- "get-east-asian-width": "^1.0.0",
- "strip-ansi": "^7.1.0"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/listr2/node_modules/strip-ansi": {
- "version": "7.1.0",
- "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz",
- "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==",
- "dev": true,
- "dependencies": {
- "ansi-regex": "^6.0.1"
- },
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/strip-ansi?sponsor=1"
- }
- },
- "node_modules/listr2/node_modules/wrap-ansi": {
- "version": "9.0.0",
- "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.0.tgz",
- "integrity": "sha512-G8ura3S+3Z2G+mkgNRq8dqaFZAuxfsxpBB8OCTGRTCtp+l/v9nbFNmCUP1BZMts3G1142MsZfn6eeUKrr4PD1Q==",
- "dev": true,
- "dependencies": {
- "ansi-styles": "^6.2.1",
- "string-width": "^7.0.0",
- "strip-ansi": "^7.1.0"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/chalk/wrap-ansi?sponsor=1"
- }
- },
"node_modules/lodash": {
"version": "4.17.21",
"resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz",
@@ -3844,217 +3386,6 @@
"integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==",
"dev": true
},
- "node_modules/log-update": {
- "version": "6.0.0",
- "resolved": "https://registry.npmjs.org/log-update/-/log-update-6.0.0.tgz",
- "integrity": "sha512-niTvB4gqvtof056rRIrTZvjNYE4rCUzO6X/X+kYjd7WFxXeJ0NwEFnRxX6ehkvv3jTwrXnNdtAak5XYZuIyPFw==",
- "dev": true,
- "dependencies": {
- "ansi-escapes": "^6.2.0",
- "cli-cursor": "^4.0.0",
- "slice-ansi": "^7.0.0",
- "strip-ansi": "^7.1.0",
- "wrap-ansi": "^9.0.0"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/log-update/node_modules/ansi-escapes": {
- "version": "6.2.0",
- "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-6.2.0.tgz",
- "integrity": "sha512-kzRaCqXnpzWs+3z5ABPQiVke+iq0KXkHo8xiWV4RPTi5Yli0l97BEQuhXV1s7+aSU/fu1kUuxgS4MsQ0fRuygw==",
- "dev": true,
- "dependencies": {
- "type-fest": "^3.0.0"
- },
- "engines": {
- "node": ">=14.16"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/log-update/node_modules/ansi-regex": {
- "version": "6.0.1",
- "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz",
- "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/ansi-regex?sponsor=1"
- }
- },
- "node_modules/log-update/node_modules/ansi-styles": {
- "version": "6.2.1",
- "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz",
- "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/ansi-styles?sponsor=1"
- }
- },
- "node_modules/log-update/node_modules/cli-cursor": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-4.0.0.tgz",
- "integrity": "sha512-VGtlMu3x/4DOtIUwEkRezxUZ2lBacNJCHash0N0WeZDBS+7Ux1dm3XWAgWYxLJFMMdOeXMHXorshEFhbMSGelg==",
- "dev": true,
- "dependencies": {
- "restore-cursor": "^4.0.0"
- },
- "engines": {
- "node": "^12.20.0 || ^14.13.1 || >=16.0.0"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/log-update/node_modules/emoji-regex": {
- "version": "10.3.0",
- "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.3.0.tgz",
- "integrity": "sha512-QpLs9D9v9kArv4lfDEgg1X/gN5XLnf/A6l9cs8SPZLRZR3ZkY9+kwIQTxm+fsSej5UMYGE8fdoaZVIBlqG0XTw==",
- "dev": true
- },
- "node_modules/log-update/node_modules/is-fullwidth-code-point": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-5.0.0.tgz",
- "integrity": "sha512-OVa3u9kkBbw7b8Xw5F9P+D/T9X+Z4+JruYVNapTjPYZYUznQ5YfWeFkOj606XYYW8yugTfC8Pj0hYqvi4ryAhA==",
- "dev": true,
- "dependencies": {
- "get-east-asian-width": "^1.0.0"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/log-update/node_modules/mimic-fn": {
- "version": "2.1.0",
- "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz",
- "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==",
- "dev": true,
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/log-update/node_modules/onetime": {
- "version": "5.1.2",
- "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz",
- "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==",
- "dev": true,
- "dependencies": {
- "mimic-fn": "^2.1.0"
- },
- "engines": {
- "node": ">=6"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/log-update/node_modules/restore-cursor": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-4.0.0.tgz",
- "integrity": "sha512-I9fPXU9geO9bHOt9pHHOhOkYerIMsmVaWB0rA2AI9ERh/+x/i7MV5HKBNrg+ljO5eoPVgCcnFuRjJ9uH6I/3eg==",
- "dev": true,
- "dependencies": {
- "onetime": "^5.1.0",
- "signal-exit": "^3.0.2"
- },
- "engines": {
- "node": "^12.20.0 || ^14.13.1 || >=16.0.0"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/log-update/node_modules/slice-ansi": {
- "version": "7.1.0",
- "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-7.1.0.tgz",
- "integrity": "sha512-bSiSngZ/jWeX93BqeIAbImyTbEihizcwNjFoRUIY/T1wWQsfsm2Vw1agPKylXvQTU7iASGdHhyqRlqQzfz+Htg==",
- "dev": true,
- "dependencies": {
- "ansi-styles": "^6.2.1",
- "is-fullwidth-code-point": "^5.0.0"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/chalk/slice-ansi?sponsor=1"
- }
- },
- "node_modules/log-update/node_modules/string-width": {
- "version": "7.1.0",
- "resolved": "https://registry.npmjs.org/string-width/-/string-width-7.1.0.tgz",
- "integrity": "sha512-SEIJCWiX7Kg4c129n48aDRwLbFb2LJmXXFrWBG4NGaRtMQ3myKPKbwrD1BKqQn74oCoNMBVrfDEr5M9YxCsrkw==",
- "dev": true,
- "dependencies": {
- "emoji-regex": "^10.3.0",
- "get-east-asian-width": "^1.0.0",
- "strip-ansi": "^7.1.0"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/log-update/node_modules/strip-ansi": {
- "version": "7.1.0",
- "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz",
- "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==",
- "dev": true,
- "dependencies": {
- "ansi-regex": "^6.0.1"
- },
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/strip-ansi?sponsor=1"
- }
- },
- "node_modules/log-update/node_modules/type-fest": {
- "version": "3.13.1",
- "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-3.13.1.tgz",
- "integrity": "sha512-tLq3bSNx+xSpwvAJnzrK0Ep5CLNWjvFTOp71URMaAEWBfRb9nnJiBoUe0tF8bI4ZFO3omgBR6NvnbzVUT3Ly4g==",
- "dev": true,
- "engines": {
- "node": ">=14.16"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/log-update/node_modules/wrap-ansi": {
- "version": "9.0.0",
- "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.0.tgz",
- "integrity": "sha512-G8ura3S+3Z2G+mkgNRq8dqaFZAuxfsxpBB8OCTGRTCtp+l/v9nbFNmCUP1BZMts3G1142MsZfn6eeUKrr4PD1Q==",
- "dev": true,
- "dependencies": {
- "ansi-styles": "^6.2.1",
- "string-width": "^7.0.0",
- "strip-ansi": "^7.1.0"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/chalk/wrap-ansi?sponsor=1"
- }
- },
"node_modules/lru-cache": {
"version": "6.0.0",
"resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
@@ -4097,23 +3428,11 @@
"node": ">= 0.6"
}
},
- "node_modules/memory-pager": {
- "version": "1.5.0",
- "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz",
- "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==",
- "optional": true
- },
"node_modules/merge-descriptors": {
"version": "1.0.1",
"resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
"integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E="
},
- "node_modules/merge-stream": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz",
- "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==",
- "dev": true
- },
"node_modules/merge2": {
"version": "1.4.1",
"resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz",
@@ -4228,44 +3547,6 @@
"node": "*"
}
},
- "node_modules/mongodb": {
- "version": "3.7.3",
- "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.7.3.tgz",
- "integrity": "sha512-Psm+g3/wHXhjBEktkxXsFMZvd3nemI0r3IPsE0bU+4//PnvNWKkzhZcEsbPcYiWqe8XqXJJEg4Tgtr7Raw67Yw==",
- "dependencies": {
- "bl": "^2.2.1",
- "bson": "^1.1.4",
- "denque": "^1.4.1",
- "optional-require": "^1.1.8",
- "safe-buffer": "^5.1.2"
- },
- "engines": {
- "node": ">=4"
- },
- "optionalDependencies": {
- "saslprep": "^1.0.0"
- },
- "peerDependenciesMeta": {
- "aws4": {
- "optional": true
- },
- "bson-ext": {
- "optional": true
- },
- "kerberos": {
- "optional": true
- },
- "mongodb-client-encryption": {
- "optional": true
- },
- "mongodb-extjson": {
- "optional": true
- },
- "snappy": {
- "optional": true
- }
- }
- },
"node_modules/ms": {
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
@@ -4328,33 +3609,6 @@
"node": ">=0.10.0"
}
},
- "node_modules/npm-run-path": {
- "version": "5.2.0",
- "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-5.2.0.tgz",
- "integrity": "sha512-W4/tgAXFqFA0iL7fk0+uQ3g7wkL8xJmx3XdK0VGb4cHW//eZTtKGvFBBoRKVTpY7n6ze4NL9ly7rgXcHufqXKg==",
- "dev": true,
- "dependencies": {
- "path-key": "^4.0.0"
- },
- "engines": {
- "node": "^12.20.0 || ^14.13.1 || >=16.0.0"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/npm-run-path/node_modules/path-key": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/path-key/-/path-key-4.0.0.tgz",
- "integrity": "sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
"node_modules/oauth-sign": {
"version": "0.9.0",
"resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz",
@@ -4502,17 +3756,6 @@
"node": ">=4"
}
},
- "node_modules/optional-require": {
- "version": "1.1.8",
- "resolved": "https://registry.npmjs.org/optional-require/-/optional-require-1.1.8.tgz",
- "integrity": "sha512-jq83qaUb0wNg9Krv1c5OQ+58EK+vHde6aBPzLvPPqJm89UQWsvSuFy9X/OSNJnFeSOKo7btE0n8Nl2+nE+z5nA==",
- "dependencies": {
- "require-at": "^1.0.6"
- },
- "engines": {
- "node": ">=4"
- }
- },
"node_modules/optionator": {
"version": "0.9.3",
"resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz",
@@ -4634,18 +3877,6 @@
"url": "https://github.com/sponsors/jonschlinkert"
}
},
- "node_modules/pidtree": {
- "version": "0.6.0",
- "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.6.0.tgz",
- "integrity": "sha512-eG2dWTVw5bzqGRztnHExczNxt5VGsE6OwTeCG3fdUf9KBsZzO3R5OIIIzWR+iZA0NtZ+RDVdaoE2dK1cn6jH4g==",
- "dev": true,
- "bin": {
- "pidtree": "bin/pidtree.js"
- },
- "engines": {
- "node": ">=0.10"
- }
- },
"node_modules/prelude-ls": {
"version": "1.2.1",
"resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz",
@@ -4663,38 +3894,6 @@
"request": "^2.83.0"
}
},
- "node_modules/prettier": {
- "version": "3.2.4",
- "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.2.4.tgz",
- "integrity": "sha512-FWu1oLHKCrtpO1ypU6J0SbK2d9Ckwysq6bHj/uaCP26DxrPpppCLQRGVuqAxSTvhF00AcvDRyYrLNW7ocBhFFQ==",
- "dev": true,
- "bin": {
- "prettier": "bin/prettier.cjs"
- },
- "engines": {
- "node": ">=14"
- },
- "funding": {
- "url": "https://github.com/prettier/prettier?sponsor=1"
- }
- },
- "node_modules/prettier-linter-helpers": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz",
- "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==",
- "dev": true,
- "dependencies": {
- "fast-diff": "^1.1.2"
- },
- "engines": {
- "node": ">=6.0.0"
- }
- },
- "node_modules/process-nextick-args": {
- "version": "2.0.1",
- "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz",
- "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag=="
- },
"node_modules/proxy-addr": {
"version": "2.0.7",
"resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz",
@@ -4712,11 +3911,6 @@
"resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz",
"integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg=="
},
- "node_modules/pseudomap": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz",
- "integrity": "sha512-b/YwNhb8lk1Zz2+bXXpS/LK9OisiZZ1SNsSLxN1x2OXVEhW2Ckr/7mWE5vrC1ZTiJlD9g19jWszTmJsB+oEpFQ=="
- },
"node_modules/psl": {
"version": "1.8.0",
"resolved": "https://registry.npmjs.org/psl/-/psl-1.8.0.tgz",
@@ -4786,25 +3980,6 @@
"node": ">= 0.8"
}
},
- "node_modules/readable-stream": {
- "version": "2.3.8",
- "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz",
- "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==",
- "dependencies": {
- "core-util-is": "~1.0.0",
- "inherits": "~2.0.3",
- "isarray": "~1.0.0",
- "process-nextick-args": "~2.0.0",
- "safe-buffer": "~5.1.1",
- "string_decoder": "~1.1.1",
- "util-deprecate": "~1.0.1"
- }
- },
- "node_modules/readable-stream/node_modules/safe-buffer": {
- "version": "5.1.2",
- "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
- "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
- },
"node_modules/readdirp": {
"version": "3.6.0",
"resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
@@ -4826,6 +4001,48 @@
"request": "^2.83.0"
}
},
+ "node_modules/redis": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/redis/-/redis-3.1.2.tgz",
+ "integrity": "sha512-grn5KoZLr/qrRQVwoSkmzdbw6pwF+/rwODtrOr6vuBRiR/f3rjSTGupbF90Zpqm2oenix8Do6RV7pYEkGwlKkw==",
+ "dependencies": {
+ "denque": "^1.5.0",
+ "redis-commands": "^1.7.0",
+ "redis-errors": "^1.2.0",
+ "redis-parser": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/node-redis"
+ }
+ },
+ "node_modules/redis-commands": {
+ "version": "1.7.0",
+ "resolved": "https://registry.npmjs.org/redis-commands/-/redis-commands-1.7.0.tgz",
+ "integrity": "sha512-nJWqw3bTFy21hX/CPKHth6sfhZbdiHP6bTawSgQBlKOVRG7EZkfHbbHwQJnrE4vsQf0CMNE+3gJ4Fmm16vdVlQ=="
+ },
+ "node_modules/redis-errors": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/redis-errors/-/redis-errors-1.2.0.tgz",
+ "integrity": "sha512-1qny3OExCf0UvUV/5wpYKf2YwPcOqXzkwKKSmKHiE6ZMQs5heeE/c8eXK+PNllPvmjgAbfnsbpkGZWy8cBpn9w==",
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/redis-parser": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/redis-parser/-/redis-parser-3.0.0.tgz",
+ "integrity": "sha512-DJnGAeenTdpMEH6uAJRK/uiyEIH9WVsUmoLwzudwGJUwZPp80PDBWPHXSAGNPwNvIXAbe7MSUB1zQFugFml66A==",
+ "dependencies": {
+ "redis-errors": "^1.0.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
"node_modules/regexp.prototype.flags": {
"version": "1.5.1",
"resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.1.tgz",
@@ -4887,14 +4104,6 @@
"node": ">=0.6"
}
},
- "node_modules/require-at": {
- "version": "1.0.6",
- "resolved": "https://registry.npmjs.org/require-at/-/require-at-1.0.6.tgz",
- "integrity": "sha512-7i1auJbMUrXEAZCOQ0VNJgmcT2VOKPRl2YGJwgpHpC9CE91Mv4/4UYIUm4chGJaI381ZDq1JUicFii64Hapd8g==",
- "engines": {
- "node": ">=4"
- }
- },
"node_modules/resolve": {
"version": "1.22.8",
"resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz",
@@ -4943,12 +4152,6 @@
"node": ">=0.10.0"
}
},
- "node_modules/rfdc": {
- "version": "1.3.1",
- "resolved": "https://registry.npmjs.org/rfdc/-/rfdc-1.3.1.tgz",
- "integrity": "sha512-r5a3l5HzYlIC68TpmYKlxWjmOP6wiPJ1vWv2HeLhNsRZMrCkxeqxiHlQ21oXmQ4F3SiryXBHhAD7JZqvOJjFmg==",
- "dev": true
- },
"node_modules/rimraf": {
"version": "3.0.2",
"resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz",
@@ -5096,18 +4299,6 @@
"resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
"integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg=="
},
- "node_modules/saslprep": {
- "version": "1.0.3",
- "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz",
- "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==",
- "optional": true,
- "dependencies": {
- "sparse-bitfield": "^3.0.3"
- },
- "engines": {
- "node": ">=6"
- }
- },
"node_modules/sax": {
"version": "1.3.0",
"resolved": "https://registry.npmjs.org/sax/-/sax-1.3.0.tgz",
@@ -5245,55 +4436,6 @@
"node": ">=8"
}
},
- "node_modules/slice-ansi": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-5.0.0.tgz",
- "integrity": "sha512-FC+lgizVPfie0kkhqUScwRu1O/lF6NOgJmlCgK+/LYxDCTk8sGelYaHDhFcDN+Sn3Cv+3VSa4Byeo+IMCzpMgQ==",
- "dev": true,
- "dependencies": {
- "ansi-styles": "^6.0.0",
- "is-fullwidth-code-point": "^4.0.0"
- },
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/slice-ansi?sponsor=1"
- }
- },
- "node_modules/slice-ansi/node_modules/ansi-styles": {
- "version": "6.2.1",
- "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz",
- "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/ansi-styles?sponsor=1"
- }
- },
- "node_modules/slice-ansi/node_modules/is-fullwidth-code-point": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-4.0.0.tgz",
- "integrity": "sha512-O4L094N2/dZ7xqVdrXhh9r1KODPJpFms8B5sGdJLPy664AgvXsreZUyCQQNItZRDlYug4xStLjNp/sz3HvBowQ==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/sparse-bitfield": {
- "version": "3.0.3",
- "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz",
- "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=",
- "optional": true,
- "dependencies": {
- "memory-pager": "^1.0.2"
- }
- },
"node_modules/sshpk": {
"version": "1.16.1",
"resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz",
@@ -5353,28 +4495,6 @@
"addon-bootstrap": "cli/bootstrap.js"
}
},
- "node_modules/string_decoder": {
- "version": "1.1.1",
- "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz",
- "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==",
- "dependencies": {
- "safe-buffer": "~5.1.0"
- }
- },
- "node_modules/string_decoder/node_modules/safe-buffer": {
- "version": "5.1.2",
- "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
- "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
- },
- "node_modules/string-argv": {
- "version": "0.3.2",
- "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.2.tgz",
- "integrity": "sha512-aqD2Q0144Z+/RqG52NeHEkZauTAUWJO8c6yTftGJKO3Tja5tUgIfmIl6kExvhtxSDP7fXB6DvzkfMpCd/F3G+Q==",
- "dev": true,
- "engines": {
- "node": ">=0.6.19"
- }
- },
"node_modules/string-width": {
"version": "2.1.1",
"resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz",
@@ -5462,18 +4582,6 @@
"node": ">=6"
}
},
- "node_modules/strip-final-newline": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-3.0.0.tgz",
- "integrity": "sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
"node_modules/strip-json-comments": {
"version": "3.1.1",
"resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz",
@@ -5509,28 +4617,6 @@
"url": "https://github.com/sponsors/ljharb"
}
},
- "node_modules/synckit": {
- "version": "0.8.8",
- "resolved": "https://registry.npmjs.org/synckit/-/synckit-0.8.8.tgz",
- "integrity": "sha512-HwOKAP7Wc5aRGYdKH+dw0PRRpbO841v2DENBtjnR5HFWoiNByAl7vrx3p0G/rCyYXQsrxqtX48TImFtPcIHSpQ==",
- "dev": true,
- "dependencies": {
- "@pkgr/core": "^0.1.0",
- "tslib": "^2.6.2"
- },
- "engines": {
- "node": "^14.18.0 || >=16.0.0"
- },
- "funding": {
- "url": "https://opencollective.com/unts"
- }
- },
- "node_modules/synckit/node_modules/tslib": {
- "version": "2.6.2",
- "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz",
- "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==",
- "dev": true
- },
"node_modules/text-table": {
"version": "0.2.0",
"resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz",
@@ -5854,11 +4940,6 @@
"lodash.clonedeep": "^4.5.0"
}
},
- "node_modules/util-deprecate": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
- "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8="
- },
"node_modules/utils-merge": {
"version": "1.0.1",
"resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
diff --git a/src/node/addon-jackett/package.json b/src/addon-jackett/package.json
similarity index 90%
rename from src/node/addon-jackett/package.json
rename to src/addon-jackett/package.json
index fb3932d..d739328 100644
--- a/src/node/addon-jackett/package.json
+++ b/src/addon-jackett/package.json
@@ -14,7 +14,6 @@
"axios": "^1.6.1",
"bottleneck": "^2.19.5",
"cache-manager": "^3.4.4",
- "cache-manager-mongodb": "^0.3.0",
"cors": "^2.8.5",
"debrid-link-api": "^1.0.1",
"express": "^4.18.2",
@@ -33,7 +32,11 @@
"user-agents": "^1.0.1444",
"video-name-parser": "^1.4.6",
"xml-js": "^1.6.11",
- "xml2js": "^0.6.2"
+ "xml2js": "^0.6.2",
+ "@redis/client": "^1.5.14",
+ "@redis/json": "^1.0.6",
+ "@redis/search": "^1.1.6",
+ "cache-manager-redis-store": "^2.0.0"
},
"devDependencies": {
"@types/node": "^20.11.6",
diff --git a/src/node/addon-jackett/src/addon.js b/src/addon-jackett/src/addon.js
similarity index 100%
rename from src/node/addon-jackett/src/addon.js
rename to src/addon-jackett/src/addon.js
diff --git a/src/node/addon-jackett/src/index.js b/src/addon-jackett/src/index.js
similarity index 100%
rename from src/node/addon-jackett/src/index.js
rename to src/addon-jackett/src/index.js
diff --git a/src/node/addon-jackett/src/jackett/jacketParser.js b/src/addon-jackett/src/jackett/jacketParser.js
similarity index 100%
rename from src/node/addon-jackett/src/jackett/jacketParser.js
rename to src/addon-jackett/src/jackett/jacketParser.js
diff --git a/src/node/addon-jackett/src/jackett/jackett.js b/src/addon-jackett/src/jackett/jackett.js
similarity index 100%
rename from src/node/addon-jackett/src/jackett/jackett.js
rename to src/addon-jackett/src/jackett/jackett.js
diff --git a/src/node/addon-jackett/src/jackett/jackettQueries.js b/src/addon-jackett/src/jackett/jackettQueries.js
similarity index 100%
rename from src/node/addon-jackett/src/jackett/jackettQueries.js
rename to src/addon-jackett/src/jackett/jackettQueries.js
diff --git a/src/node/addon-jackett/src/lib/cache.js b/src/addon-jackett/src/lib/cache.js
similarity index 79%
rename from src/node/addon-jackett/src/lib/cache.js
rename to src/addon-jackett/src/lib/cache.js
index d51adb5..743b932 100644
--- a/src/node/addon-jackett/src/lib/cache.js
+++ b/src/addon-jackett/src/lib/cache.js
@@ -1,7 +1,7 @@
import cacheManager from 'cache-manager';
-import mangodbStore from 'cache-manager-mongodb';
import { isStaticUrl } from '../moch/static.js';
import {cacheConfig} from "./settings.js";
+import redisStore from 'cache-manager-redis-store';
const STREAM_KEY_PREFIX = `${cacheConfig.GLOBAL_KEY_PREFIX}|stream`;
const IMDB_KEY_PREFIX = `${cacheConfig.GLOBAL_KEY_PREFIX}|imdb`;
@@ -12,28 +12,20 @@ const memoryCache = initiateMemoryCache();
const remoteCache = initiateRemoteCache();
function initiateRemoteCache() {
- if (cacheConfig.NO_CACHE) {
- return null;
- } else if (cacheConfig.MONGODB_URI) {
- return cacheManager.caching({
- store: mangodbStore,
- uri: cacheConfig.MONGODB_URI,
- options: {
- collection: 'jackettio_addon_collection',
- socketTimeoutMS: 120000,
- useNewUrlParser: true,
- useUnifiedTopology: false,
- ttl: cacheConfig.STREAM_EMPTY_TTL
- },
- ttl: cacheConfig.STREAM_EMPTY_TTL,
- ignoreCacheErrors: true
- });
- } else {
- return cacheManager.caching({
- store: 'memory',
- ttl: cacheConfig.STREAM_EMPTY_TTL
- });
- }
+ if (cacheConfig.NO_CACHE) {
+ return null;
+ } else if (cacheConfig.REDIS_CONNECTION_STRING) {
+ return cacheManager.caching({
+ store: redisStore,
+ ttl: cacheConfig.STREAM_EMPTY_TTL,
+ url: cacheConfig.REDIS_CONNECTION_STRING
+ });
+ } else {
+ return cacheManager.caching({
+ store: 'memory',
+ ttl: cacheConfig.STREAM_EMPTY_TTL
+ });
+ }
}
function initiateMemoryCache() {
diff --git a/src/node/addon-jackett/src/lib/cinemetaProvider.js b/src/addon-jackett/src/lib/cinemetaProvider.js
similarity index 100%
rename from src/node/addon-jackett/src/lib/cinemetaProvider.js
rename to src/addon-jackett/src/lib/cinemetaProvider.js
diff --git a/src/node/addon-jackett/src/lib/configuration.js b/src/addon-jackett/src/lib/configuration.js
similarity index 100%
rename from src/node/addon-jackett/src/lib/configuration.js
rename to src/addon-jackett/src/lib/configuration.js
diff --git a/src/node/addon-jackett/src/lib/extension.js b/src/addon-jackett/src/lib/extension.js
similarity index 100%
rename from src/node/addon-jackett/src/lib/extension.js
rename to src/addon-jackett/src/lib/extension.js
diff --git a/src/node/addon-jackett/src/lib/landingTemplate.js b/src/addon-jackett/src/lib/landingTemplate.js
similarity index 100%
rename from src/node/addon-jackett/src/lib/landingTemplate.js
rename to src/addon-jackett/src/lib/landingTemplate.js
diff --git a/src/node/addon-jackett/src/lib/magnetHelper.js b/src/addon-jackett/src/lib/magnetHelper.js
similarity index 100%
rename from src/node/addon-jackett/src/lib/magnetHelper.js
rename to src/addon-jackett/src/lib/magnetHelper.js
diff --git a/src/node/addon-jackett/src/lib/manifest.js b/src/addon-jackett/src/lib/manifest.js
similarity index 100%
rename from src/node/addon-jackett/src/lib/manifest.js
rename to src/addon-jackett/src/lib/manifest.js
diff --git a/src/node/addon-jackett/src/lib/promises.js b/src/addon-jackett/src/lib/promises.js
similarity index 100%
rename from src/node/addon-jackett/src/lib/promises.js
rename to src/addon-jackett/src/lib/promises.js
diff --git a/src/node/addon-jackett/src/lib/requestHelper.js b/src/addon-jackett/src/lib/requestHelper.js
similarity index 100%
rename from src/node/addon-jackett/src/lib/requestHelper.js
rename to src/addon-jackett/src/lib/requestHelper.js
diff --git a/src/node/addon-jackett/src/lib/settings.js b/src/addon-jackett/src/lib/settings.js
similarity index 95%
rename from src/node/addon-jackett/src/lib/settings.js
rename to src/addon-jackett/src/lib/settings.js
index a435b0e..fcf25cf 100644
--- a/src/node/addon-jackett/src/lib/settings.js
+++ b/src/addon-jackett/src/lib/settings.js
@@ -25,7 +25,7 @@ export const cinemetaConfig = {
}
export const cacheConfig = {
- MONGODB_URI: process.env.MONGODB_URI,
+ REDIS_CONNECTION_STRING: process.env.REDIS_CONNECTION_STRING || 'redis://localhost:6379/0',
NO_CACHE: parseBool(process.env.NO_CACHE, false),
IMDB_TTL: parseInt(process.env.IMDB_TTL || 60 * 60 * 4), // 4 Hours
STREAM_TTL: parseInt(process.env.STREAM_TTL || 60 * 60 * 4), // 1 Hour
diff --git a/src/node/addon-jackett/src/lib/sort.js b/src/addon-jackett/src/lib/sort.js
similarity index 100%
rename from src/node/addon-jackett/src/lib/sort.js
rename to src/addon-jackett/src/lib/sort.js
diff --git a/src/node/addon-jackett/src/lib/streamInfo.js b/src/addon-jackett/src/lib/streamInfo.js
similarity index 100%
rename from src/node/addon-jackett/src/lib/streamInfo.js
rename to src/addon-jackett/src/lib/streamInfo.js
diff --git a/src/node/addon-jackett/src/lib/types.js b/src/addon-jackett/src/lib/types.js
similarity index 100%
rename from src/node/addon-jackett/src/lib/types.js
rename to src/addon-jackett/src/lib/types.js
diff --git a/src/node/addon-jackett/src/moch/alldebrid.js b/src/addon-jackett/src/moch/alldebrid.js
similarity index 100%
rename from src/node/addon-jackett/src/moch/alldebrid.js
rename to src/addon-jackett/src/moch/alldebrid.js
diff --git a/src/node/addon-jackett/src/moch/debridlink.js b/src/addon-jackett/src/moch/debridlink.js
similarity index 100%
rename from src/node/addon-jackett/src/moch/debridlink.js
rename to src/addon-jackett/src/moch/debridlink.js
diff --git a/src/node/addon-jackett/src/moch/moch.js b/src/addon-jackett/src/moch/moch.js
similarity index 100%
rename from src/node/addon-jackett/src/moch/moch.js
rename to src/addon-jackett/src/moch/moch.js
diff --git a/src/node/addon-jackett/src/moch/mochHelper.js b/src/addon-jackett/src/moch/mochHelper.js
similarity index 100%
rename from src/node/addon-jackett/src/moch/mochHelper.js
rename to src/addon-jackett/src/moch/mochHelper.js
diff --git a/src/node/addon-jackett/src/moch/offcloud.js b/src/addon-jackett/src/moch/offcloud.js
similarity index 100%
rename from src/node/addon-jackett/src/moch/offcloud.js
rename to src/addon-jackett/src/moch/offcloud.js
diff --git a/src/node/addon-jackett/src/moch/options.js b/src/addon-jackett/src/moch/options.js
similarity index 100%
rename from src/node/addon-jackett/src/moch/options.js
rename to src/addon-jackett/src/moch/options.js
diff --git a/src/node/addon-jackett/src/moch/premiumize.js b/src/addon-jackett/src/moch/premiumize.js
similarity index 100%
rename from src/node/addon-jackett/src/moch/premiumize.js
rename to src/addon-jackett/src/moch/premiumize.js
diff --git a/src/node/addon-jackett/src/moch/putio.js b/src/addon-jackett/src/moch/putio.js
similarity index 100%
rename from src/node/addon-jackett/src/moch/putio.js
rename to src/addon-jackett/src/moch/putio.js
diff --git a/src/node/addon-jackett/src/moch/realdebrid.js b/src/addon-jackett/src/moch/realdebrid.js
similarity index 100%
rename from src/node/addon-jackett/src/moch/realdebrid.js
rename to src/addon-jackett/src/moch/realdebrid.js
diff --git a/src/node/addon-jackett/src/moch/static.js b/src/addon-jackett/src/moch/static.js
similarity index 100%
rename from src/node/addon-jackett/src/moch/static.js
rename to src/addon-jackett/src/moch/static.js
diff --git a/src/node/addon-jackett/src/serverless.js b/src/addon-jackett/src/serverless.js
similarity index 100%
rename from src/node/addon-jackett/src/serverless.js
rename to src/addon-jackett/src/serverless.js
diff --git a/src/node/addon-jackett/static/videos/download_failed_v2.mp4 b/src/addon-jackett/static/videos/download_failed_v2.mp4
similarity index 100%
rename from src/node/addon-jackett/static/videos/download_failed_v2.mp4
rename to src/addon-jackett/static/videos/download_failed_v2.mp4
diff --git a/src/node/addon-jackett/static/videos/downloading_v2.mp4 b/src/addon-jackett/static/videos/downloading_v2.mp4
similarity index 100%
rename from src/node/addon-jackett/static/videos/downloading_v2.mp4
rename to src/addon-jackett/static/videos/downloading_v2.mp4
diff --git a/src/node/addon-jackett/static/videos/failed_access_v2.mp4 b/src/addon-jackett/static/videos/failed_access_v2.mp4
similarity index 100%
rename from src/node/addon-jackett/static/videos/failed_access_v2.mp4
rename to src/addon-jackett/static/videos/failed_access_v2.mp4
diff --git a/src/node/addon-jackett/static/videos/failed_infringement_v2.mp4 b/src/addon-jackett/static/videos/failed_infringement_v2.mp4
similarity index 100%
rename from src/node/addon-jackett/static/videos/failed_infringement_v2.mp4
rename to src/addon-jackett/static/videos/failed_infringement_v2.mp4
diff --git a/src/node/addon-jackett/static/videos/failed_opening_v2.mp4 b/src/addon-jackett/static/videos/failed_opening_v2.mp4
similarity index 100%
rename from src/node/addon-jackett/static/videos/failed_opening_v2.mp4
rename to src/addon-jackett/static/videos/failed_opening_v2.mp4
diff --git a/src/node/addon-jackett/static/videos/failed_rar_v2.mp4 b/src/addon-jackett/static/videos/failed_rar_v2.mp4
similarity index 100%
rename from src/node/addon-jackett/static/videos/failed_rar_v2.mp4
rename to src/addon-jackett/static/videos/failed_rar_v2.mp4
diff --git a/src/node/addon-jackett/static/videos/failed_unexpected_v2.mp4 b/src/addon-jackett/static/videos/failed_unexpected_v2.mp4
similarity index 100%
rename from src/node/addon-jackett/static/videos/failed_unexpected_v2.mp4
rename to src/addon-jackett/static/videos/failed_unexpected_v2.mp4
diff --git a/src/node/addon/.dockerignore b/src/addon/.dockerignore
similarity index 100%
rename from src/node/addon/.dockerignore
rename to src/addon/.dockerignore
diff --git a/src/node/addon/.eslintignore b/src/addon/.eslintignore
similarity index 100%
rename from src/node/addon/.eslintignore
rename to src/addon/.eslintignore
diff --git a/src/node/addon/.eslintrc.cjs b/src/addon/.eslintrc.cjs
similarity index 100%
rename from src/node/addon/.eslintrc.cjs
rename to src/addon/.eslintrc.cjs
diff --git a/src/node/addon/Dockerfile b/src/addon/Dockerfile
similarity index 100%
rename from src/node/addon/Dockerfile
rename to src/addon/Dockerfile
diff --git a/src/node/addon/ecosystem.config.cjs b/src/addon/ecosystem.config.cjs
similarity index 100%
rename from src/node/addon/ecosystem.config.cjs
rename to src/addon/ecosystem.config.cjs
diff --git a/src/node/addon/esbuild.js b/src/addon/esbuild.js
similarity index 100%
rename from src/node/addon/esbuild.js
rename to src/addon/esbuild.js
diff --git a/src/node/addon/jsconfig.json b/src/addon/jsconfig.json
similarity index 100%
rename from src/node/addon/jsconfig.json
rename to src/addon/jsconfig.json
diff --git a/src/node/addon/package-lock.json b/src/addon/package-lock.json
similarity index 85%
rename from src/node/addon/package-lock.json
rename to src/addon/package-lock.json
index 32cb4a5..50b5798 100644
--- a/src/node/addon/package-lock.json
+++ b/src/addon/package-lock.json
@@ -9,11 +9,14 @@
"version": "0.0.1",
"dependencies": {
"@putdotio/api-client": "^8.42.0",
+ "@redis/client": "^1.5.14",
+ "@redis/json": "^1.0.6",
+ "@redis/search": "^1.1.6",
"all-debrid-api": "^1.1.0",
"axios": "^1.6.1",
"bottleneck": "^2.19.5",
"cache-manager": "^3.4.4",
- "cache-manager-mongodb": "^0.3.0",
+ "cache-manager-redis-store": "^2.0.0",
"cors": "^2.8.5",
"debrid-link-api": "^1.0.1",
"express-rate-limit": "^6.7.0",
@@ -42,11 +45,8 @@
"esbuild": "^0.19.12",
"esbuild-plugin-copy": "^2.1.1",
"eslint": "^8.56.0",
- "eslint-config-prettier": "^9.1.0",
"eslint-plugin-import": "^2.29.1",
"eslint-plugin-import-helpers": "^1.3.1",
- "eslint-plugin-prettier": "^5.1.3",
- "lint-staged": "^15.2.0",
"tsx": "^4.7.0"
}
},
@@ -597,18 +597,6 @@
"node": ">= 8"
}
},
- "node_modules/@pkgr/core": {
- "version": "0.1.1",
- "resolved": "https://registry.npmjs.org/@pkgr/core/-/core-0.1.1.tgz",
- "integrity": "sha512-cq8o4cWH0ibXh9VGi5P20Tu9XF/0fFXl9EUinr9QfTM7a7p0oTA4iJRCQWppXR1Pg8dSM0UCItCkPwsk9qWWYA==",
- "dev": true,
- "engines": {
- "node": "^12.20.0 || ^14.18.0 || >=16.0.0"
- },
- "funding": {
- "url": "https://opencollective.com/unts"
- }
- },
"node_modules/@putdotio/api-client": {
"version": "8.42.0",
"resolved": "https://registry.npmjs.org/@putdotio/api-client/-/api-client-8.42.0.tgz",
@@ -632,6 +620,35 @@
"follow-redirects": "^1.14.0"
}
},
+ "node_modules/@redis/client": {
+ "version": "1.5.14",
+ "resolved": "https://registry.npmjs.org/@redis/client/-/client-1.5.14.tgz",
+ "integrity": "sha512-YGn0GqsRBFUQxklhY7v562VMOP0DcmlrHHs3IV1mFE3cbxe31IITUkqhBcIhVSI/2JqtWAJXg5mjV4aU+zD0HA==",
+ "dependencies": {
+ "cluster-key-slot": "1.1.2",
+ "generic-pool": "3.9.0",
+ "yallist": "4.0.0"
+ },
+ "engines": {
+ "node": ">=14"
+ }
+ },
+ "node_modules/@redis/json": {
+ "version": "1.0.6",
+ "resolved": "https://registry.npmjs.org/@redis/json/-/json-1.0.6.tgz",
+ "integrity": "sha512-rcZO3bfQbm2zPRpqo82XbW8zg4G/w4W3tI7X8Mqleq9goQjAGLL7q/1n1ZX4dXEAmORVZ4s1+uKLaUOg7LrUhw==",
+ "peerDependencies": {
+ "@redis/client": "^1.0.0"
+ }
+ },
+ "node_modules/@redis/search": {
+ "version": "1.1.6",
+ "resolved": "https://registry.npmjs.org/@redis/search/-/search-1.1.6.tgz",
+ "integrity": "sha512-mZXCxbTYKBQ3M2lZnEddwEAks0Kc7nauire8q20oA0oA/LoA+E/b5Y5KZn232ztPb1FkIGqo12vh3Lf+Vw5iTw==",
+ "peerDependencies": {
+ "@redis/client": "^1.0.0"
+ }
+ },
"node_modules/@types/debug": {
"version": "4.1.7",
"resolved": "https://registry.npmjs.org/@types/debug/-/debug-4.1.7.tgz",
@@ -1023,20 +1040,6 @@
"resolved": "https://registry.npmjs.org/bintrees/-/bintrees-1.0.2.tgz",
"integrity": "sha512-VOMgTMwjAaUG580SXn3LacVgjurrbMme7ZZNYGSSV7mmtY6QQRh0Eg3pwIcntQ77DErK1L0NxkbetjcoXzVwKw=="
},
- "node_modules/bl": {
- "version": "2.2.1",
- "resolved": "https://registry.npmjs.org/bl/-/bl-2.2.1.tgz",
- "integrity": "sha512-6Pesp1w0DEX1N550i/uGV/TqucVL4AM/pgThFSN/Qq9si1/DF9aIHs1BxD8V/QU0HoeHO6cQRTAuYnLPKq1e4g==",
- "dependencies": {
- "readable-stream": "^2.3.5",
- "safe-buffer": "^5.1.1"
- }
- },
- "node_modules/bluebird": {
- "version": "3.7.2",
- "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz",
- "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg=="
- },
"node_modules/body-parser": {
"version": "1.20.1",
"resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz",
@@ -1087,14 +1090,6 @@
"node": ">=8"
}
},
- "node_modules/bson": {
- "version": "1.1.6",
- "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.6.tgz",
- "integrity": "sha512-EvVNVeGo4tHxwi8L6bPj3y3itEvStdwvvlojVxxbyYfoaxJ6keLgrTuKdyfEAszFK+H3olzBuafE0yoh0D1gdg==",
- "engines": {
- "node": ">=0.6.19"
- }
- },
"node_modules/buffer-writer": {
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/buffer-writer/-/buffer-writer-2.0.0.tgz",
@@ -1121,46 +1116,35 @@
"lru-cache": "6.0.0"
}
},
- "node_modules/cache-manager-mongodb": {
- "version": "0.3.0",
- "resolved": "https://registry.npmjs.org/cache-manager-mongodb/-/cache-manager-mongodb-0.3.0.tgz",
- "integrity": "sha512-r+piWvu8XD8ceBWflZBEQZKemksoaL1V5zSHWyviVTXiGBSVQAf18b4S1v5UwGZMJnrMk8YNFgpBlugF0nuhvg==",
+ "node_modules/cache-manager-redis-store": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/cache-manager-redis-store/-/cache-manager-redis-store-2.0.0.tgz",
+ "integrity": "sha512-bWLWlUg6nCYHiJLCCYxY2MgvwvKnvlWwrbuynrzpjEIhfArD2GC9LtutIHFEPeyGVQN6C+WEw+P3r+BFBwhswg==",
"dependencies": {
- "bluebird": "^3.5.3",
- "cache-manager": "^2.9.0",
- "lodash": "^4.17.15",
- "mongodb": "^3.6.3"
+ "redis": "^3.0.2"
+ },
+ "engines": {
+ "node": ">= 8.3"
}
},
- "node_modules/cache-manager-mongodb/node_modules/async": {
- "version": "1.5.2",
- "resolved": "https://registry.npmjs.org/async/-/async-1.5.2.tgz",
- "integrity": "sha512-nSVgobk4rv61R9PUSDtYt7mPVB2olxNR5RWJcAsH676/ef11bUZwvu7+RGYrYauVdDPcO519v68wRhXQtxsV9w=="
- },
- "node_modules/cache-manager-mongodb/node_modules/cache-manager": {
- "version": "2.11.1",
- "resolved": "https://registry.npmjs.org/cache-manager/-/cache-manager-2.11.1.tgz",
- "integrity": "sha512-XhUuc9eYwkzpK89iNewFwtvcDYMUsvtwzHeyEOPJna/WsVsXcrzsA1ft2M0QqPNunEzLhNCYPo05tEfG+YuNow==",
+ "node_modules/cache-manager-redis-store/node_modules/redis": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/redis/-/redis-3.1.2.tgz",
+ "integrity": "sha512-grn5KoZLr/qrRQVwoSkmzdbw6pwF+/rwODtrOr6vuBRiR/f3rjSTGupbF90Zpqm2oenix8Do6RV7pYEkGwlKkw==",
"dependencies": {
- "async": "1.5.2",
- "lodash.clonedeep": "4.5.0",
- "lru-cache": "4.0.0"
+ "denque": "^1.5.0",
+ "redis-commands": "^1.7.0",
+ "redis-errors": "^1.2.0",
+ "redis-parser": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/node-redis"
}
},
- "node_modules/cache-manager-mongodb/node_modules/lru-cache": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.0.0.tgz",
- "integrity": "sha512-WKhDkjlLwzE8jAQdQlsxLUQTPXLCKX/4cJk6s5AlRtJkDBk0IKH5O51bVDH61K9N4bhbbyvLM6EiOuE8ovApPA==",
- "dependencies": {
- "pseudomap": "^1.0.1",
- "yallist": "^2.0.0"
- }
- },
- "node_modules/cache-manager-mongodb/node_modules/yallist": {
- "version": "2.1.2",
- "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz",
- "integrity": "sha512-ncTzHV7NvsQZkYe1DW7cbDLm0YpzHmZF5r/iyP3ZnQtMiJ+pjzisCiMNI+Sj+xQF5pXhSHxSB3uDbsBTzY/c2A=="
- },
"node_modules/call-bind": {
"version": "1.0.5",
"resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.5.tgz",
@@ -1244,71 +1228,19 @@
"node": ">=4"
}
},
- "node_modules/cli-truncate": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-4.0.0.tgz",
- "integrity": "sha512-nPdaFdQ0h/GEigbPClz11D0v/ZJEwxmeVZGeMo3Z5StPtUTkA9o1lD6QwoirYiSDzbcwn2XcjwmCp68W1IS4TA==",
- "dev": true,
- "dependencies": {
- "slice-ansi": "^5.0.0",
- "string-width": "^7.0.0"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/cli-truncate/node_modules/ansi-regex": {
- "version": "6.0.1",
- "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz",
- "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/ansi-regex?sponsor=1"
- }
- },
- "node_modules/cli-truncate/node_modules/string-width": {
- "version": "7.1.0",
- "resolved": "https://registry.npmjs.org/string-width/-/string-width-7.1.0.tgz",
- "integrity": "sha512-SEIJCWiX7Kg4c129n48aDRwLbFb2LJmXXFrWBG4NGaRtMQ3myKPKbwrD1BKqQn74oCoNMBVrfDEr5M9YxCsrkw==",
- "dev": true,
- "dependencies": {
- "emoji-regex": "^10.3.0",
- "get-east-asian-width": "^1.0.0",
- "strip-ansi": "^7.1.0"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/cli-truncate/node_modules/strip-ansi": {
- "version": "7.1.0",
- "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz",
- "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==",
- "dev": true,
- "dependencies": {
- "ansi-regex": "^6.0.1"
- },
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/strip-ansi?sponsor=1"
- }
- },
"node_modules/cli-width": {
"version": "2.2.0",
"resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz",
"integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk="
},
+ "node_modules/cluster-key-slot": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/cluster-key-slot/-/cluster-key-slot-1.1.2.tgz",
+ "integrity": "sha512-RMr0FhtfXemyinomL4hrWcYJxmX6deFdCxpJzhDttxgO1+bcCnkk+9drydLVDmAMG7NE6aN/fl4F7ucU/90gAA==",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
"node_modules/color-convert": {
"version": "1.9.3",
"resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
@@ -1322,12 +1254,6 @@
"resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
"integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU="
},
- "node_modules/colorette": {
- "version": "2.0.20",
- "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.20.tgz",
- "integrity": "sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w==",
- "dev": true
- },
"node_modules/combined-stream": {
"version": "1.0.8",
"resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz",
@@ -1339,15 +1265,6 @@
"node": ">= 0.8"
}
},
- "node_modules/commander": {
- "version": "11.1.0",
- "resolved": "https://registry.npmjs.org/commander/-/commander-11.1.0.tgz",
- "integrity": "sha512-yPVavfyCcRhmorC7rWlkHn15b4wDVgVmBA7kV4QVBsF7kv/9TKJAbAXVTxvTnwP8HHKjRCJDClKbciiYS7p0DQ==",
- "dev": true,
- "engines": {
- "node": ">=16"
- }
- },
"node_modules/concat-map": {
"version": "0.0.1",
"resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
@@ -1582,12 +1499,6 @@
"resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
"integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow=="
},
- "node_modules/emoji-regex": {
- "version": "10.3.0",
- "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.3.0.tgz",
- "integrity": "sha512-QpLs9D9v9kArv4lfDEgg1X/gN5XLnf/A6l9cs8SPZLRZR3ZkY9+kwIQTxm+fsSej5UMYGE8fdoaZVIBlqG0XTw==",
- "dev": true
- },
"node_modules/encodeurl": {
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
@@ -1932,18 +1843,6 @@
"url": "https://opencollective.com/eslint"
}
},
- "node_modules/eslint-config-prettier": {
- "version": "9.1.0",
- "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-9.1.0.tgz",
- "integrity": "sha512-NSWl5BFQWEPi1j4TjVNItzYV7dZXZ+wP6I6ZhrBGpChQhZRUaElihE9uRRkcbRnNb76UMKDF3r+WTmNcGPKsqw==",
- "dev": true,
- "bin": {
- "eslint-config-prettier": "bin/cli.js"
- },
- "peerDependencies": {
- "eslint": ">=7.0.0"
- }
- },
"node_modules/eslint-import-resolver-node": {
"version": "0.3.9",
"resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.9.tgz",
@@ -2078,36 +1977,6 @@
"semver": "bin/semver.js"
}
},
- "node_modules/eslint-plugin-prettier": {
- "version": "5.1.3",
- "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-5.1.3.tgz",
- "integrity": "sha512-C9GCVAs4Eq7ZC/XFQHITLiHJxQngdtraXaM+LoUFoFp/lHNl2Zn8f3WQbe9HvTBBQ9YnKFB0/2Ajdqwo5D1EAw==",
- "dev": true,
- "dependencies": {
- "prettier-linter-helpers": "^1.0.0",
- "synckit": "^0.8.6"
- },
- "engines": {
- "node": "^14.18.0 || >=16.0.0"
- },
- "funding": {
- "url": "https://opencollective.com/eslint-plugin-prettier"
- },
- "peerDependencies": {
- "@types/eslint": ">=8.0.0",
- "eslint": ">=8.0.0",
- "eslint-config-prettier": "*",
- "prettier": ">=3.0.0"
- },
- "peerDependenciesMeta": {
- "@types/eslint": {
- "optional": true
- },
- "eslint-config-prettier": {
- "optional": true
- }
- }
- },
"node_modules/eslint-scope": {
"version": "7.2.2",
"resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz",
@@ -2350,74 +2219,6 @@
"es5-ext": "~0.10.14"
}
},
- "node_modules/eventemitter3": {
- "version": "5.0.1",
- "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-5.0.1.tgz",
- "integrity": "sha512-GWkBvjiSZK87ELrYOSESUYeVIc9mvLLf/nXalMOS5dYrgZq9o5OVkbZAVM06CVxYsCwH9BDZFPlQTlPA1j4ahA==",
- "dev": true
- },
- "node_modules/execa": {
- "version": "8.0.1",
- "resolved": "https://registry.npmjs.org/execa/-/execa-8.0.1.tgz",
- "integrity": "sha512-VyhnebXciFV2DESc+p6B+y0LjSm0krU4OgJN44qFAhBY0TJ+1V61tYD2+wHusZ6F9n5K+vl8k0sTy7PEfV4qpg==",
- "dev": true,
- "dependencies": {
- "cross-spawn": "^7.0.3",
- "get-stream": "^8.0.1",
- "human-signals": "^5.0.0",
- "is-stream": "^3.0.0",
- "merge-stream": "^2.0.0",
- "npm-run-path": "^5.1.0",
- "onetime": "^6.0.0",
- "signal-exit": "^4.1.0",
- "strip-final-newline": "^3.0.0"
- },
- "engines": {
- "node": ">=16.17"
- },
- "funding": {
- "url": "https://github.com/sindresorhus/execa?sponsor=1"
- }
- },
- "node_modules/execa/node_modules/mimic-fn": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-4.0.0.tgz",
- "integrity": "sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/execa/node_modules/onetime": {
- "version": "6.0.0",
- "resolved": "https://registry.npmjs.org/onetime/-/onetime-6.0.0.tgz",
- "integrity": "sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ==",
- "dev": true,
- "dependencies": {
- "mimic-fn": "^4.0.0"
- },
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/execa/node_modules/signal-exit": {
- "version": "4.1.0",
- "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz",
- "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==",
- "dev": true,
- "engines": {
- "node": ">=14"
- },
- "funding": {
- "url": "https://github.com/sponsors/isaacs"
- }
- },
"node_modules/express": {
"version": "4.18.2",
"resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz",
@@ -2514,12 +2315,6 @@
"resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
"integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q=="
},
- "node_modules/fast-diff": {
- "version": "1.3.0",
- "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.3.0.tgz",
- "integrity": "sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw==",
- "dev": true
- },
"node_modules/fast-glob": {
"version": "3.3.2",
"resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz",
@@ -2778,16 +2573,12 @@
"url": "https://github.com/sponsors/ljharb"
}
},
- "node_modules/get-east-asian-width": {
- "version": "1.2.0",
- "resolved": "https://registry.npmjs.org/get-east-asian-width/-/get-east-asian-width-1.2.0.tgz",
- "integrity": "sha512-2nk+7SIVb14QrgXFHcm84tD4bKQz0RxPuMT8Ag5KPOq7J5fEmAg0UbXdTOSHqNuHSU28k55qnceesxXRZGzKWA==",
- "dev": true,
+ "node_modules/generic-pool": {
+ "version": "3.9.0",
+ "resolved": "https://registry.npmjs.org/generic-pool/-/generic-pool-3.9.0.tgz",
+ "integrity": "sha512-hymDOu5B53XvN4QT9dBmZxPX4CWhBPPLguTZ9MMFeFa/Kg0xWVfylOVNlJji/E7yTZWFd/q9GO5TxDLq156D7g==",
"engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
+ "node": ">= 4"
}
},
"node_modules/get-intrinsic": {
@@ -2804,18 +2595,6 @@
"url": "https://github.com/sponsors/ljharb"
}
},
- "node_modules/get-stream": {
- "version": "8.0.1",
- "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-8.0.1.tgz",
- "integrity": "sha512-VaUJspBffn/LMCJVoMvSAdmscJyS1auj5Zulnn5UoYcY531UWmdwhRWkcGKnGU93m5HSXP9LP2usOryrBtQowA==",
- "dev": true,
- "engines": {
- "node": ">=16"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
"node_modules/get-symbol-description": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz",
@@ -3083,15 +2862,6 @@
"npm": ">=1.3.7"
}
},
- "node_modules/human-signals": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-5.0.0.tgz",
- "integrity": "sha512-AXcZb6vzzrFAUE61HnN4mpLqd/cSIwNQjtNWR0euPm6y0iqx3G4gOXaIDdtdDwZmhwe82LA6+zinmW4UBWVePQ==",
- "dev": true,
- "engines": {
- "node": ">=16.17.0"
- }
- },
"node_modules/iconv-lite": {
"version": "0.4.24",
"resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
@@ -3410,18 +3180,6 @@
"url": "https://github.com/sponsors/ljharb"
}
},
- "node_modules/is-stream": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-3.0.0.tgz",
- "integrity": "sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA==",
- "dev": true,
- "engines": {
- "node": "^12.20.0 || ^14.13.1 || >=16.0.0"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
"node_modules/is-string": {
"version": "1.0.7",
"resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz",
@@ -3492,11 +3250,6 @@
"node": ">=4"
}
},
- "node_modules/isarray": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
- "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ=="
- },
"node_modules/isexe": {
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
@@ -3628,94 +3381,6 @@
"node": ">= 0.8.0"
}
},
- "node_modules/lilconfig": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-3.0.0.tgz",
- "integrity": "sha512-K2U4W2Ff5ibV7j7ydLr+zLAkIg5JJ4lPn1Ltsdt+Tz/IjQ8buJ55pZAxoP34lqIiwtF9iAvtLv3JGv7CAyAg+g==",
- "dev": true,
- "engines": {
- "node": ">=14"
- }
- },
- "node_modules/lint-staged": {
- "version": "15.2.1",
- "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-15.2.1.tgz",
- "integrity": "sha512-dhwAPnM85VdshybV9FWI/9ghTvMLoQLEXgVMx+ua2DN7mdfzd/tRfoU2yhMcBac0RHkofoxdnnJUokr8s4zKmQ==",
- "dev": true,
- "dependencies": {
- "chalk": "5.3.0",
- "commander": "11.1.0",
- "debug": "4.3.4",
- "execa": "8.0.1",
- "lilconfig": "3.0.0",
- "listr2": "8.0.1",
- "micromatch": "4.0.5",
- "pidtree": "0.6.0",
- "string-argv": "0.3.2",
- "yaml": "2.3.4"
- },
- "bin": {
- "lint-staged": "bin/lint-staged.js"
- },
- "engines": {
- "node": ">=18.12.0"
- },
- "funding": {
- "url": "https://opencollective.com/lint-staged"
- }
- },
- "node_modules/lint-staged/node_modules/chalk": {
- "version": "5.3.0",
- "resolved": "https://registry.npmjs.org/chalk/-/chalk-5.3.0.tgz",
- "integrity": "sha512-dLitG79d+GV1Nb/VYcCDFivJeK1hiukt9QjRNVOsUtTy1rR1YJsmpGGTZ3qJos+uw7WmWF4wUwBd9jxjocFC2w==",
- "dev": true,
- "engines": {
- "node": "^12.17.0 || ^14.13 || >=16.0.0"
- },
- "funding": {
- "url": "https://github.com/chalk/chalk?sponsor=1"
- }
- },
- "node_modules/lint-staged/node_modules/debug": {
- "version": "4.3.4",
- "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz",
- "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==",
- "dev": true,
- "dependencies": {
- "ms": "2.1.2"
- },
- "engines": {
- "node": ">=6.0"
- },
- "peerDependenciesMeta": {
- "supports-color": {
- "optional": true
- }
- }
- },
- "node_modules/lint-staged/node_modules/ms": {
- "version": "2.1.2",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
- "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==",
- "dev": true
- },
- "node_modules/listr2": {
- "version": "8.0.1",
- "resolved": "https://registry.npmjs.org/listr2/-/listr2-8.0.1.tgz",
- "integrity": "sha512-ovJXBXkKGfq+CwmKTjluEqFi3p4h8xvkxGQQAQan22YCgef4KZ1mKGjzfGh6PL6AW5Csw0QiQPNuQyH+6Xk3hA==",
- "dev": true,
- "dependencies": {
- "cli-truncate": "^4.0.0",
- "colorette": "^2.0.20",
- "eventemitter3": "^5.0.1",
- "log-update": "^6.0.0",
- "rfdc": "^1.3.0",
- "wrap-ansi": "^9.0.0"
- },
- "engines": {
- "node": ">=18.0.0"
- }
- },
"node_modules/locate-path": {
"version": "6.0.0",
"resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz",
@@ -3747,177 +3412,6 @@
"integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==",
"dev": true
},
- "node_modules/log-update": {
- "version": "6.0.0",
- "resolved": "https://registry.npmjs.org/log-update/-/log-update-6.0.0.tgz",
- "integrity": "sha512-niTvB4gqvtof056rRIrTZvjNYE4rCUzO6X/X+kYjd7WFxXeJ0NwEFnRxX6ehkvv3jTwrXnNdtAak5XYZuIyPFw==",
- "dev": true,
- "dependencies": {
- "ansi-escapes": "^6.2.0",
- "cli-cursor": "^4.0.0",
- "slice-ansi": "^7.0.0",
- "strip-ansi": "^7.1.0",
- "wrap-ansi": "^9.0.0"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/log-update/node_modules/ansi-escapes": {
- "version": "6.2.0",
- "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-6.2.0.tgz",
- "integrity": "sha512-kzRaCqXnpzWs+3z5ABPQiVke+iq0KXkHo8xiWV4RPTi5Yli0l97BEQuhXV1s7+aSU/fu1kUuxgS4MsQ0fRuygw==",
- "dev": true,
- "dependencies": {
- "type-fest": "^3.0.0"
- },
- "engines": {
- "node": ">=14.16"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/log-update/node_modules/ansi-regex": {
- "version": "6.0.1",
- "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz",
- "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/ansi-regex?sponsor=1"
- }
- },
- "node_modules/log-update/node_modules/ansi-styles": {
- "version": "6.2.1",
- "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz",
- "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/ansi-styles?sponsor=1"
- }
- },
- "node_modules/log-update/node_modules/cli-cursor": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-4.0.0.tgz",
- "integrity": "sha512-VGtlMu3x/4DOtIUwEkRezxUZ2lBacNJCHash0N0WeZDBS+7Ux1dm3XWAgWYxLJFMMdOeXMHXorshEFhbMSGelg==",
- "dev": true,
- "dependencies": {
- "restore-cursor": "^4.0.0"
- },
- "engines": {
- "node": "^12.20.0 || ^14.13.1 || >=16.0.0"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/log-update/node_modules/is-fullwidth-code-point": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-5.0.0.tgz",
- "integrity": "sha512-OVa3u9kkBbw7b8Xw5F9P+D/T9X+Z4+JruYVNapTjPYZYUznQ5YfWeFkOj606XYYW8yugTfC8Pj0hYqvi4ryAhA==",
- "dev": true,
- "dependencies": {
- "get-east-asian-width": "^1.0.0"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/log-update/node_modules/mimic-fn": {
- "version": "2.1.0",
- "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz",
- "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==",
- "dev": true,
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/log-update/node_modules/onetime": {
- "version": "5.1.2",
- "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz",
- "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==",
- "dev": true,
- "dependencies": {
- "mimic-fn": "^2.1.0"
- },
- "engines": {
- "node": ">=6"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/log-update/node_modules/restore-cursor": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-4.0.0.tgz",
- "integrity": "sha512-I9fPXU9geO9bHOt9pHHOhOkYerIMsmVaWB0rA2AI9ERh/+x/i7MV5HKBNrg+ljO5eoPVgCcnFuRjJ9uH6I/3eg==",
- "dev": true,
- "dependencies": {
- "onetime": "^5.1.0",
- "signal-exit": "^3.0.2"
- },
- "engines": {
- "node": "^12.20.0 || ^14.13.1 || >=16.0.0"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/log-update/node_modules/slice-ansi": {
- "version": "7.1.0",
- "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-7.1.0.tgz",
- "integrity": "sha512-bSiSngZ/jWeX93BqeIAbImyTbEihizcwNjFoRUIY/T1wWQsfsm2Vw1agPKylXvQTU7iASGdHhyqRlqQzfz+Htg==",
- "dev": true,
- "dependencies": {
- "ansi-styles": "^6.2.1",
- "is-fullwidth-code-point": "^5.0.0"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/chalk/slice-ansi?sponsor=1"
- }
- },
- "node_modules/log-update/node_modules/strip-ansi": {
- "version": "7.1.0",
- "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz",
- "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==",
- "dev": true,
- "dependencies": {
- "ansi-regex": "^6.0.1"
- },
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/strip-ansi?sponsor=1"
- }
- },
- "node_modules/log-update/node_modules/type-fest": {
- "version": "3.13.1",
- "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-3.13.1.tgz",
- "integrity": "sha512-tLq3bSNx+xSpwvAJnzrK0Ep5CLNWjvFTOp71URMaAEWBfRb9nnJiBoUe0tF8bI4ZFO3omgBR6NvnbzVUT3Ly4g==",
- "dev": true,
- "engines": {
- "node": ">=14.16"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
"node_modules/lru-cache": {
"version": "6.0.0",
"resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
@@ -3960,23 +3454,11 @@
"node": ">= 0.6"
}
},
- "node_modules/memory-pager": {
- "version": "1.5.0",
- "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz",
- "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==",
- "optional": true
- },
"node_modules/merge-descriptors": {
"version": "1.0.1",
"resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
"integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E="
},
- "node_modules/merge-stream": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz",
- "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==",
- "dev": true
- },
"node_modules/merge2": {
"version": "1.4.1",
"resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz",
@@ -4092,44 +3574,6 @@
"node": "*"
}
},
- "node_modules/mongodb": {
- "version": "3.7.3",
- "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.7.3.tgz",
- "integrity": "sha512-Psm+g3/wHXhjBEktkxXsFMZvd3nemI0r3IPsE0bU+4//PnvNWKkzhZcEsbPcYiWqe8XqXJJEg4Tgtr7Raw67Yw==",
- "dependencies": {
- "bl": "^2.2.1",
- "bson": "^1.1.4",
- "denque": "^1.4.1",
- "optional-require": "^1.1.8",
- "safe-buffer": "^5.1.2"
- },
- "engines": {
- "node": ">=4"
- },
- "optionalDependencies": {
- "saslprep": "^1.0.0"
- },
- "peerDependenciesMeta": {
- "aws4": {
- "optional": true
- },
- "bson-ext": {
- "optional": true
- },
- "kerberos": {
- "optional": true
- },
- "mongodb-client-encryption": {
- "optional": true
- },
- "mongodb-extjson": {
- "optional": true
- },
- "snappy": {
- "optional": true
- }
- }
- },
"node_modules/ms": {
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
@@ -4218,33 +3662,6 @@
"node": ">=0.10.0"
}
},
- "node_modules/npm-run-path": {
- "version": "5.2.0",
- "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-5.2.0.tgz",
- "integrity": "sha512-W4/tgAXFqFA0iL7fk0+uQ3g7wkL8xJmx3XdK0VGb4cHW//eZTtKGvFBBoRKVTpY7n6ze4NL9ly7rgXcHufqXKg==",
- "dev": true,
- "dependencies": {
- "path-key": "^4.0.0"
- },
- "engines": {
- "node": "^12.20.0 || ^14.13.1 || >=16.0.0"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/npm-run-path/node_modules/path-key": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/path-key/-/path-key-4.0.0.tgz",
- "integrity": "sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
"node_modules/oauth-sign": {
"version": "0.9.0",
"resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz",
@@ -4392,17 +3809,6 @@
"node": ">=4"
}
},
- "node_modules/optional-require": {
- "version": "1.1.8",
- "resolved": "https://registry.npmjs.org/optional-require/-/optional-require-1.1.8.tgz",
- "integrity": "sha512-jq83qaUb0wNg9Krv1c5OQ+58EK+vHde6aBPzLvPPqJm89UQWsvSuFy9X/OSNJnFeSOKo7btE0n8Nl2+nE+z5nA==",
- "dependencies": {
- "require-at": "^1.0.6"
- },
- "engines": {
- "node": ">=4"
- }
- },
"node_modules/optionator": {
"version": "0.9.3",
"resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz",
@@ -4653,18 +4059,6 @@
"url": "https://github.com/sponsors/jonschlinkert"
}
},
- "node_modules/pidtree": {
- "version": "0.6.0",
- "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.6.0.tgz",
- "integrity": "sha512-eG2dWTVw5bzqGRztnHExczNxt5VGsE6OwTeCG3fdUf9KBsZzO3R5OIIIzWR+iZA0NtZ+RDVdaoE2dK1cn6jH4g==",
- "dev": true,
- "bin": {
- "pidtree": "bin/pidtree.js"
- },
- "engines": {
- "node": ">=0.10"
- }
- },
"node_modules/postgres-array": {
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/postgres-array/-/postgres-array-2.0.0.tgz",
@@ -4717,39 +4111,6 @@
"request": "^2.83.0"
}
},
- "node_modules/prettier": {
- "version": "3.2.4",
- "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.2.4.tgz",
- "integrity": "sha512-FWu1oLHKCrtpO1ypU6J0SbK2d9Ckwysq6bHj/uaCP26DxrPpppCLQRGVuqAxSTvhF00AcvDRyYrLNW7ocBhFFQ==",
- "dev": true,
- "peer": true,
- "bin": {
- "prettier": "bin/prettier.cjs"
- },
- "engines": {
- "node": ">=14"
- },
- "funding": {
- "url": "https://github.com/prettier/prettier?sponsor=1"
- }
- },
- "node_modules/prettier-linter-helpers": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz",
- "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==",
- "dev": true,
- "dependencies": {
- "fast-diff": "^1.1.2"
- },
- "engines": {
- "node": ">=6.0.0"
- }
- },
- "node_modules/process-nextick-args": {
- "version": "2.0.1",
- "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz",
- "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag=="
- },
"node_modules/prom-client": {
"version": "12.0.0",
"resolved": "https://registry.npmjs.org/prom-client/-/prom-client-12.0.0.tgz",
@@ -4778,11 +4139,6 @@
"resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz",
"integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg=="
},
- "node_modules/pseudomap": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz",
- "integrity": "sha512-b/YwNhb8lk1Zz2+bXXpS/LK9OisiZZ1SNsSLxN1x2OXVEhW2Ckr/7mWE5vrC1ZTiJlD9g19jWszTmJsB+oEpFQ=="
- },
"node_modules/psl": {
"version": "1.8.0",
"resolved": "https://registry.npmjs.org/psl/-/psl-1.8.0.tgz",
@@ -4852,25 +4208,6 @@
"node": ">= 0.8"
}
},
- "node_modules/readable-stream": {
- "version": "2.3.8",
- "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz",
- "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==",
- "dependencies": {
- "core-util-is": "~1.0.0",
- "inherits": "~2.0.3",
- "isarray": "~1.0.0",
- "process-nextick-args": "~2.0.0",
- "safe-buffer": "~5.1.1",
- "string_decoder": "~1.1.1",
- "util-deprecate": "~1.0.1"
- }
- },
- "node_modules/readable-stream/node_modules/safe-buffer": {
- "version": "5.1.2",
- "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
- "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
- },
"node_modules/readdirp": {
"version": "3.6.0",
"resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
@@ -4892,6 +4229,30 @@
"request": "^2.83.0"
}
},
+ "node_modules/redis-commands": {
+ "version": "1.7.0",
+ "resolved": "https://registry.npmjs.org/redis-commands/-/redis-commands-1.7.0.tgz",
+ "integrity": "sha512-nJWqw3bTFy21hX/CPKHth6sfhZbdiHP6bTawSgQBlKOVRG7EZkfHbbHwQJnrE4vsQf0CMNE+3gJ4Fmm16vdVlQ=="
+ },
+ "node_modules/redis-errors": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/redis-errors/-/redis-errors-1.2.0.tgz",
+ "integrity": "sha512-1qny3OExCf0UvUV/5wpYKf2YwPcOqXzkwKKSmKHiE6ZMQs5heeE/c8eXK+PNllPvmjgAbfnsbpkGZWy8cBpn9w==",
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/redis-parser": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/redis-parser/-/redis-parser-3.0.0.tgz",
+ "integrity": "sha512-DJnGAeenTdpMEH6uAJRK/uiyEIH9WVsUmoLwzudwGJUwZPp80PDBWPHXSAGNPwNvIXAbe7MSUB1zQFugFml66A==",
+ "dependencies": {
+ "redis-errors": "^1.0.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
"node_modules/regexp.prototype.flags": {
"version": "1.5.1",
"resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.1.tgz",
@@ -4953,14 +4314,6 @@
"node": ">=0.6"
}
},
- "node_modules/require-at": {
- "version": "1.0.6",
- "resolved": "https://registry.npmjs.org/require-at/-/require-at-1.0.6.tgz",
- "integrity": "sha512-7i1auJbMUrXEAZCOQ0VNJgmcT2VOKPRl2YGJwgpHpC9CE91Mv4/4UYIUm4chGJaI381ZDq1JUicFii64Hapd8g==",
- "engines": {
- "node": ">=4"
- }
- },
"node_modules/resolve": {
"version": "1.22.8",
"resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz",
@@ -5023,12 +4376,6 @@
"node": ">=0.10.0"
}
},
- "node_modules/rfdc": {
- "version": "1.3.1",
- "resolved": "https://registry.npmjs.org/rfdc/-/rfdc-1.3.1.tgz",
- "integrity": "sha512-r5a3l5HzYlIC68TpmYKlxWjmOP6wiPJ1vWv2HeLhNsRZMrCkxeqxiHlQ21oXmQ4F3SiryXBHhAD7JZqvOJjFmg==",
- "dev": true
- },
"node_modules/rimraf": {
"version": "3.0.2",
"resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz",
@@ -5176,18 +4523,6 @@
"resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
"integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg=="
},
- "node_modules/saslprep": {
- "version": "1.0.3",
- "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz",
- "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==",
- "optional": true,
- "dependencies": {
- "sparse-bitfield": "^3.0.3"
- },
- "engines": {
- "node": ">=6"
- }
- },
"node_modules/semver": {
"version": "5.7.2",
"resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz",
@@ -5432,55 +4767,6 @@
"node": ">=8"
}
},
- "node_modules/slice-ansi": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-5.0.0.tgz",
- "integrity": "sha512-FC+lgizVPfie0kkhqUScwRu1O/lF6NOgJmlCgK+/LYxDCTk8sGelYaHDhFcDN+Sn3Cv+3VSa4Byeo+IMCzpMgQ==",
- "dev": true,
- "dependencies": {
- "ansi-styles": "^6.0.0",
- "is-fullwidth-code-point": "^4.0.0"
- },
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/slice-ansi?sponsor=1"
- }
- },
- "node_modules/slice-ansi/node_modules/ansi-styles": {
- "version": "6.2.1",
- "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz",
- "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/ansi-styles?sponsor=1"
- }
- },
- "node_modules/slice-ansi/node_modules/is-fullwidth-code-point": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-4.0.0.tgz",
- "integrity": "sha512-O4L094N2/dZ7xqVdrXhh9r1KODPJpFms8B5sGdJLPy664AgvXsreZUyCQQNItZRDlYug4xStLjNp/sz3HvBowQ==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/sparse-bitfield": {
- "version": "3.0.3",
- "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz",
- "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=",
- "optional": true,
- "dependencies": {
- "memory-pager": "^1.0.2"
- }
- },
"node_modules/split2": {
"version": "3.2.2",
"resolved": "https://registry.npmjs.org/split2/-/split2-3.2.2.tgz",
@@ -5574,15 +4860,6 @@
"resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
"integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
},
- "node_modules/string-argv": {
- "version": "0.3.2",
- "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.2.tgz",
- "integrity": "sha512-aqD2Q0144Z+/RqG52NeHEkZauTAUWJO8c6yTftGJKO3Tja5tUgIfmIl6kExvhtxSDP7fXB6DvzkfMpCd/F3G+Q==",
- "dev": true,
- "engines": {
- "node": ">=0.6.19"
- }
- },
"node_modules/string-width": {
"version": "2.1.1",
"resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz",
@@ -5679,18 +4956,6 @@
"node": ">=4"
}
},
- "node_modules/strip-final-newline": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-3.0.0.tgz",
- "integrity": "sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
"node_modules/strip-json-comments": {
"version": "3.1.1",
"resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz",
@@ -5797,28 +5062,6 @@
"uuid": "dist/bin/uuid"
}
},
- "node_modules/synckit": {
- "version": "0.8.8",
- "resolved": "https://registry.npmjs.org/synckit/-/synckit-0.8.8.tgz",
- "integrity": "sha512-HwOKAP7Wc5aRGYdKH+dw0PRRpbO841v2DENBtjnR5HFWoiNByAl7vrx3p0G/rCyYXQsrxqtX48TImFtPcIHSpQ==",
- "dev": true,
- "dependencies": {
- "@pkgr/core": "^0.1.0",
- "tslib": "^2.6.2"
- },
- "engines": {
- "node": "^14.18.0 || >=16.0.0"
- },
- "funding": {
- "url": "https://opencollective.com/unts"
- }
- },
- "node_modules/synckit/node_modules/tslib": {
- "version": "2.6.2",
- "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz",
- "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==",
- "dev": true
- },
"node_modules/tdigest": {
"version": "0.1.2",
"resolved": "https://registry.npmjs.org/tdigest/-/tdigest-0.1.2.tgz",
@@ -6273,79 +5516,6 @@
"@types/node": "*"
}
},
- "node_modules/wrap-ansi": {
- "version": "9.0.0",
- "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.0.tgz",
- "integrity": "sha512-G8ura3S+3Z2G+mkgNRq8dqaFZAuxfsxpBB8OCTGRTCtp+l/v9nbFNmCUP1BZMts3G1142MsZfn6eeUKrr4PD1Q==",
- "dev": true,
- "dependencies": {
- "ansi-styles": "^6.2.1",
- "string-width": "^7.0.0",
- "strip-ansi": "^7.1.0"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/chalk/wrap-ansi?sponsor=1"
- }
- },
- "node_modules/wrap-ansi/node_modules/ansi-regex": {
- "version": "6.0.1",
- "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz",
- "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/ansi-regex?sponsor=1"
- }
- },
- "node_modules/wrap-ansi/node_modules/ansi-styles": {
- "version": "6.2.1",
- "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz",
- "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/ansi-styles?sponsor=1"
- }
- },
- "node_modules/wrap-ansi/node_modules/string-width": {
- "version": "7.1.0",
- "resolved": "https://registry.npmjs.org/string-width/-/string-width-7.1.0.tgz",
- "integrity": "sha512-SEIJCWiX7Kg4c129n48aDRwLbFb2LJmXXFrWBG4NGaRtMQ3myKPKbwrD1BKqQn74oCoNMBVrfDEr5M9YxCsrkw==",
- "dev": true,
- "dependencies": {
- "emoji-regex": "^10.3.0",
- "get-east-asian-width": "^1.0.0",
- "strip-ansi": "^7.1.0"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/wrap-ansi/node_modules/strip-ansi": {
- "version": "7.1.0",
- "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz",
- "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==",
- "dev": true,
- "dependencies": {
- "ansi-regex": "^6.0.1"
- },
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/chalk/strip-ansi?sponsor=1"
- }
- },
"node_modules/wrappy": {
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
@@ -6365,15 +5535,6 @@
"resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
"integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A=="
},
- "node_modules/yaml": {
- "version": "2.3.4",
- "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.3.4.tgz",
- "integrity": "sha512-8aAvwVUSHpfEqTQ4w/KMlf3HcRdt50E5ODIQJBw1fQ5RL34xabzxtUlzTXVqc4rkZsPbvrXKWnABCD7kWSmocA==",
- "dev": true,
- "engines": {
- "node": ">= 14"
- }
- },
"node_modules/yocto-queue": {
"version": "0.1.0",
"resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz",
diff --git a/src/node/addon/package.json b/src/addon/package.json
similarity index 89%
rename from src/node/addon/package.json
rename to src/addon/package.json
index d062dd2..2f49f6b 100644
--- a/src/node/addon/package.json
+++ b/src/addon/package.json
@@ -14,7 +14,6 @@
"axios": "^1.6.1",
"bottleneck": "^2.19.5",
"cache-manager": "^3.4.4",
- "cache-manager-mongodb": "^0.3.0",
"cors": "^2.8.5",
"debrid-link-api": "^1.0.1",
"express-rate-limit": "^6.7.0",
@@ -35,7 +34,11 @@
"stremio-addon-sdk": "^1.6.10",
"swagger-stats": "^0.99.7",
"ua-parser-js": "^1.0.36",
- "user-agents": "^1.0.1444"
+ "user-agents": "^1.0.1444",
+ "@redis/client": "^1.5.14",
+ "@redis/json": "^1.0.6",
+ "@redis/search": "^1.1.6",
+ "cache-manager-redis-store": "^2.0.0"
},
"devDependencies": {
"@types/node": "^20.11.6",
diff --git a/src/node/addon/src/addon.js b/src/addon/src/addon.js
similarity index 100%
rename from src/node/addon/src/addon.js
rename to src/addon/src/addon.js
diff --git a/src/node/addon/src/index.js b/src/addon/src/index.js
similarity index 100%
rename from src/node/addon/src/index.js
rename to src/addon/src/index.js
diff --git a/src/node/addon/src/lib/cache.js b/src/addon/src/lib/cache.js
similarity index 86%
rename from src/node/addon/src/lib/cache.js
rename to src/addon/src/lib/cache.js
index aca0092..4cf2070 100644
--- a/src/node/addon/src/lib/cache.js
+++ b/src/addon/src/lib/cache.js
@@ -1,7 +1,7 @@
import cacheManager from 'cache-manager';
-import mangodbStore from 'cache-manager-mongodb';
import { cacheConfig } from './config.js';
import { isStaticUrl } from '../moch/static.js';
+import redisStore from "cache-manager-redis-store";
const GLOBAL_KEY_PREFIX = 'knightcrawler-addon';
const STREAM_KEY_PREFIX = `${GLOBAL_KEY_PREFIX}|stream`;
@@ -21,19 +21,11 @@ const remoteCache = initiateRemoteCache();
function initiateRemoteCache() {
if (cacheConfig.NO_CACHE) {
return null;
- } else if (cacheConfig.MONGO_URI) {
+ } else if (cacheConfig.REDIS_CONNECTION_STRING) {
return cacheManager.caching({
- store: mangodbStore,
- uri: cacheConfig.MONGO_URI,
- options: {
- collection: 'knightcrawler_addon_collection',
- socketTimeoutMS: 120000,
- useNewUrlParser: true,
- useUnifiedTopology: false,
- ttl: STREAM_EMPTY_TTL
- },
+ store: redisStore,
ttl: STREAM_EMPTY_TTL,
- ignoreCacheErrors: true
+ url: cacheConfig.REDIS_CONNECTION_STRING
});
} else {
return cacheManager.caching({
diff --git a/src/node/addon/src/lib/config.js b/src/addon/src/lib/config.js
similarity index 57%
rename from src/node/addon/src/lib/config.js
rename to src/addon/src/lib/config.js
index f792828..d21cfae 100644
--- a/src/node/addon/src/lib/config.js
+++ b/src/addon/src/lib/config.js
@@ -1,18 +1,8 @@
export const cacheConfig = {
- MONGODB_HOST: process.env.MONGODB_HOST || 'mongodb',
- MONGODB_PORT: process.env.MONGODB_PORT || '27017',
- MONGODB_DB: process.env.MONGODB_DB || 'knightcrawler',
- MONGODB_USER: process.env.MONGODB_USER || 'mongo',
- MONGODB_PASSWORD: process.env.MONGODB_PASSWORD || 'mongo',
- COLLECTION_NAME: process.env.MONGODB_ADDON_COLLECTION || 'knightcrawler_addon_collection',
+ REDIS_CONNECTION_STRING: process.env.REDIS_CONNECTION_STRING || 'redis://localhost:6379/0',
NO_CACHE: parseBool(process.env.NO_CACHE, false),
}
-// Combine the environment variables into a connection string
-// The combined string will look something like:
-// 'mongodb://mongo:mongo@localhost:27017/knightcrawler?authSource=admin'
-cacheConfig.MONGO_URI = 'mongodb://' + cacheConfig.MONGODB_USER + ':' + cacheConfig.MONGODB_PASSWORD + '@' + cacheConfig.MONGODB_HOST + ':' + cacheConfig.MONGODB_PORT + '/' + cacheConfig.MONGODB_DB + '?authSource=admin';
-
export const databaseConfig = {
POSTGRES_HOST: process.env.POSTGRES_HOST || 'postgres',
POSTGRES_PORT: process.env.POSTGRES_PORT || '5432',
diff --git a/src/node/addon/src/lib/configuration.js b/src/addon/src/lib/configuration.js
similarity index 100%
rename from src/node/addon/src/lib/configuration.js
rename to src/addon/src/lib/configuration.js
diff --git a/src/node/addon/src/lib/extension.js b/src/addon/src/lib/extension.js
similarity index 100%
rename from src/node/addon/src/lib/extension.js
rename to src/addon/src/lib/extension.js
diff --git a/src/node/addon/src/lib/filter.js b/src/addon/src/lib/filter.js
similarity index 100%
rename from src/node/addon/src/lib/filter.js
rename to src/addon/src/lib/filter.js
diff --git a/src/node/addon/src/lib/landingTemplate.js b/src/addon/src/lib/landingTemplate.js
similarity index 100%
rename from src/node/addon/src/lib/landingTemplate.js
rename to src/addon/src/lib/landingTemplate.js
diff --git a/src/node/addon/src/lib/languages.js b/src/addon/src/lib/languages.js
similarity index 100%
rename from src/node/addon/src/lib/languages.js
rename to src/addon/src/lib/languages.js
diff --git a/src/node/addon/src/lib/magnetHelper.js b/src/addon/src/lib/magnetHelper.js
similarity index 100%
rename from src/node/addon/src/lib/magnetHelper.js
rename to src/addon/src/lib/magnetHelper.js
diff --git a/src/node/addon/src/lib/manifest.js b/src/addon/src/lib/manifest.js
similarity index 100%
rename from src/node/addon/src/lib/manifest.js
rename to src/addon/src/lib/manifest.js
diff --git a/src/node/addon/src/lib/promises.js b/src/addon/src/lib/promises.js
similarity index 100%
rename from src/node/addon/src/lib/promises.js
rename to src/addon/src/lib/promises.js
diff --git a/src/node/addon/src/lib/repository.js b/src/addon/src/lib/repository.js
similarity index 100%
rename from src/node/addon/src/lib/repository.js
rename to src/addon/src/lib/repository.js
diff --git a/src/node/addon/src/lib/requestHelper.js b/src/addon/src/lib/requestHelper.js
similarity index 100%
rename from src/node/addon/src/lib/requestHelper.js
rename to src/addon/src/lib/requestHelper.js
diff --git a/src/node/addon/src/lib/sort.js b/src/addon/src/lib/sort.js
similarity index 100%
rename from src/node/addon/src/lib/sort.js
rename to src/addon/src/lib/sort.js
diff --git a/src/node/addon/src/lib/streamInfo.js b/src/addon/src/lib/streamInfo.js
similarity index 100%
rename from src/node/addon/src/lib/streamInfo.js
rename to src/addon/src/lib/streamInfo.js
diff --git a/src/node/addon/src/lib/subtitles.js b/src/addon/src/lib/subtitles.js
similarity index 100%
rename from src/node/addon/src/lib/subtitles.js
rename to src/addon/src/lib/subtitles.js
diff --git a/src/node/addon/src/lib/titleHelper.js b/src/addon/src/lib/titleHelper.js
similarity index 100%
rename from src/node/addon/src/lib/titleHelper.js
rename to src/addon/src/lib/titleHelper.js
diff --git a/src/node/addon/src/lib/types.js b/src/addon/src/lib/types.js
similarity index 100%
rename from src/node/addon/src/lib/types.js
rename to src/addon/src/lib/types.js
diff --git a/src/node/addon/src/moch/alldebrid.js b/src/addon/src/moch/alldebrid.js
similarity index 100%
rename from src/node/addon/src/moch/alldebrid.js
rename to src/addon/src/moch/alldebrid.js
diff --git a/src/node/addon/src/moch/debridlink.js b/src/addon/src/moch/debridlink.js
similarity index 100%
rename from src/node/addon/src/moch/debridlink.js
rename to src/addon/src/moch/debridlink.js
diff --git a/src/node/addon/src/moch/moch.js b/src/addon/src/moch/moch.js
similarity index 100%
rename from src/node/addon/src/moch/moch.js
rename to src/addon/src/moch/moch.js
diff --git a/src/node/addon/src/moch/mochHelper.js b/src/addon/src/moch/mochHelper.js
similarity index 100%
rename from src/node/addon/src/moch/mochHelper.js
rename to src/addon/src/moch/mochHelper.js
diff --git a/src/node/addon/src/moch/offcloud.js b/src/addon/src/moch/offcloud.js
similarity index 100%
rename from src/node/addon/src/moch/offcloud.js
rename to src/addon/src/moch/offcloud.js
diff --git a/src/node/addon/src/moch/options.js b/src/addon/src/moch/options.js
similarity index 100%
rename from src/node/addon/src/moch/options.js
rename to src/addon/src/moch/options.js
diff --git a/src/node/addon/src/moch/premiumize.js b/src/addon/src/moch/premiumize.js
similarity index 100%
rename from src/node/addon/src/moch/premiumize.js
rename to src/addon/src/moch/premiumize.js
diff --git a/src/node/addon/src/moch/putio.js b/src/addon/src/moch/putio.js
similarity index 100%
rename from src/node/addon/src/moch/putio.js
rename to src/addon/src/moch/putio.js
diff --git a/src/node/addon/src/moch/realdebrid.js b/src/addon/src/moch/realdebrid.js
similarity index 100%
rename from src/node/addon/src/moch/realdebrid.js
rename to src/addon/src/moch/realdebrid.js
diff --git a/src/node/addon/src/moch/static.js b/src/addon/src/moch/static.js
similarity index 100%
rename from src/node/addon/src/moch/static.js
rename to src/addon/src/moch/static.js
diff --git a/src/node/addon/src/serverless.js b/src/addon/src/serverless.js
similarity index 100%
rename from src/node/addon/src/serverless.js
rename to src/addon/src/serverless.js
diff --git a/src/node/addon/static/videos/download_failed_v2.mp4 b/src/addon/static/videos/download_failed_v2.mp4
similarity index 100%
rename from src/node/addon/static/videos/download_failed_v2.mp4
rename to src/addon/static/videos/download_failed_v2.mp4
diff --git a/src/node/addon/static/videos/downloading_v2.mp4 b/src/addon/static/videos/downloading_v2.mp4
similarity index 100%
rename from src/node/addon/static/videos/downloading_v2.mp4
rename to src/addon/static/videos/downloading_v2.mp4
diff --git a/src/node/addon/static/videos/failed_access_v2.mp4 b/src/addon/static/videos/failed_access_v2.mp4
similarity index 100%
rename from src/node/addon/static/videos/failed_access_v2.mp4
rename to src/addon/static/videos/failed_access_v2.mp4
diff --git a/src/node/addon/static/videos/failed_infringement_v2.mp4 b/src/addon/static/videos/failed_infringement_v2.mp4
similarity index 100%
rename from src/node/addon/static/videos/failed_infringement_v2.mp4
rename to src/addon/static/videos/failed_infringement_v2.mp4
diff --git a/src/node/addon/static/videos/failed_opening_v2.mp4 b/src/addon/static/videos/failed_opening_v2.mp4
similarity index 100%
rename from src/node/addon/static/videos/failed_opening_v2.mp4
rename to src/addon/static/videos/failed_opening_v2.mp4
diff --git a/src/node/addon/static/videos/failed_rar_v2.mp4 b/src/addon/static/videos/failed_rar_v2.mp4
similarity index 100%
rename from src/node/addon/static/videos/failed_rar_v2.mp4
rename to src/addon/static/videos/failed_rar_v2.mp4
diff --git a/src/node/addon/static/videos/failed_unexpected_v2.mp4 b/src/addon/static/videos/failed_unexpected_v2.mp4
similarity index 100%
rename from src/node/addon/static/videos/failed_unexpected_v2.mp4
rename to src/addon/static/videos/failed_unexpected_v2.mp4
diff --git a/src/debrid-collector/Configuration/logging.json b/src/debrid-collector/Configuration/logging.json
new file mode 100644
index 0000000..3df9b11
--- /dev/null
+++ b/src/debrid-collector/Configuration/logging.json
@@ -0,0 +1,36 @@
+{
+ "Serilog": {
+ "Using": [ "Serilog.Sinks.Console" ],
+ "MinimumLevel": {
+ "Default": "Information",
+ "Override": {
+ "Microsoft": "Warning",
+ "System": "Warning",
+ "Npgsql.Command": "Warning",
+ "Marten.IDocumentStore": "Warning",
+ "Wolverine.Runtime.WolverineRuntime": "Warning",
+ "Wolverine.Runtime.Agents.NodeAgentController": "Warning",
+ "Oakton.Resources.ResourceSetupHostService": "Warning",
+ "System.Net.Http.HttpClient.Scraper.LogicalHandler": "Warning",
+ "System.Net.Http.HttpClient.Scraper.ClientHandler": "Warning",
+ "Quartz.Impl.StdSchedulerFactory": "Warning",
+ "Quartz.Core.QuartzScheduler": "Warning",
+ "Quartz.Simpl.RAMJobStore": "Warning",
+ "Quartz.Core.JobRunShell": "Warning",
+ "Quartz.Core.SchedulerSignalerImpl": "Warning"
+ }
+ },
+ "WriteTo": [
+ {
+ "Name": "Console",
+ "Args": {
+ "outputTemplate": "{Timestamp:HH:mm:ss} [{Level}] [{SourceContext}] {Message}{NewLine}{Exception}"
+ }
+ }
+ ],
+ "Enrich": [ "FromLogContext", "WithMachineName", "WithThreadId" ],
+ "Properties": {
+ "Application": "Metadata"
+ }
+ }
+}
diff --git a/src/debrid-collector/DebridCollector.csproj b/src/debrid-collector/DebridCollector.csproj
new file mode 100644
index 0000000..21ce4fa
--- /dev/null
+++ b/src/debrid-collector/DebridCollector.csproj
@@ -0,0 +1,38 @@
+
+
+
+ Exe
+ net8.0
+ enable
+ enable
+ 54cad2ee-57df-4bb2-a192-d5d501448e0a
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Always
+
+
+
+
+
+
+
+
diff --git a/src/debrid-collector/DebridCollector.sln b/src/debrid-collector/DebridCollector.sln
new file mode 100644
index 0000000..a3dfeb0
--- /dev/null
+++ b/src/debrid-collector/DebridCollector.sln
@@ -0,0 +1,27 @@
+
+Microsoft Visual Studio Solution File, Format Version 12.00
+Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "DebridCollector", "DebridCollector.csproj", "{64C3253C-0638-4825-AC82-7D5600D1F9C9}"
+EndProject
+Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "SharedContracts", "..\shared\SharedContracts.csproj", "{C9BE500C-CE04-480B-874F-A85D33CAA821}"
+EndProject
+Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "shared", "shared", "{2C0A0F53-28E6-404F-9EFE-DADFBEF8338B}"
+EndProject
+Global
+ GlobalSection(SolutionConfigurationPlatforms) = preSolution
+ Debug|Any CPU = Debug|Any CPU
+ Release|Any CPU = Release|Any CPU
+ EndGlobalSection
+ GlobalSection(ProjectConfigurationPlatforms) = postSolution
+ {64C3253C-0638-4825-AC82-7D5600D1F9C9}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
+ {64C3253C-0638-4825-AC82-7D5600D1F9C9}.Debug|Any CPU.Build.0 = Debug|Any CPU
+ {64C3253C-0638-4825-AC82-7D5600D1F9C9}.Release|Any CPU.ActiveCfg = Release|Any CPU
+ {64C3253C-0638-4825-AC82-7D5600D1F9C9}.Release|Any CPU.Build.0 = Release|Any CPU
+ {C9BE500C-CE04-480B-874F-A85D33CAA821}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
+ {C9BE500C-CE04-480B-874F-A85D33CAA821}.Debug|Any CPU.Build.0 = Debug|Any CPU
+ {C9BE500C-CE04-480B-874F-A85D33CAA821}.Release|Any CPU.ActiveCfg = Release|Any CPU
+ {C9BE500C-CE04-480B-874F-A85D33CAA821}.Release|Any CPU.Build.0 = Release|Any CPU
+ EndGlobalSection
+ GlobalSection(NestedProjects) = preSolution
+ {C9BE500C-CE04-480B-874F-A85D33CAA821} = {2C0A0F53-28E6-404F-9EFE-DADFBEF8338B}
+ EndGlobalSection
+EndGlobal
diff --git a/src/debrid-collector/Dockerfile b/src/debrid-collector/Dockerfile
new file mode 100644
index 0000000..baab5d7
--- /dev/null
+++ b/src/debrid-collector/Dockerfile
@@ -0,0 +1,20 @@
+FROM --platform=$BUILDPLATFORM mcr.microsoft.com/dotnet/sdk:8.0 AS build
+
+ARG TARGETARCH
+WORKDIR /src
+COPY shared/ shared/
+COPY debrid-collector/ debrid-collector/
+WORKDIR /src/debrid-collector/
+RUN dotnet restore -a $TARGETARCH
+RUN dotnet publish -c Release --no-restore -o /src/out -a $TARGETARCH
+
+
+FROM mcr.microsoft.com/dotnet/aspnet:8.0-alpine
+
+WORKDIR /app
+COPY --from=build /src/out .
+RUN addgroup -S debrid && adduser -S -G debrid debrid
+USER debrid
+HEALTHCHECK --interval=30s --timeout=30s --start-period=5s --retries=3 \
+ CMD pgrep -f dotnet || exit 1
+ENTRYPOINT ["dotnet", "DebridCollector.dll"]
diff --git a/src/debrid-collector/Extensions/ServiceCollectionExtensions.cs b/src/debrid-collector/Extensions/ServiceCollectionExtensions.cs
new file mode 100644
index 0000000..4fe0451
--- /dev/null
+++ b/src/debrid-collector/Extensions/ServiceCollectionExtensions.cs
@@ -0,0 +1,73 @@
+using DebridCollector.Features.Configuration;
+
+namespace DebridCollector.Extensions;
+
+public static class ServiceCollectionExtensions
+{
+ internal static IServiceCollection AddDatabase(this IServiceCollection services)
+ {
+ services.LoadConfigurationFromEnv();
+ services.AddTransient();
+
+ return services;
+ }
+
+ internal static IServiceCollection AddServiceConfiguration(this IServiceCollection services)
+ {
+ var serviceConfiguration = services.LoadConfigurationFromEnv();
+
+ services.AddRealDebridClient(serviceConfiguration);
+ services.AddSingleton();
+ services.AddHostedService();
+
+ return services;
+ }
+
+ internal static IServiceCollection RegisterMassTransit(this IServiceCollection services)
+ {
+ var rabbitConfiguration = services.LoadConfigurationFromEnv();
+ var redisConfiguration = services.LoadConfigurationFromEnv();
+
+ services.AddMassTransit(x =>
+ {
+ x.SetKebabCaseEndpointNameFormatter();
+
+ x.UsingRabbitMq((context, cfg) =>
+ {
+ cfg.AutoStart = true;
+
+ cfg.Host(
+ rabbitConfiguration.Host, h =>
+ {
+ h.Username(rabbitConfiguration.Username);
+ h.Password(rabbitConfiguration.Password);
+ });
+
+ cfg.Message(e => e.SetEntityName(rabbitConfiguration.DebridCollectorQueueName));
+ cfg.ConfigureEndpoints(context);
+ });
+
+ x.AddConsumer();
+ x.AddConsumer();
+ x.RegisterMetadataIngestionSaga(redisConfiguration, rabbitConfiguration);
+ });
+
+ return services;
+ }
+
+ private static void RegisterMetadataIngestionSaga(this IBusRegistrationConfigurator x, RedisConfiguration redisConfiguration, RabbitMqConfiguration rabbitMqConfiguration) =>
+ x.AddSagaStateMachine(
+ cfg =>
+ {
+ cfg.UseMessageRetry(r => r.Intervals(1000,2000,5000));
+ cfg.UseInMemoryOutbox();
+ })
+ .RedisRepository(redisConfiguration.ConnectionString)
+ .Endpoint(
+ e =>
+ {
+ e.Name = rabbitMqConfiguration.DebridCollectorQueueName;
+ e.ConcurrentMessageLimit = 50;
+ e.PrefetchCount = 50;
+ });
+}
diff --git a/src/debrid-collector/Features/Configuration/DebridCollectorConfiguration.cs b/src/debrid-collector/Features/Configuration/DebridCollectorConfiguration.cs
new file mode 100644
index 0000000..0603170
--- /dev/null
+++ b/src/debrid-collector/Features/Configuration/DebridCollectorConfiguration.cs
@@ -0,0 +1,8 @@
+namespace DebridCollector.Features.Configuration;
+
+public class DebridCollectorConfiguration
+{
+ private const string Prefix = "COLLECTOR";
+ private const string RealDebridApiKeyVariable = "REAL_DEBRID_API_KEY";
+ public string RealDebridApiKey { get; init; } = Prefix.GetRequiredEnvironmentVariableAsString(RealDebridApiKeyVariable);
+}
diff --git a/src/debrid-collector/Features/Debrid/DebridRequestProcessor.cs b/src/debrid-collector/Features/Debrid/DebridRequestProcessor.cs
new file mode 100644
index 0000000..b5054e6
--- /dev/null
+++ b/src/debrid-collector/Features/Debrid/DebridRequestProcessor.cs
@@ -0,0 +1,64 @@
+namespace DebridCollector.Features.Debrid;
+
+public class DebridRequestProcessor(IDebridHttpClient debridHttpClient, ILogger logger, IBus messageBus) : BackgroundService
+{
+ private const int BatchDelay = 3000;
+ public const int MaxBatchSize = 100;
+
+ protected override async Task ExecuteAsync(CancellationToken stoppingToken)
+ {
+ var requests = new List(MaxBatchSize);
+ var delay = TimeSpan.FromMilliseconds(BatchDelay);
+ while (!stoppingToken.IsCancellationRequested)
+ {
+ while (ProcessorChannel.Queue.Reader.TryRead(out var request))
+ {
+ if (requests.Count >= MaxBatchSize)
+ {
+ break;
+ }
+
+ if (requests.All(x => x.InfoHash != request.InfoHash))
+ {
+ requests.Add(request);
+ }
+ }
+
+ if (requests.Any())
+ {
+ await ProcessRequests(requests, stoppingToken);
+ requests.Clear();
+ }
+
+ await Task.Delay(delay, stoppingToken);
+ }
+
+ // After the loop ends, there may be remaining requests which were not processed. Let's process them:
+ if (requests.Count != 0)
+ {
+ await ProcessRequests(requests, stoppingToken);
+ requests.Clear();
+ }
+ }
+
+ private async Task ProcessRequests(IReadOnlyCollection requests, CancellationToken stoppingToken = default)
+ {
+ try
+ {
+ var results = await debridHttpClient.GetMetadataAsync(requests, stoppingToken);
+ await ProcessResponses(results);
+ logger.LogInformation("Processed: {Count} infoHashes", requests.Count);
+ }
+ catch (Exception e)
+ {
+ logger.LogError(e, "Failed to process infoHashes");
+ }
+ }
+
+ private async Task ProcessResponses(IEnumerable results)
+ {
+ var messages = results.Select(response => new GotMetadata(response)).ToList();
+
+ await messageBus.PublishBatch(messages);
+ }
+}
\ No newline at end of file
diff --git a/src/debrid-collector/Features/Debrid/IDebridHttpClient.cs b/src/debrid-collector/Features/Debrid/IDebridHttpClient.cs
new file mode 100644
index 0000000..55dc08d
--- /dev/null
+++ b/src/debrid-collector/Features/Debrid/IDebridHttpClient.cs
@@ -0,0 +1,6 @@
+namespace DebridCollector.Features.Debrid;
+
+public interface IDebridHttpClient
+{
+ public Task> GetMetadataAsync(IReadOnlyCollection infoHashes, CancellationToken cancellationToken = default);
+}
\ No newline at end of file
diff --git a/src/debrid-collector/Features/Debrid/ProcessorChannel.cs b/src/debrid-collector/Features/Debrid/ProcessorChannel.cs
new file mode 100644
index 0000000..b5c94b2
--- /dev/null
+++ b/src/debrid-collector/Features/Debrid/ProcessorChannel.cs
@@ -0,0 +1,12 @@
+namespace DebridCollector.Features.Debrid;
+
+public static class ProcessorChannel
+{
+ public static Channel Queue = Channel.CreateUnbounded(new()
+ {
+ SingleReader = true,
+ SingleWriter = true,
+ });
+
+ public static bool AddToQueue(PerformMetadataRequest infoHash) => Queue.Writer.TryWrite(infoHash);
+}
\ No newline at end of file
diff --git a/src/debrid-collector/Features/Debrid/RealDebridClient.cs b/src/debrid-collector/Features/Debrid/RealDebridClient.cs
new file mode 100644
index 0000000..5fb7f5e
--- /dev/null
+++ b/src/debrid-collector/Features/Debrid/RealDebridClient.cs
@@ -0,0 +1,65 @@
+namespace DebridCollector.Features.Debrid;
+
+public class RealDebridClient(HttpClient client) : IDebridHttpClient
+{
+ private const string TorrentsInstantAvailability = "torrents/instantAvailability/";
+
+ public async Task> GetMetadataAsync(IReadOnlyCollection requests, CancellationToken cancellationToken = default)
+ {
+ var responseAsString = await client.GetStringAsync($"{TorrentsInstantAvailability}{string.Join("/", requests.Select(x => x.InfoHash.ToLowerInvariant()))}", cancellationToken);
+
+ var document = JsonDocument.Parse(responseAsString);
+
+ var torrentMetadataResponses = new List();
+
+ foreach (var request in requests)
+ {
+ if (document.RootElement.TryGetProperty(request.InfoHash.ToLowerInvariant(), out var dataElement) &&
+ dataElement.ValueKind == JsonValueKind.Object &&
+ dataElement.TryGetProperty("rd", out var rdDataElement) &&
+ rdDataElement.ValueKind == JsonValueKind.Array &&
+ rdDataElement.GetArrayLength() > 0)
+ {
+ MapResponseToMetadata(rdDataElement, torrentMetadataResponses, request);
+ continue;
+ }
+
+ torrentMetadataResponses.Add(new(request.CorrelationId, new()));
+ }
+
+ return torrentMetadataResponses;
+ }
+
+ private static void MapResponseToMetadata(JsonElement rdDataElement, List torrentMetadataResponses, PerformMetadataRequest request)
+ {
+ var metaData = new FileDataDictionary();
+
+ foreach (var item in rdDataElement.EnumerateArray())
+ {
+ if (item.ValueKind == JsonValueKind.Object)
+ {
+ foreach (var property in item.EnumerateObject())
+ {
+ if (property.Value.ValueKind == JsonValueKind.Object)
+ {
+ var fileData = new FileData();
+
+ if (property.Value.TryGetProperty("filename", out var filenameElement) && filenameElement.ValueKind == JsonValueKind.String)
+ {
+ fileData.Filename = filenameElement.GetString();
+ }
+
+ if (property.Value.TryGetProperty("filesize", out var filesizeElement) && filesizeElement.ValueKind == JsonValueKind.Number)
+ {
+ fileData.Filesize = filesizeElement.GetInt64();
+ }
+
+ metaData[property.Name] = fileData;
+ }
+ }
+ }
+ }
+
+ torrentMetadataResponses.Add(new(request.CorrelationId, metaData));
+ }
+}
\ No newline at end of file
diff --git a/src/debrid-collector/Features/Debrid/RealDebridResponse.cs b/src/debrid-collector/Features/Debrid/RealDebridResponse.cs
new file mode 100644
index 0000000..460e744
--- /dev/null
+++ b/src/debrid-collector/Features/Debrid/RealDebridResponse.cs
@@ -0,0 +1,24 @@
+namespace DebridCollector.Features.Debrid;
+
+public class RealDebridResponse : Dictionary
+{
+}
+
+public class RdData
+{
+ [JsonPropertyName("rd")]
+ public List? Rd { get; set; }
+}
+
+public class FileDataDictionary : Dictionary
+{
+}
+
+public class FileData
+{
+ [JsonPropertyName("filename")]
+ public string? Filename { get; set; }
+
+ [JsonPropertyName("filesize")]
+ public long? Filesize { get; set; }
+}
\ No newline at end of file
diff --git a/src/debrid-collector/Features/Debrid/ServiceCollectionExtensions.cs b/src/debrid-collector/Features/Debrid/ServiceCollectionExtensions.cs
new file mode 100644
index 0000000..dbd1f9b
--- /dev/null
+++ b/src/debrid-collector/Features/Debrid/ServiceCollectionExtensions.cs
@@ -0,0 +1,32 @@
+using DebridCollector.Features.Configuration;
+
+namespace DebridCollector.Features.Debrid;
+
+public static class ServiceCollectionExtensions
+{
+ public static IServiceCollection AddRealDebridClient(this IServiceCollection services, DebridCollectorConfiguration serviceConfiguration)
+ {
+ services.AddHttpClient(
+ client =>
+ {
+ client.BaseAddress = new("https://api.real-debrid.com/rest/1.0/");
+ client.DefaultRequestHeaders.Add("Authorization", $"Bearer {serviceConfiguration.RealDebridApiKey}");
+ })
+ .AddPolicyHandler(GetRetryPolicy())
+ .AddPolicyHandler(GetCircuitBreakerPolicy());
+
+ return services;
+ }
+
+ private static AsyncPolicy GetRetryPolicy(int MaxRetryCount = 5, int MaxJitterTime = 1000) =>
+ HttpPolicyExtensions
+ .HandleTransientHttpError()
+ .WaitAndRetryAsync(MaxRetryCount, RetryAttempt =>
+ TimeSpan.FromSeconds(Math.Pow(2, RetryAttempt)) +
+ TimeSpan.FromMilliseconds(Random.Shared.Next(0, MaxJitterTime)));
+
+ private static AsyncPolicy GetCircuitBreakerPolicy() =>
+ HttpPolicyExtensions
+ .HandleTransientHttpError()
+ .CircuitBreakerAsync(handledEventsAllowedBeforeBreaking: 5, TimeSpan.FromSeconds(30));
+}
\ No newline at end of file
diff --git a/src/debrid-collector/Features/Worker/DebridMetaToTorrentMeta.cs b/src/debrid-collector/Features/Worker/DebridMetaToTorrentMeta.cs
new file mode 100644
index 0000000..ce2935a
--- /dev/null
+++ b/src/debrid-collector/Features/Worker/DebridMetaToTorrentMeta.cs
@@ -0,0 +1,82 @@
+namespace DebridCollector.Features.Worker;
+
+public static class DebridMetaToTorrentMeta
+{
+ public static IReadOnlyList MapMetadataToFilesCollection(
+ IParseTorrentTitle torrentTitle,
+ Torrent torrent,
+ string ImdbId,
+ FileDataDictionary Metadata)
+ {
+ try
+ {
+ var files = new List();
+
+ foreach (var metadataEntry in Metadata.Where(m => Filetypes.VideoFileExtensions.Any(ext => m.Value.Filename.EndsWith(ext))))
+ {
+ var validFileIndex = int.TryParse(metadataEntry.Key, out var fileIndex);
+
+ var file = new TorrentFile
+ {
+ ImdbId = ImdbId,
+ KitsuId = 0,
+ InfoHash = torrent.InfoHash,
+ FileIndex = validFileIndex ? fileIndex : 0,
+ Title = metadataEntry.Value.Filename,
+ Size = metadataEntry.Value.Filesize.GetValueOrDefault(),
+ };
+
+ var parsedTitle = torrentTitle.Parse(file.Title);
+
+ file.ImdbSeason = parsedTitle.Seasons.FirstOrDefault();
+ file.ImdbEpisode = parsedTitle.Episodes.FirstOrDefault();
+
+ files.Add(file);
+ }
+
+ return files;
+ }
+ catch (Exception)
+ {
+ return [];
+ }
+ }
+
+ public static async Task> MapMetadataToSubtitlesCollection(IDataStorage storage, string InfoHash, FileDataDictionary Metadata)
+ {
+ try
+ {
+ var files = new List();
+
+ var torrentFiles = await storage.GetTorrentFiles(InfoHash.ToLowerInvariant());
+
+ if (torrentFiles.Count == 0)
+ {
+ return files;
+ }
+
+ foreach (var metadataEntry in Metadata.Where(m => Filetypes.SubtitleFileExtensions.Any(ext => m.Value.Filename.EndsWith(ext))))
+ {
+ var validFileIndex = int.TryParse(metadataEntry.Key, out var fileIndex);
+ var fileId = torrentFiles.FirstOrDefault(
+ t => Path.GetFileNameWithoutExtension(t.Title) == Path.GetFileNameWithoutExtension(metadataEntry.Value.Filename))?.Id ?? 0;
+
+ var file = new SubtitleFile
+ {
+ InfoHash = InfoHash,
+ FileIndex = validFileIndex ? fileIndex : 0,
+ FileId = fileId,
+ Title = metadataEntry.Value.Filename,
+ };
+
+ files.Add(file);
+ }
+
+ return files;
+ }
+ catch (Exception)
+ {
+ return [];
+ }
+ }
+}
\ No newline at end of file
diff --git a/src/debrid-collector/Features/Worker/Filetypes.cs b/src/debrid-collector/Features/Worker/Filetypes.cs
new file mode 100644
index 0000000..3ce751b
--- /dev/null
+++ b/src/debrid-collector/Features/Worker/Filetypes.cs
@@ -0,0 +1,104 @@
+namespace DebridCollector.Features.Worker;
+
+public static class Filetypes
+{
+ public static IReadOnlyList VideoFileExtensions =
+ [
+ ".3g2",
+ ".3gp",
+ ".3gp2",
+ ".3gpp",
+ ".60d",
+ ".ajp",
+ ".asf",
+ ".asx",
+ ".avchd",
+ ".avi",
+ ".bik",
+ ".bix",
+ ".box",
+ ".cam",
+ ".dat",
+ ".divx",
+ ".dmf",
+ ".dv",
+ ".dvr-ms",
+ ".evo",
+ ".flc",
+ ".fli",
+ ".flic",
+ ".flv",
+ ".flx",
+ ".gvi",
+ ".gvp",
+ ".h264",
+ ".m1v",
+ ".m2p",
+ ".m2ts",
+ ".m2v",
+ ".m4e",
+ ".m4v",
+ ".mjp",
+ ".mjpeg",
+ ".mjpg",
+ ".mkv",
+ ".moov",
+ ".mov",
+ ".movhd",
+ ".movie",
+ ".movx",
+ ".mp4",
+ ".mpe",
+ ".mpeg",
+ ".mpg",
+ ".mpv",
+ ".mpv2",
+ ".mxf",
+ ".nsv",
+ ".nut",
+ ".ogg",
+ ".ogm",
+ ".omf",
+ ".ps",
+ ".qt",
+ ".ram",
+ ".rm",
+ ".rmvb",
+ ".swf",
+ ".ts",
+ ".vfw",
+ ".vid",
+ ".video",
+ ".viv",
+ ".vivo",
+ ".vob",
+ ".vro",
+ ".wm",
+ ".wmv",
+ ".wmx",
+ ".wrap",
+ ".wvx",
+ ".wx",
+ ".x264",
+ ".xvid",
+ ];
+
+ public static IReadOnlyList SubtitleFileExtensions =
+ [
+ ".a",
+ ".srt",
+ ".ass",
+ ".ssa",
+ ".stl",
+ ".scc",
+ ".ttml",
+ ".sbv",
+ ".dks",
+ ".qtx",
+ ".jss",
+ ".vtt",
+ ".smi",
+ ".usf",
+ ".idx"
+ ];
+}
\ No newline at end of file
diff --git a/src/debrid-collector/Features/Worker/InfohashMetadataSagaState.cs b/src/debrid-collector/Features/Worker/InfohashMetadataSagaState.cs
new file mode 100644
index 0000000..69e5125
--- /dev/null
+++ b/src/debrid-collector/Features/Worker/InfohashMetadataSagaState.cs
@@ -0,0 +1,14 @@
+namespace DebridCollector.Features.Worker;
+
+public class InfohashMetadataSagaState : SagaStateMachineInstance, ISagaVersion
+{
+ public Torrent? Torrent { get; set; }
+ public string? Title { get; set; }
+ public string? ImdbId { get; set; }
+ public TorrentMetadataResponse? Metadata { get; set; }
+ public int RetriesAllowed { get; set; } = 2;
+
+ public Guid CorrelationId { get; set; }
+ public int Version { get; set; }
+ public int CurrentState { get; set; }
+}
\ No newline at end of file
diff --git a/src/debrid-collector/Features/Worker/InfohashMetadataSagaStateMachine.cs b/src/debrid-collector/Features/Worker/InfohashMetadataSagaStateMachine.cs
new file mode 100644
index 0000000..d726dab
--- /dev/null
+++ b/src/debrid-collector/Features/Worker/InfohashMetadataSagaStateMachine.cs
@@ -0,0 +1,63 @@
+namespace DebridCollector.Features.Worker;
+
+public class InfohashMetadataSagaStateMachine : MassTransitStateMachine
+{
+ public State Ingesting { get; private set; } = null!;
+ public State Writing { get; private set; } = null!;
+ public State Completed { get; private set; } = null!;
+
+ public Event CollectMetadata { get; private set; } = null!;
+ public Event GotMetadata { get; private set; } = null!;
+ public Event MetadataWritten { get; private set; } = null!;
+
+ public InfohashMetadataSagaStateMachine(ILogger logger)
+ {
+ InstanceState(x => x.CurrentState);
+
+ Event(() => CollectMetadata, x => x.CorrelateById(context => context.Message.CorrelationId));
+ Event(() => GotMetadata, x => x.CorrelateById(context => context.Message.CorrelationId));
+ Event(() => MetadataWritten, x => x.CorrelateById(context => context.Message.CorrelationId));
+
+ Initially(
+ When(CollectMetadata)
+ .ThenAsync(
+ async context =>
+ {
+ context.Saga.CorrelationId = context.Data.CorrelationId;
+ context.Saga.Torrent = context.Data.Torrent;
+ context.Saga.ImdbId = context.Data.ImdbId;
+
+ await context.Publish(new PerformMetadataRequest(context.Saga.CorrelationId, context.Saga.Torrent.InfoHash));
+
+ logger.LogInformation("Collecting Metadata for torrent {InfoHash} in Saga {SagaId}", context.Instance.Torrent.InfoHash, context.Instance.CorrelationId);
+ })
+ .TransitionTo(Ingesting));
+
+ During(
+ Ingesting,
+ When(GotMetadata)
+ .ThenAsync(
+ async context =>
+ {
+ context.Saga.Metadata = context.Data.Metadata;
+
+ await context.Publish(new WriteMetadata(context.Saga.Torrent, context.Saga.Metadata, context.Saga.ImdbId));
+
+ logger.LogInformation("Got Metadata for torrent {InfoHash} in Saga {SagaId}", context.Saga.Torrent.InfoHash, context.Saga.CorrelationId);
+ })
+ .TransitionTo(Writing));
+
+ During(
+ Writing,
+ When(MetadataWritten)
+ .Then(
+ context =>
+ {
+ logger.LogInformation("Metadata Written for torrent {InfoHash} in Saga {SagaId}", context.Saga.Torrent.InfoHash, context.Saga.CorrelationId);
+ })
+ .TransitionTo(Completed)
+ .Finalize());
+
+ SetCompletedWhenFinalized();
+ }
+}
diff --git a/src/debrid-collector/Features/Worker/PerformMetadataRequestConsumer.cs b/src/debrid-collector/Features/Worker/PerformMetadataRequestConsumer.cs
new file mode 100644
index 0000000..09ba01a
--- /dev/null
+++ b/src/debrid-collector/Features/Worker/PerformMetadataRequestConsumer.cs
@@ -0,0 +1,10 @@
+namespace DebridCollector.Features.Worker;
+
+public class PerformMetadataRequestConsumer : IConsumer
+{
+ public Task Consume(ConsumeContext context)
+ {
+ ProcessorChannel.AddToQueue(context.Message);
+ return Task.CompletedTask;
+ }
+}
\ No newline at end of file
diff --git a/src/debrid-collector/Features/Worker/Requests.cs b/src/debrid-collector/Features/Worker/Requests.cs
new file mode 100644
index 0000000..b976dd7
--- /dev/null
+++ b/src/debrid-collector/Features/Worker/Requests.cs
@@ -0,0 +1,22 @@
+namespace DebridCollector.Features.Worker;
+
+[EntityName("perform-metadata-request")]
+public record PerformMetadataRequest(Guid CorrelationId, string InfoHash) : CorrelatedBy;
+
+[EntityName("torrent-metadata-response")]
+public record GotMetadata(TorrentMetadataResponse Metadata) : CorrelatedBy
+{
+ public Guid CorrelationId { get; init; } = Metadata.CorrelationId;
+}
+
+[EntityName("write-metadata")]
+public record WriteMetadata(Torrent Torrent, TorrentMetadataResponse Metadata, string ImdbId) : CorrelatedBy
+{
+ public Guid CorrelationId { get; init; } = Metadata.CorrelationId;
+}
+
+[EntityName("metadata-written")]
+public record MetadataWritten(TorrentMetadataResponse Metadata) : CorrelatedBy
+{
+ public Guid CorrelationId { get; init; } = Metadata.CorrelationId;
+}
\ No newline at end of file
diff --git a/src/debrid-collector/Features/Worker/TorrentMetadataResponse.cs b/src/debrid-collector/Features/Worker/TorrentMetadataResponse.cs
new file mode 100644
index 0000000..7201bb2
--- /dev/null
+++ b/src/debrid-collector/Features/Worker/TorrentMetadataResponse.cs
@@ -0,0 +1,4 @@
+namespace DebridCollector.Features.Worker;
+
+[EntityName("torrent-metadata-response")]
+public record TorrentMetadataResponse(Guid CorrelationId, FileDataDictionary Metadata) : CorrelatedBy;
\ No newline at end of file
diff --git a/src/debrid-collector/Features/Worker/WriteMetadataConsumer.cs b/src/debrid-collector/Features/Worker/WriteMetadataConsumer.cs
new file mode 100644
index 0000000..7423966
--- /dev/null
+++ b/src/debrid-collector/Features/Worker/WriteMetadataConsumer.cs
@@ -0,0 +1,25 @@
+namespace DebridCollector.Features.Worker;
+
+public class WriteMetadataConsumer(IParseTorrentTitle parseTorrentTitle, IDataStorage dataStorage) : IConsumer
+{
+ public async Task Consume(ConsumeContext context)
+ {
+ var request = context.Message;
+
+ var torrentFiles = DebridMetaToTorrentMeta.MapMetadataToFilesCollection(parseTorrentTitle, request.Torrent, request.ImdbId, request.Metadata.Metadata);
+
+ if (torrentFiles.Any())
+ {
+ await dataStorage.InsertFiles(torrentFiles);
+
+ var subtitles = await DebridMetaToTorrentMeta.MapMetadataToSubtitlesCollection(dataStorage, request.Torrent.InfoHash, request.Metadata.Metadata);
+
+ if (subtitles.Any())
+ {
+ await dataStorage.InsertSubtitles(subtitles);
+ }
+ }
+
+ await context.Publish(new MetadataWritten(request.Metadata));
+ }
+}
\ No newline at end of file
diff --git a/src/debrid-collector/GlobalUsings.cs b/src/debrid-collector/GlobalUsings.cs
new file mode 100644
index 0000000..0d1ada4
--- /dev/null
+++ b/src/debrid-collector/GlobalUsings.cs
@@ -0,0 +1,20 @@
+// Global using directives
+
+global using System.Text.Json;
+global using System.Text.Json.Serialization;
+global using System.Threading.Channels;
+global using DebridCollector.Extensions;
+global using DebridCollector.Features.Debrid;
+global using DebridCollector.Features.Worker;
+global using MassTransit;
+global using MassTransit.Mediator;
+global using Microsoft.AspNetCore.Builder;
+global using Microsoft.Extensions.DependencyInjection;
+global using Polly;
+global using Polly.Extensions.Http;
+global using PromKnight.ParseTorrentTitle;
+global using SharedContracts.Configuration;
+global using SharedContracts.Dapper;
+global using SharedContracts.Extensions;
+global using SharedContracts.Models;
+global using SharedContracts.Requests;
\ No newline at end of file
diff --git a/src/debrid-collector/Program.cs b/src/debrid-collector/Program.cs
new file mode 100644
index 0000000..04d682b
--- /dev/null
+++ b/src/debrid-collector/Program.cs
@@ -0,0 +1,17 @@
+var builder = WebApplication.CreateBuilder();
+
+builder.DisableIpPortBinding();
+
+builder.Configuration
+ .AddServiceConfiguration();
+
+builder.Host
+ .SetupSerilog(builder.Configuration);
+
+builder.Services
+ .AddServiceConfiguration()
+ .AddDatabase()
+ .RegisterMassTransit();
+
+var app = builder.Build();
+app.Run();
diff --git a/src/metadata/Extensions/ServiceCollectionExtensions.cs b/src/metadata/Extensions/ServiceCollectionExtensions.cs
index ef92737..1971d49 100644
--- a/src/metadata/Extensions/ServiceCollectionExtensions.cs
+++ b/src/metadata/Extensions/ServiceCollectionExtensions.cs
@@ -9,22 +9,29 @@ public static class ServiceCollectionExtensions
return services;
}
- internal static IServiceCollection AddMongoDb(this IServiceCollection services)
+ internal static IServiceCollection AddDatabase(this IServiceCollection services)
{
- services.LoadConfigurationFromEnv();
- services.AddTransient();
-
+ services.LoadConfigurationFromEnv();
+ services.AddScoped();
+
return services;
}
-
- internal static IServiceCollection AddJobSupport(this IServiceCollection services)
+
+ internal static IServiceCollection AddImporters(this IServiceCollection services)
{
- services.LoadConfigurationFromEnv();
-
- services.AddScheduler()
- .AddTransient()
- .AddHostedService();
-
+ services.AddScoped, BasicsFile>();
+ services.AddScoped, AkasFile>();
+ services.AddScoped, EpisodesFile>();
+
+ return services;
+ }
+
+ internal static IServiceCollection AddServiceConfiguration(this IServiceCollection services)
+ {
+ services.LoadConfigurationFromEnv();
+ services.AddScoped();
+ services.AddHostedService();
+
return services;
}
}
diff --git a/src/metadata/Extensions/WebApplicationBuilderExtensions.cs b/src/metadata/Extensions/WebApplicationBuilderExtensions.cs
index 41d869d..897460d 100644
--- a/src/metadata/Extensions/WebApplicationBuilderExtensions.cs
+++ b/src/metadata/Extensions/WebApplicationBuilderExtensions.cs
@@ -12,6 +12,8 @@ internal static class WebApplicationBuilderExtensions
options =>
{
options.DefaultExecutionTimeout = 6.Hours();
+ options.CodeGeneration.TypeLoadMode = TypeLoadMode.Static;
+ options.Services.AssertAllExpectedPreBuiltTypesExistOnStartUp();
});
return builder;
diff --git a/src/metadata/Features/ClearExistingImdbData/ClearExistingImdbDataRequest.cs b/src/metadata/Features/ClearExistingImdbData/ClearExistingImdbDataRequest.cs
new file mode 100644
index 0000000..ce4866f
--- /dev/null
+++ b/src/metadata/Features/ClearExistingImdbData/ClearExistingImdbDataRequest.cs
@@ -0,0 +1,3 @@
+namespace Metadata.Features.ClearExistingImdbData;
+
+public record ClearExistingImdbDataRequest(string TitleBasicsFilePath, string TitleAkasFilePath, string EpisodesFilePath);
diff --git a/src/metadata/Features/ClearExistingImdbData/ClearExistingImdbDataRequestHandler.cs b/src/metadata/Features/ClearExistingImdbData/ClearExistingImdbDataRequestHandler.cs
new file mode 100644
index 0000000..fced625
--- /dev/null
+++ b/src/metadata/Features/ClearExistingImdbData/ClearExistingImdbDataRequestHandler.cs
@@ -0,0 +1,16 @@
+namespace Metadata.Features.ClearExistingImdbData;
+
+public class ClearExistingImdbDataRequestHandler(ILogger logger, ImdbDbService dbService)
+{
+ public async Task Handle(ClearExistingImdbDataRequest request, CancellationToken _)
+ {
+ logger.LogInformation("Clearing existing IMDB data from database");
+ await dbService.DropPgtrmIndex();
+ await dbService.TruncateTable(TableNames.EpisodesTable);
+ await dbService.TruncateTable(TableNames.AkasTable);
+ await dbService.TruncateTable(TableNames.MetadataTable, cascade: true);
+ logger.LogInformation("Existing IMDB data cleared from database");
+
+ return new(request.TitleBasicsFilePath, request.TitleAkasFilePath, request.EpisodesFilePath);
+ }
+}
diff --git a/src/metadata/Features/Configuration/JobConfiguration.cs b/src/metadata/Features/Configuration/JobConfiguration.cs
deleted file mode 100644
index 06a576c..0000000
--- a/src/metadata/Features/Configuration/JobConfiguration.cs
+++ /dev/null
@@ -1,13 +0,0 @@
-namespace Metadata.Features.Configuration;
-
-public class JobConfiguration
-{
- private const string Prefix = "METADATA";
- private const string DownloadImdbDataVariable = "DOWNLOAD_IMDB_DATA_SCHEDULE";
- private const string DownloadImdbDataOnceVariable = "DOWNLOAD_IMDB_DATA_ONCE";
- private const string InsertBatchSizeVariable = "INSERT_BATCH_SIZE";
-
- public int InsertBatchSize { get; init; } = Prefix.GetEnvironmentVariableAsInt(InsertBatchSizeVariable, 25_000);
- public string DownloadImdbCronSchedule { get; init; } = Prefix.GetOptionalEnvironmentVariableAsString(DownloadImdbDataVariable, CronExpressions.EveryHour);
- public bool DownloadImdbOnce { get; init; } = Prefix.GetEnvironmentVariableAsBool(DownloadImdbDataOnceVariable);
-}
diff --git a/src/metadata/Features/Configuration/MongoConfiguration.cs b/src/metadata/Features/Configuration/MongoConfiguration.cs
deleted file mode 100644
index 0b844a2..0000000
--- a/src/metadata/Features/Configuration/MongoConfiguration.cs
+++ /dev/null
@@ -1,20 +0,0 @@
-namespace Metadata.Features.Configuration;
-
-public class MongoConfiguration
-{
- private const string Prefix = "MONGODB";
- private const string HostVariable = "HOST";
- private const string PortVariable = "PORT";
- private const string DbVariable = "DB";
- private const string UsernameVariable = "USER";
- private const string PasswordVariable = "PASSWORD";
-
-
- private string Host { get; init; } = Prefix.GetRequiredEnvironmentVariableAsString(HostVariable);
- private int Port { get; init; } = Prefix.GetEnvironmentVariableAsInt(PortVariable, 27017);
- private string Username { get; init; } = Prefix.GetRequiredEnvironmentVariableAsString(UsernameVariable);
- private string Password { get; init; } = Prefix.GetRequiredEnvironmentVariableAsString(PasswordVariable);
- public string DbName { get; init; } = Prefix.GetRequiredEnvironmentVariableAsString(DbVariable);
-
- public string ConnectionString => $"mongodb://{Username}:{Password}@{Host}:{Port}/{DbName}?tls=false&directConnection=true&authSource=admin";
-}
diff --git a/src/producer/Features/DataProcessing/PostgresConfiguration.cs b/src/metadata/Features/Configuration/PostgresConfiguration.cs
similarity index 95%
rename from src/producer/Features/DataProcessing/PostgresConfiguration.cs
rename to src/metadata/Features/Configuration/PostgresConfiguration.cs
index a1d86aa..c7e465c 100644
--- a/src/producer/Features/DataProcessing/PostgresConfiguration.cs
+++ b/src/metadata/Features/Configuration/PostgresConfiguration.cs
@@ -1,4 +1,4 @@
-namespace Producer.Features.DataProcessing;
+namespace Metadata.Features.Configuration;
public class PostgresConfiguration
{
diff --git a/src/metadata/Features/Configuration/ServiceConfiguration.cs b/src/metadata/Features/Configuration/ServiceConfiguration.cs
new file mode 100644
index 0000000..7e4ca8e
--- /dev/null
+++ b/src/metadata/Features/Configuration/ServiceConfiguration.cs
@@ -0,0 +1,9 @@
+namespace Metadata.Features.Configuration;
+
+public class ServiceConfiguration
+{
+ private const string Prefix = "METADATA";
+ private const string InsertBatchSizeVariable = "INSERT_BATCH_SIZE";
+
+ public int InsertBatchSize { get; init; } = Prefix.GetEnvironmentVariableAsInt(InsertBatchSizeVariable, 25_000);
+}
diff --git a/src/metadata/Features/DeleteDownloadedImdbData/DeleteDownloadedImdbDataRequest.cs b/src/metadata/Features/DeleteDownloadedImdbData/DeleteDownloadedImdbDataRequest.cs
index 01d6fd1..3a4f1cc 100644
--- a/src/metadata/Features/DeleteDownloadedImdbData/DeleteDownloadedImdbDataRequest.cs
+++ b/src/metadata/Features/DeleteDownloadedImdbData/DeleteDownloadedImdbDataRequest.cs
@@ -1,3 +1,3 @@
namespace Metadata.Features.DeleteDownloadedImdbData;
-public record DeleteDownloadedImdbDataRequest(string FilePath);
+public record DeleteDownloadedImdbDataRequest(string TitleBasicsFilePath, string TitleAkasFilePath, string EpisodesFilePath);
diff --git a/src/metadata/Features/DeleteDownloadedImdbData/DeleteDownloadedImdbDataRequestHandler.cs b/src/metadata/Features/DeleteDownloadedImdbData/DeleteDownloadedImdbDataRequestHandler.cs
index bed5947..7bc6053 100644
--- a/src/metadata/Features/DeleteDownloadedImdbData/DeleteDownloadedImdbDataRequestHandler.cs
+++ b/src/metadata/Features/DeleteDownloadedImdbData/DeleteDownloadedImdbDataRequestHandler.cs
@@ -1,21 +1,23 @@
namespace Metadata.Features.DeleteDownloadedImdbData;
-public class DeleteDownloadedImdbDataRequestHandler(ILogger logger, JobConfiguration configuration)
+public class DeleteDownloadedImdbDataRequestHandler(ILogger logger)
{
public Task Handle(DeleteDownloadedImdbDataRequest request, CancellationToken _)
{
- logger.LogInformation("Deleting file {FilePath}", request.FilePath);
+ DeleteFile(request.TitleBasicsFilePath);
+ DeleteFile(request.TitleAkasFilePath);
+ DeleteFile(request.EpisodesFilePath);
+ logger.LogInformation("Processing Completed");
- File.Delete(request.FilePath);
-
- logger.LogInformation("File Deleted");
-
- if (configuration.DownloadImdbOnce)
- {
- logger.LogInformation("Processing Completed: Exiting application as DownloadImdbOnce is set to true");
- Environment.Exit(0);
- }
+ Environment.Exit(0);
return Task.CompletedTask;
}
+
+ private void DeleteFile(string file)
+ {
+ logger.LogInformation("Deleting file {FilePath}", file);
+ File.Delete(file);
+ logger.LogInformation("File Deleted");
+ }
}
diff --git a/src/metadata/Features/DownloadImdbData/DownloadImdbDataJob.cs b/src/metadata/Features/DownloadImdbData/DownloadImdbDataJob.cs
deleted file mode 100644
index d964141..0000000
--- a/src/metadata/Features/DownloadImdbData/DownloadImdbDataJob.cs
+++ /dev/null
@@ -1,8 +0,0 @@
-namespace Metadata.Features.DownloadImdbData;
-
-public class DownloadImdbDataJob(IMessageBus messageBus, JobConfiguration configuration) : BaseJob
-{
- public override bool IsScheduelable => !configuration.DownloadImdbOnce && !string.IsNullOrEmpty(configuration.DownloadImdbCronSchedule);
- public override string JobName => nameof(DownloadImdbDataJob);
- public override async Task Invoke() => await messageBus.SendAsync(new GetImdbDataRequest());
-}
diff --git a/src/metadata/Features/DownloadImdbData/GetImdbDataRequestHandler.cs b/src/metadata/Features/DownloadImdbData/GetImdbDataRequestHandler.cs
index 5f485b2..140cc60 100644
--- a/src/metadata/Features/DownloadImdbData/GetImdbDataRequestHandler.cs
+++ b/src/metadata/Features/DownloadImdbData/GetImdbDataRequestHandler.cs
@@ -1,30 +1,20 @@
namespace Metadata.Features.DownloadImdbData;
-public class GetImdbDataRequestHandler(IHttpClientFactory clientFactory, ILogger logger)
+public class GetImdbDataRequestHandler(IHttpClientFactory clientFactory, IImdbFileDownloader downloader, ILogger logger)
{
private const string TitleBasicsFileName = "title.basics.tsv";
+ private const string TitleAkasFileName = "title.akas.tsv";
+ private const string EpisodesFileName = "title.episode.tsv";
- public async Task Handle(GetImdbDataRequest _, CancellationToken cancellationToken)
+ public async Task Handle(GetImdbDataRequest _, CancellationToken cancellationToken)
{
logger.LogInformation("Downloading IMDB data");
var client = clientFactory.CreateClient("imdb-data");
- var response = await client.GetAsync($"{TitleBasicsFileName}.gz", cancellationToken);
+ var tempBasicsFile = await downloader.DownloadFileToTempPath(client, TitleBasicsFileName, cancellationToken);
+ var tempAkasFile = await downloader.DownloadFileToTempPath(client, TitleAkasFileName, cancellationToken);
+ var tempEpisodesFile = await downloader.DownloadFileToTempPath(client, EpisodesFileName, cancellationToken);
- var tempFile = Path.Combine(Path.GetTempPath(), TitleBasicsFileName);
-
- response.EnsureSuccessStatusCode();
-
- await using var stream = await response.Content.ReadAsStreamAsync(cancellationToken);
- await using var gzipStream = new GZipStream(stream, CompressionMode.Decompress);
- await using var fileStream = File.Create(tempFile);
-
- await gzipStream.CopyToAsync(fileStream, cancellationToken);
-
- logger.LogInformation("Downloaded IMDB data to {TempFile}", tempFile);
-
- fileStream.Close();
-
- return new(tempFile);
+ return new(tempBasicsFile, tempAkasFile, tempEpisodesFile);
}
}
diff --git a/src/metadata/Features/DownloadImdbData/IImdbFileDownloader.cs b/src/metadata/Features/DownloadImdbData/IImdbFileDownloader.cs
new file mode 100644
index 0000000..f018d15
--- /dev/null
+++ b/src/metadata/Features/DownloadImdbData/IImdbFileDownloader.cs
@@ -0,0 +1,6 @@
+namespace Metadata.Features.DownloadImdbData;
+
+public interface IImdbFileDownloader
+{
+ Task DownloadFileToTempPath(HttpClient client, string fileName, CancellationToken cancellationToken);
+}
\ No newline at end of file
diff --git a/src/metadata/Features/DownloadImdbData/ImdbFileDownloader.cs b/src/metadata/Features/DownloadImdbData/ImdbFileDownloader.cs
new file mode 100644
index 0000000..332f42d
--- /dev/null
+++ b/src/metadata/Features/DownloadImdbData/ImdbFileDownloader.cs
@@ -0,0 +1,24 @@
+namespace Metadata.Features.DownloadImdbData;
+
+public class ImdbFileDownloader(ILogger logger) : IImdbFileDownloader
+{
+ public async Task DownloadFileToTempPath(HttpClient client, string fileName, CancellationToken cancellationToken)
+ {
+ var response = await client.GetAsync($"{fileName}.gz", cancellationToken);
+
+ var tempFile = Path.Combine(Path.GetTempPath(), fileName);
+
+ response.EnsureSuccessStatusCode();
+
+ await using var stream = await response.Content.ReadAsStreamAsync(cancellationToken);
+ await using var gzipStream = new GZipStream(stream, CompressionMode.Decompress);
+ await using var fileStream = File.Create(tempFile);
+
+ await gzipStream.CopyToAsync(fileStream, cancellationToken);
+
+ logger.LogInformation("Downloaded IMDB data '{Filename}' to {TempFile}", fileName, tempFile);
+
+ fileStream.Close();
+ return tempFile;
+ }
+}
\ No newline at end of file
diff --git a/src/metadata/Features/Files/AkasFile.cs b/src/metadata/Features/Files/AkasFile.cs
new file mode 100644
index 0000000..5f01997
--- /dev/null
+++ b/src/metadata/Features/Files/AkasFile.cs
@@ -0,0 +1,89 @@
+namespace Metadata.Features.Files;
+
+public class AkasFile(ILogger logger, ImdbDbService dbService) : IFileImport
+{
+ public async Task Import(string fileName, int batchSize, CancellationToken cancellationToken)
+ {
+ logger.LogInformation("Importing Downloaded IMDB AKAs data from {FilePath}", fileName);
+
+ var csvConfig = new CsvConfiguration(CultureInfo.InvariantCulture)
+ {
+ Delimiter = "\t",
+ BadDataFound = null, // Skip Bad Data from Imdb
+ MissingFieldFound = null, // Skip Missing Fields from Imdb
+ };
+
+ using var reader = new StreamReader(fileName);
+ using var csv = new CsvReader(reader, csvConfig);
+
+ var channel = Channel.CreateBounded(new BoundedChannelOptions(batchSize)
+ {
+ FullMode = BoundedChannelFullMode.Wait,
+ });
+
+ await csv.ReadAsync();
+
+ var batchInsertTask = CreateBatchOfAkaEntries(channel, batchSize, cancellationToken);
+
+ await ReadAkaEntries(csv, channel, cancellationToken);
+
+ channel.Writer.Complete();
+
+ await batchInsertTask;
+ }
+
+ private Task CreateBatchOfAkaEntries(Channel channel, int batchSize, CancellationToken cancellationToken) =>
+ Task.Run(async () =>
+ {
+ await foreach (var movieData in channel.Reader.ReadAllAsync(cancellationToken))
+ {
+ if (cancellationToken.IsCancellationRequested)
+ {
+ return;
+ }
+
+ var batch = new List
+ {
+ movieData,
+ };
+
+ while (batch.Count < batchSize && channel.Reader.TryRead(out var nextMovieData))
+ {
+ batch.Add(nextMovieData);
+ }
+
+ if (batch.Count > 0)
+ {
+ await dbService.InsertImdbAkaEntries(batch);
+ logger.LogInformation("Imported batch of {BatchSize} aka entries starting with ImdbId {FirstImdbId}", batch.Count, batch.First().ImdbId);
+ }
+ }
+ }, cancellationToken);
+
+ private static async Task ReadAkaEntries(CsvReader csv, Channel channel, CancellationToken cancellationToken)
+ {
+ while (await csv.ReadAsync())
+ {
+ var data = new ImdbAkaEntry
+ {
+ ImdbId = csv.GetField(0),
+ Ordering = csv.GetField(1),
+ LocalizedTitle = csv.GetField(2),
+ Region = csv.GetField(3),
+ Language = csv.GetField(4),
+ Types = csv.GetField(5),
+ Attributes = csv.GetField(6),
+ };
+
+ var isOriginalTitle = int.TryParse(csv.GetField(7), out var original);
+ data.IsOriginalTitle = isOriginalTitle && original == 1;
+
+ if (cancellationToken.IsCancellationRequested)
+ {
+ return;
+ }
+
+ await channel.Writer.WriteAsync(data, cancellationToken);
+ }
+ }
+}
\ No newline at end of file
diff --git a/src/metadata/Features/Files/BasicsFile.cs b/src/metadata/Features/Files/BasicsFile.cs
new file mode 100644
index 0000000..c55a610
--- /dev/null
+++ b/src/metadata/Features/Files/BasicsFile.cs
@@ -0,0 +1,86 @@
+namespace Metadata.Features.Files;
+
+public class BasicsFile(ILogger logger, ImdbDbService dbService): IFileImport
+{
+ public async Task Import(string fileName, int batchSize, CancellationToken cancellationToken)
+ {
+ logger.LogInformation("Importing Downloaded IMDB Basics data from {FilePath}", fileName);
+
+ var csvConfig = new CsvConfiguration(CultureInfo.InvariantCulture)
+ {
+ Delimiter = "\t",
+ BadDataFound = null, // Skip Bad Data from Imdb
+ MissingFieldFound = null, // Skip Missing Fields from Imdb
+ };
+
+ using var reader = new StreamReader(fileName);
+ using var csv = new CsvReader(reader, csvConfig);
+
+ var channel = Channel.CreateBounded(new BoundedChannelOptions(batchSize)
+ {
+ FullMode = BoundedChannelFullMode.Wait,
+ });
+
+ await csv.ReadAsync();
+
+ var batchInsertTask = CreateBatchOfBasicEntries(channel, batchSize, cancellationToken);
+
+ await ReadBasicEntries(csv, channel, cancellationToken);
+
+ channel.Writer.Complete();
+
+ await batchInsertTask;
+ }
+
+ private Task CreateBatchOfBasicEntries(Channel channel, int batchSize, CancellationToken cancellationToken) =>
+ Task.Run(async () =>
+ {
+ await foreach (var movieData in channel.Reader.ReadAllAsync(cancellationToken))
+ {
+ if (cancellationToken.IsCancellationRequested)
+ {
+ return;
+ }
+
+ var batch = new List
+ {
+ movieData,
+ };
+
+ while (batch.Count < batchSize && channel.Reader.TryRead(out var nextMovieData))
+ {
+ batch.Add(nextMovieData);
+ }
+
+ if (batch.Count > 0)
+ {
+ await dbService.InsertImdbEntries(batch);
+ logger.LogInformation("Imported batch of {BatchSize} basics starting with ImdbId {FirstImdbId}", batch.Count, batch.First().ImdbId);
+ }
+ }
+ }, cancellationToken);
+
+ private static async Task ReadBasicEntries(CsvReader csv, Channel channel, CancellationToken cancellationToken)
+ {
+ while (await csv.ReadAsync())
+ {
+ var isAdultSet = int.TryParse(csv.GetField(4), out var adult);
+
+ var movieData = new ImdbBasicEntry
+ {
+ ImdbId = csv.GetField(0),
+ Category = csv.GetField(1),
+ Title = csv.GetField(2),
+ Adult = isAdultSet && adult == 1,
+ Year = csv.GetField(5),
+ };
+
+ if (cancellationToken.IsCancellationRequested)
+ {
+ return;
+ }
+
+ await channel.Writer.WriteAsync(movieData, cancellationToken);
+ }
+ }
+}
\ No newline at end of file
diff --git a/src/metadata/Features/Files/EpisodesFile.cs b/src/metadata/Features/Files/EpisodesFile.cs
new file mode 100644
index 0000000..9a6573c
--- /dev/null
+++ b/src/metadata/Features/Files/EpisodesFile.cs
@@ -0,0 +1,83 @@
+namespace Metadata.Features.Files;
+
+public class EpisodesFile(ILogger logger, ImdbDbService dbService): IFileImport
+{
+ public async Task Import(string fileName, int batchSize, CancellationToken cancellationToken)
+ {
+ logger.LogInformation("Importing Downloaded IMDB Episodes data from {FilePath}", fileName);
+
+ var csvConfig = new CsvConfiguration(CultureInfo.InvariantCulture)
+ {
+ Delimiter = "\t",
+ BadDataFound = null, // Skip Bad Data from Imdb
+ MissingFieldFound = null, // Skip Missing Fields from Imdb
+ };
+
+ using var reader = new StreamReader(fileName);
+ using var csv = new CsvReader(reader, csvConfig);
+
+ var channel = Channel.CreateBounded(new BoundedChannelOptions(batchSize)
+ {
+ FullMode = BoundedChannelFullMode.Wait,
+ });
+
+ await csv.ReadAsync();
+
+ var batchInsertTask = CreateBatchOfAkaEntries(channel, batchSize, cancellationToken);
+
+ await ReadAkaEntries(csv, channel, cancellationToken);
+
+ channel.Writer.Complete();
+
+ await batchInsertTask;
+ }
+
+ private Task CreateBatchOfAkaEntries(Channel channel, int batchSize, CancellationToken cancellationToken) =>
+ Task.Run(async () =>
+ {
+ await foreach (var movieData in channel.Reader.ReadAllAsync(cancellationToken))
+ {
+ if (cancellationToken.IsCancellationRequested)
+ {
+ return;
+ }
+
+ var batch = new List
+ {
+ movieData,
+ };
+
+ while (batch.Count < batchSize && channel.Reader.TryRead(out var nextMovieData))
+ {
+ batch.Add(nextMovieData);
+ }
+
+ if (batch.Count > 0)
+ {
+ await dbService.InsertImdbEpisodeEntries(batch);
+ logger.LogInformation("Imported batch of {BatchSize} episodes starting with ImdbId {FirstImdbId}", batch.Count, batch.First().EpisodeImdbId);
+ }
+ }
+ }, cancellationToken);
+
+ private static async Task ReadAkaEntries(CsvReader csv, Channel channel, CancellationToken cancellationToken)
+ {
+ while (await csv.ReadAsync())
+ {
+ var data = new ImdbEpisodeEntry
+ {
+ EpisodeImdbId = csv.GetField(0),
+ ParentImdbId = csv.GetField(1),
+ SeasonNumber = csv.GetField(2),
+ EpisodeNumber = csv.GetField(3),
+ };
+
+ if (cancellationToken.IsCancellationRequested)
+ {
+ return;
+ }
+
+ await channel.Writer.WriteAsync(data, cancellationToken);
+ }
+ }
+}
\ No newline at end of file
diff --git a/src/metadata/Features/Files/IFileImport.cs b/src/metadata/Features/Files/IFileImport.cs
new file mode 100644
index 0000000..d694c84
--- /dev/null
+++ b/src/metadata/Features/Files/IFileImport.cs
@@ -0,0 +1,6 @@
+namespace Metadata.Features.Files;
+
+public interface IFileImport
+{
+ Task Import(string fileName, int batchSize, CancellationToken cancellationToken);
+}
\ No newline at end of file
diff --git a/src/metadata/Features/Files/ImdbAkaEntry.cs b/src/metadata/Features/Files/ImdbAkaEntry.cs
new file mode 100644
index 0000000..de7aedd
--- /dev/null
+++ b/src/metadata/Features/Files/ImdbAkaEntry.cs
@@ -0,0 +1,13 @@
+namespace Metadata.Features.Files;
+
+public class ImdbAkaEntry
+{
+ public string ImdbId { get; set; } = default!;
+ public int Ordering { get; set; }
+ public string? LocalizedTitle { get; set; }
+ public string? Region { get; set; }
+ public string? Language { get; set; }
+ public string? Types { get; set; }
+ public string? Attributes { get; set; }
+ public bool IsOriginalTitle { get; set; }
+}
\ No newline at end of file
diff --git a/src/metadata/Features/Files/ImdbBasicEntry.cs b/src/metadata/Features/Files/ImdbBasicEntry.cs
new file mode 100644
index 0000000..c8b2cb1
--- /dev/null
+++ b/src/metadata/Features/Files/ImdbBasicEntry.cs
@@ -0,0 +1,10 @@
+namespace Metadata.Features.Files;
+
+public class ImdbBasicEntry
+{
+ public string ImdbId { get; set; } = default!;
+ public string? Category { get; set; }
+ public string? Title { get; set; }
+ public bool Adult { get; set; }
+ public string? Year { get; set; }
+}
\ No newline at end of file
diff --git a/src/metadata/Features/Files/ImdbEpisodeEntry.cs b/src/metadata/Features/Files/ImdbEpisodeEntry.cs
new file mode 100644
index 0000000..82f2408
--- /dev/null
+++ b/src/metadata/Features/Files/ImdbEpisodeEntry.cs
@@ -0,0 +1,9 @@
+namespace Metadata.Features.Files;
+
+public class ImdbEpisodeEntry
+{
+ public string EpisodeImdbId { get; set; } = default!;
+ public string? ParentImdbId { get; set; }
+ public string? SeasonNumber { get; set; }
+ public string? EpisodeNumber { get; set; }
+}
\ No newline at end of file
diff --git a/src/metadata/Features/ImportImdbData/ImdbDbService.cs b/src/metadata/Features/ImportImdbData/ImdbDbService.cs
new file mode 100644
index 0000000..88add91
--- /dev/null
+++ b/src/metadata/Features/ImportImdbData/ImdbDbService.cs
@@ -0,0 +1,174 @@
+namespace Metadata.Features.ImportImdbData;
+
+public class ImdbDbService(PostgresConfiguration configuration, ILogger logger)
+{
+ public Task InsertImdbEntries(IEnumerable entries) =>
+ ExecuteCommandAsync(
+ async connection =>
+ {
+ await using var writer = await connection.BeginBinaryImportAsync(
+ $"COPY {TableNames.MetadataTable} (\"imdb_id\", \"category\", \"title\", \"year\", \"adult\") FROM STDIN (FORMAT BINARY)");
+
+ foreach (var entry in entries)
+ {
+ try
+ {
+ await writer.StartRowAsync();
+ await writer.WriteAsync(entry.ImdbId, NpgsqlDbType.Text);
+ await writer.WriteAsync(entry.Category, NpgsqlDbType.Text);
+ await writer.WriteAsync(entry.Title, NpgsqlDbType.Text);
+ await writer.WriteAsync(entry.Year, NpgsqlDbType.Text);
+ await writer.WriteAsync(entry.Adult, NpgsqlDbType.Boolean);
+ }
+ catch (Npgsql.PostgresException e)
+ {
+ if (e.Message.Contains("duplicate key value violates unique constraint", StringComparison.OrdinalIgnoreCase))
+ {
+ continue;
+ }
+
+ throw;
+ }
+ }
+
+ await writer.CompleteAsync();
+ }, "Error while inserting imdb entries into database");
+
+ public Task InsertImdbAkaEntries(IEnumerable entries) =>
+ ExecuteCommandAsync(
+ async connection =>
+ {
+ await using var writer = await connection.BeginBinaryImportAsync(
+ $"COPY {TableNames.AkasTable} (\"imdb_id\", \"ordering\", \"localized_title\", \"region\", \"language\", \"types\", \"attributes\", \"is_original_title\") FROM STDIN (FORMAT BINARY)");
+
+ foreach (var entry in entries.Where(x=>x.LocalizedTitle?.Length <= 8000))
+ {
+ try
+ {
+ await writer.StartRowAsync();
+ await writer.WriteAsync(entry.ImdbId, NpgsqlDbType.Text);
+ await writer.WriteAsync(entry.Ordering, NpgsqlDbType.Integer);
+ await writer.WriteAsync(entry.LocalizedTitle, NpgsqlDbType.Text);
+ await writer.WriteAsync(entry.Region, NpgsqlDbType.Text);
+ await writer.WriteAsync(entry.Language, NpgsqlDbType.Text);
+ await writer.WriteAsync(entry.Types, NpgsqlDbType.Text);
+ await writer.WriteAsync(entry.Attributes, NpgsqlDbType.Text);
+ await writer.WriteAsync(entry.IsOriginalTitle, NpgsqlDbType.Boolean);
+
+ }
+ catch (PostgresException e)
+ {
+ if (e.Message.Contains("value too long for type character", StringComparison.OrdinalIgnoreCase))
+ {
+ continue;
+ }
+
+ throw;
+ }
+ }
+
+ await writer.CompleteAsync();
+ }, "Error while inserting imdb entries into database");
+
+ public Task InsertImdbEpisodeEntries(IEnumerable entries) =>
+ ExecuteCommandAsync(
+ async connection =>
+ {
+ await using var writer = await connection.BeginBinaryImportAsync(
+ $"COPY {TableNames.EpisodesTable} (\"episode_id\", \"parent_id\", \"season\", \"episode\") FROM STDIN (FORMAT BINARY)");
+
+ foreach (var entry in entries)
+ {
+ try
+ {
+ await writer.StartRowAsync();
+ await writer.WriteAsync(entry.EpisodeImdbId, NpgsqlDbType.Text);
+ await writer.WriteAsync(entry.ParentImdbId, NpgsqlDbType.Text);
+ await writer.WriteAsync(entry.SeasonNumber, NpgsqlDbType.Text);
+ await writer.WriteAsync(entry.EpisodeNumber, NpgsqlDbType.Text);
+
+ }
+ catch (PostgresException e)
+ {
+ if (e.Message.Contains("value too long for type character", StringComparison.OrdinalIgnoreCase))
+ {
+ continue;
+ }
+
+ throw;
+ }
+ }
+
+ await writer.CompleteAsync();
+ }, "Error while inserting imdb entries into database");
+
+ public Task TruncateTable(string table, bool cascade = false) =>
+ ExecuteCommandAsync(
+ async connection =>
+ {
+ var cascadeOption = cascade ? "CASCADE" : string.Empty;
+ logger.LogInformation("Truncating '{Table}' table", table);
+ await using var command = new NpgsqlCommand($"TRUNCATE TABLE {table} {cascadeOption}", connection);
+ await command.ExecuteNonQueryAsync();
+ }, $"Error while clearing '{table}' table");
+
+ public Task CreatePgtrmIndex() =>
+ ExecuteCommandAsync(
+ async connection =>
+ {
+ await using var command = new NpgsqlCommand($"CREATE INDEX title_gist ON {TableNames.MetadataTable} USING gist(title gist_trgm_ops)", connection);
+ await command.ExecuteNonQueryAsync();
+ }, "Error while creating index on imdb_metadata table");
+
+ public Task DropPgtrmIndex() =>
+ ExecuteCommandAsync(
+ async connection =>
+ {
+ logger.LogInformation("Dropping Trigrams index if it exists already");
+ await using var dropCommand = new NpgsqlCommand("DROP INDEX if exists title_gist", connection);
+ await dropCommand.ExecuteNonQueryAsync();
+ }, $"Error while dropping index on {TableNames.MetadataTable} table");
+
+
+ private async Task ExecuteCommandAsync(Func operation, string errorMessage)
+ {
+ try
+ {
+ await using var connection = CreateNpgsqlConnection();
+ await connection.OpenAsync();
+
+ await operation(connection);
+ }
+ catch (Exception e)
+ {
+ logger.LogError(e, errorMessage);
+ }
+ }
+
+ private NpgsqlConnection CreateNpgsqlConnection()
+ {
+ var connectionStringBuilder = new NpgsqlConnectionStringBuilder(configuration.StorageConnectionString)
+ {
+ CommandTimeout = 3000,
+ };
+
+ return new(connectionStringBuilder.ConnectionString);
+ }
+
+ private async Task ExecuteCommandWithTransactionAsync(Func operation, NpgsqlTransaction transaction, string errorMessage)
+ {
+ try
+ {
+ await operation(transaction.Connection, transaction);
+ }
+ catch (PostgresException)
+ {
+ await transaction.RollbackAsync();
+ throw;
+ }
+ catch (Exception e)
+ {
+ logger.LogError(e, errorMessage);
+ }
+ }
+}
\ No newline at end of file
diff --git a/src/metadata/Features/ImportImdbData/ImdbEntry.cs b/src/metadata/Features/ImportImdbData/ImdbEntry.cs
deleted file mode 100644
index 7d1ba90..0000000
--- a/src/metadata/Features/ImportImdbData/ImdbEntry.cs
+++ /dev/null
@@ -1,15 +0,0 @@
-namespace Metadata.Features.ImportImdbData;
-
-public class ImdbEntry
-{
- [BsonId]
- public string ImdbId { get; set; } = default!;
- public string? TitleType { get; set; }
- public string? PrimaryTitle { get; set; }
- public string? OriginalTitle { get; set; }
- public string? IsAdult { get; set; }
- public string? StartYear { get; set; }
- public string? EndYear { get; set; }
- public string? RuntimeMinutes { get; set; }
- public string? Genres { get; set; }
-}
diff --git a/src/metadata/Features/ImportImdbData/ImdbMongoDbService.cs b/src/metadata/Features/ImportImdbData/ImdbMongoDbService.cs
deleted file mode 100644
index 415d1e1..0000000
--- a/src/metadata/Features/ImportImdbData/ImdbMongoDbService.cs
+++ /dev/null
@@ -1,64 +0,0 @@
-namespace Metadata.Features.ImportImdbData;
-
-public class ImdbMongoDbService
-{
- private readonly ILogger _logger;
- private readonly IMongoCollection _imdbCollection;
-
- public ImdbMongoDbService(MongoConfiguration configuration, ILogger logger)
- {
- _logger = logger;
-
- var client = new MongoClient(configuration.ConnectionString);
- var database = client.GetDatabase(configuration.DbName);
-
- _imdbCollection = database.GetCollection("imdb-entries");
- }
-
- public async Task InsertImdbEntries(IEnumerable entries)
- {
- var operations = new List>();
-
- foreach (var entry in entries)
- {
- var filter = Builders.Filter.Eq(e => e.ImdbId, entry.ImdbId);
- var update = Builders.Update
- .SetOnInsert(e => e.TitleType, entry.TitleType)
- .SetOnInsert(e => e.PrimaryTitle, entry.PrimaryTitle)
- .SetOnInsert(e => e.OriginalTitle, entry.OriginalTitle)
- .SetOnInsert(e => e.IsAdult, entry.IsAdult)
- .SetOnInsert(e => e.StartYear, entry.StartYear)
- .SetOnInsert(e => e.EndYear, entry.EndYear)
- .SetOnInsert(e => e.RuntimeMinutes, entry.RuntimeMinutes)
- .SetOnInsert(e => e.Genres, entry.Genres);
-
- operations.Add(new UpdateOneModel(filter, update) { IsUpsert = true });
- }
-
- await _imdbCollection.BulkWriteAsync(operations);
- }
-
- public bool IsDatabaseInitialized()
- {
- try
- {
- // Create compound index for PrimaryTitle, TitleType, and StartYear
- var indexKeysDefinition = Builders.IndexKeys
- .Text(e => e.PrimaryTitle)
- .Ascending(e => e.TitleType)
- .Ascending(e => e.StartYear);
-
- var createIndexOptions = new CreateIndexOptions { Background = true };
- var indexModel = new CreateIndexModel(indexKeysDefinition, createIndexOptions);
-
- _imdbCollection.Indexes.CreateOne(indexModel);
-
- return true;
- }
- catch (Exception e)
- {
- _logger.LogError(e, "Error initializing database");
- return false;
- }
- }
-}
diff --git a/src/metadata/Features/ImportImdbData/ImportImdbDataRequest.cs b/src/metadata/Features/ImportImdbData/ImportImdbDataRequest.cs
index 7d50247..4371b13 100644
--- a/src/metadata/Features/ImportImdbData/ImportImdbDataRequest.cs
+++ b/src/metadata/Features/ImportImdbData/ImportImdbDataRequest.cs
@@ -1,3 +1,3 @@
namespace Metadata.Features.ImportImdbData;
-public record ImportImdbDataRequest(string FilePath);
+public record ImportImdbDataRequest(string TitleBasicsFilePath, string TitleAkasFilePath, string EpisodesFilePath);
diff --git a/src/metadata/Features/ImportImdbData/ImportImdbDataRequestHandler.cs b/src/metadata/Features/ImportImdbData/ImportImdbDataRequestHandler.cs
index cb1c0d1..584e2e6 100644
--- a/src/metadata/Features/ImportImdbData/ImportImdbDataRequestHandler.cs
+++ b/src/metadata/Features/ImportImdbData/ImportImdbDataRequestHandler.cs
@@ -1,92 +1,17 @@
namespace Metadata.Features.ImportImdbData;
-public class ImportImdbDataRequestHandler(ILogger logger, ImdbMongoDbService mongoDbService, JobConfiguration configuration)
+public class ImportImdbDataRequestHandler(
+ ServiceConfiguration configuration,
+ IFileImport basicsFile,
+ IFileImport akasFile,
+ IFileImport episodesFile)
{
- public async Task Handle(ImportImdbDataRequest request, CancellationToken cancellationToken)
+ public async Task Handle(ImportImdbDataRequest request, CancellationToken cancellationToken)
{
- logger.LogInformation("Importing Downloaded IMDB data from {FilePath}", request.FilePath);
-
- var config = new CsvConfiguration(CultureInfo.InvariantCulture)
- {
- Delimiter = "\t",
- BadDataFound = null, // Skip Bad Data from Imdb
- MissingFieldFound = null, // Skip Missing Fields from Imdb
- };
-
- using var reader = new StreamReader(request.FilePath);
- using var csv = new CsvReader(reader, config);
-
- var channel = Channel.CreateBounded(new BoundedChannelOptions(configuration.InsertBatchSize)
- {
- FullMode = BoundedChannelFullMode.Wait,
- });
-
-
- // Skip the header row
- await csv.ReadAsync();
-
- var batchInsertTask = CreateBatchOfEntries(channel, cancellationToken);
-
- await ReadEntries(csv, channel, cancellationToken);
-
- channel.Writer.Complete();
-
- await batchInsertTask;
-
- return new(request.FilePath);
+ await basicsFile.Import(request.TitleBasicsFilePath, configuration.InsertBatchSize, cancellationToken);
+ await akasFile.Import(request.TitleAkasFilePath, configuration.InsertBatchSize, cancellationToken);
+ await episodesFile.Import(request.EpisodesFilePath, configuration.InsertBatchSize, cancellationToken);
+
+ return new(request.TitleBasicsFilePath, request.TitleAkasFilePath, request.EpisodesFilePath);
}
-
- private Task CreateBatchOfEntries(Channel channel, CancellationToken cancellationToken) =>
- Task.Run(async () =>
- {
- await foreach (var movieData in channel.Reader.ReadAllAsync(cancellationToken))
- {
- if (cancellationToken.IsCancellationRequested)
- {
- return;
- }
-
- var batch = new List
- {
- movieData,
- };
-
- while (batch.Count < configuration.InsertBatchSize && channel.Reader.TryRead(out var nextMovieData))
- {
- batch.Add(nextMovieData);
- }
-
- if (batch.Count > 0)
- {
- await mongoDbService.InsertImdbEntries(batch);
- logger.LogInformation("Imported batch of {BatchSize} starting with ImdbId {FirstImdbId}", batch.Count, batch.First().ImdbId);
- }
- }
- }, cancellationToken);
-
- private static async Task ReadEntries(CsvReader csv, Channel channel, CancellationToken cancellationToken)
- {
- while (await csv.ReadAsync())
- {
- var movieData = new ImdbEntry
- {
- ImdbId = csv.GetField(0),
- TitleType = csv.GetField(1),
- PrimaryTitle = csv.GetField(2),
- OriginalTitle = csv.GetField(3),
- IsAdult = csv.GetField(4),
- StartYear = csv.GetField(5),
- EndYear = csv.GetField(6),
- RuntimeMinutes = csv.GetField(7),
- Genres = csv.GetField(8),
- };
-
- if (cancellationToken.IsCancellationRequested)
- {
- return;
- }
-
- await channel.Writer.WriteAsync(movieData, cancellationToken);
- }
- }
-}
+}
\ No newline at end of file
diff --git a/src/metadata/Features/ImportImdbData/TableNames.cs b/src/metadata/Features/ImportImdbData/TableNames.cs
new file mode 100644
index 0000000..104b9da
--- /dev/null
+++ b/src/metadata/Features/ImportImdbData/TableNames.cs
@@ -0,0 +1,8 @@
+namespace Metadata.Features.ImportImdbData;
+
+public static class TableNames
+{
+ public const string MetadataTable = "imdb_metadata";
+ public const string EpisodesTable = "imdb_metadata_episodes";
+ public const string AkasTable = "imdb_metadata_akas";
+}
\ No newline at end of file
diff --git a/src/metadata/Features/IndexImdbData/IndexImdbDataRequest.cs b/src/metadata/Features/IndexImdbData/IndexImdbDataRequest.cs
new file mode 100644
index 0000000..df24cdb
--- /dev/null
+++ b/src/metadata/Features/IndexImdbData/IndexImdbDataRequest.cs
@@ -0,0 +1,3 @@
+namespace Metadata.Features.IndexImdbData;
+
+public record IndexImdbDataRequest(string TitleBasicsFilePath, string TitleAkasFilePath, string EpisodesFilePath);
diff --git a/src/metadata/Features/IndexImdbData/IndexImdbDataRequestHandler.cs b/src/metadata/Features/IndexImdbData/IndexImdbDataRequestHandler.cs
new file mode 100644
index 0000000..5ce0f83
--- /dev/null
+++ b/src/metadata/Features/IndexImdbData/IndexImdbDataRequestHandler.cs
@@ -0,0 +1,13 @@
+namespace Metadata.Features.IndexImdbData;
+
+public class IndexImdbDataRequestHandler(ILogger logger, ImdbDbService dbService)
+{
+ public async Task Handle(IndexImdbDataRequest request, CancellationToken _)
+ {
+ logger.LogInformation("Creating Trigram Indexes for IMDB data");
+
+ await dbService.CreatePgtrmIndex();
+
+ return new(request.TitleBasicsFilePath, request.TitleAkasFilePath, request.EpisodesFilePath);
+ }
+}
diff --git a/src/metadata/Features/Jobs/BaseJob.cs b/src/metadata/Features/Jobs/BaseJob.cs
deleted file mode 100644
index 6d5ad7a..0000000
--- a/src/metadata/Features/Jobs/BaseJob.cs
+++ /dev/null
@@ -1,10 +0,0 @@
-namespace Metadata.Features.Jobs;
-
-public abstract class BaseJob : IMetadataJob
-{
- public abstract bool IsScheduelable { get; }
-
- public abstract string JobName { get; }
-
- public abstract Task Invoke();
-}
diff --git a/src/metadata/Features/Jobs/DownloadImdbDataJob.cs b/src/metadata/Features/Jobs/DownloadImdbDataJob.cs
new file mode 100644
index 0000000..c9af150
--- /dev/null
+++ b/src/metadata/Features/Jobs/DownloadImdbDataJob.cs
@@ -0,0 +1,9 @@
+namespace Metadata.Features.Jobs;
+
+public class DownloadImdbDataJob(IMessageBus messageBus) : IHostedService
+{
+ public async Task StartAsync(CancellationToken cancellationToken) =>
+ await messageBus.SendAsync(new GetImdbDataRequest());
+
+ public Task StopAsync(CancellationToken cancellationToken) => Task.CompletedTask;
+}
diff --git a/src/metadata/Features/Jobs/IMetadataJob.cs b/src/metadata/Features/Jobs/IMetadataJob.cs
deleted file mode 100644
index 8e7d2b7..0000000
--- a/src/metadata/Features/Jobs/IMetadataJob.cs
+++ /dev/null
@@ -1,7 +0,0 @@
-namespace Metadata.Features.Jobs;
-
-public interface IMetadataJob : IInvocable
-{
- bool IsScheduelable { get; }
- string JobName { get; }
-}
diff --git a/src/metadata/Features/Jobs/JobScheduler.cs b/src/metadata/Features/Jobs/JobScheduler.cs
deleted file mode 100644
index 02c5120..0000000
--- a/src/metadata/Features/Jobs/JobScheduler.cs
+++ /dev/null
@@ -1,34 +0,0 @@
-namespace Metadata.Features.Jobs;
-
-public class JobScheduler(IServiceProvider serviceProvider) : IHostedService
-{
- public Task StartAsync(CancellationToken cancellationToken)
- {
- using var scope = serviceProvider.CreateAsyncScope();
-
- var mongoDbService = scope.ServiceProvider.GetRequiredService();
-
- if (!mongoDbService.IsDatabaseInitialized())
- {
- throw new InvalidOperationException("MongoDb is not initialized");
- }
-
- var jobConfigurations = scope.ServiceProvider.GetRequiredService();
- var downloadJob = scope.ServiceProvider.GetRequiredService();
-
- if (!downloadJob.IsScheduelable)
- {
- return downloadJob.Invoke();
- }
-
- var scheduler = scope.ServiceProvider.GetRequiredService();
-
- scheduler.Schedule()
- .Cron(jobConfigurations.DownloadImdbCronSchedule)
- .PreventOverlapping(nameof(downloadJob.JobName));
-
- return Task.CompletedTask;
- }
-
- public Task StopAsync(CancellationToken cancellationToken) => Task.CompletedTask;
-}
diff --git a/src/metadata/GlobalUsings.cs b/src/metadata/GlobalUsings.cs
index e6098da..09647b9 100644
--- a/src/metadata/GlobalUsings.cs
+++ b/src/metadata/GlobalUsings.cs
@@ -4,23 +4,26 @@ global using System.Globalization;
global using System.IO.Compression;
global using System.Text.Json;
global using System.Threading.Channels;
-global using Coravel;
-global using Coravel.Invocable;
-global using Coravel.Scheduling.Schedule.Interfaces;
global using CsvHelper;
global using CsvHelper.Configuration;
+global using JasperFx.CodeGeneration;
+global using JasperFx.CodeGeneration.Commands;
global using JasperFx.Core;
global using Metadata.Extensions;
+global using Metadata.Features.ClearExistingImdbData;
global using Metadata.Features.Configuration;
global using Metadata.Features.DeleteDownloadedImdbData;
global using Metadata.Features.DownloadImdbData;
+global using Metadata.Features.Files;
global using Metadata.Features.ImportImdbData;
+global using Metadata.Features.IndexImdbData;
global using Metadata.Features.Jobs;
global using Metadata.Features.Literals;
global using Microsoft.AspNetCore.Builder;
global using Microsoft.Extensions.DependencyInjection;
global using Microsoft.Extensions.DependencyInjection.Extensions;
-global using MongoDB.Bson.Serialization.Attributes;
-global using MongoDB.Driver;
+global using Npgsql;
+global using NpgsqlTypes;
+global using Oakton;
global using Serilog;
global using Wolverine;
diff --git a/src/metadata/Internal/Generated/WolverineHandlers/ClearExistingImdbDataRequestHandler2085209125.cs b/src/metadata/Internal/Generated/WolverineHandlers/ClearExistingImdbDataRequestHandler2085209125.cs
new file mode 100644
index 0000000..e91ac7c
--- /dev/null
+++ b/src/metadata/Internal/Generated/WolverineHandlers/ClearExistingImdbDataRequestHandler2085209125.cs
@@ -0,0 +1,47 @@
+//
+#pragma warning disable
+using Metadata.Features.Configuration;
+using Microsoft.Extensions.Logging;
+
+namespace Internal.Generated.WolverineHandlers
+{
+ // START: ClearExistingImdbDataRequestHandler2085209125
+ public class ClearExistingImdbDataRequestHandler2085209125 : Wolverine.Runtime.Handlers.MessageHandler
+ {
+ private readonly Microsoft.Extensions.Logging.ILogger _logger1;
+ private readonly Microsoft.Extensions.Logging.ILogger _logger2;
+ private readonly Metadata.Features.Configuration.PostgresConfiguration _postgresConfiguration;
+
+ public ClearExistingImdbDataRequestHandler2085209125(Microsoft.Extensions.Logging.ILogger __logger1, Microsoft.Extensions.Logging.ILogger __logger2, Metadata.Features.Configuration.PostgresConfiguration postgresConfiguration)
+ {
+ _logger1 = __logger1;
+ _logger2 = __logger2;
+ _postgresConfiguration = postgresConfiguration;
+ }
+
+
+
+ public override async System.Threading.Tasks.Task HandleAsync(Wolverine.Runtime.MessageContext context, System.Threading.CancellationToken cancellation)
+ {
+ var imdbDbService = new Metadata.Features.ImportImdbData.ImdbDbService(_postgresConfiguration, _logger2);
+ var clearExistingImdbDataRequestHandler = new Metadata.Features.ClearExistingImdbData.ClearExistingImdbDataRequestHandler(_logger1, imdbDbService);
+ // The actual message body
+ var clearExistingImdbDataRequest = (Metadata.Features.ClearExistingImdbData.ClearExistingImdbDataRequest)context.Envelope.Message;
+
+
+ // The actual message execution
+ var outgoing1 = await clearExistingImdbDataRequestHandler.Handle(clearExistingImdbDataRequest, cancellation).ConfigureAwait(false);
+
+
+ // Outgoing, cascaded message
+ await context.EnqueueCascadingAsync(outgoing1).ConfigureAwait(false);
+
+ }
+
+ }
+
+ // END: ClearExistingImdbDataRequestHandler2085209125
+
+
+}
+
diff --git a/src/metadata/Internal/Generated/WolverineHandlers/DeleteDownloadedImdbDataRequestHandler52235941.cs b/src/metadata/Internal/Generated/WolverineHandlers/DeleteDownloadedImdbDataRequestHandler52235941.cs
new file mode 100644
index 0000000..5b1e49d
--- /dev/null
+++ b/src/metadata/Internal/Generated/WolverineHandlers/DeleteDownloadedImdbDataRequestHandler52235941.cs
@@ -0,0 +1,37 @@
+//
+#pragma warning disable
+using Microsoft.Extensions.Logging;
+
+namespace Internal.Generated.WolverineHandlers
+{
+ // START: DeleteDownloadedImdbDataRequestHandler52235941
+ public class DeleteDownloadedImdbDataRequestHandler52235941 : Wolverine.Runtime.Handlers.MessageHandler
+ {
+ private readonly Microsoft.Extensions.Logging.ILogger _logger;
+
+ public DeleteDownloadedImdbDataRequestHandler52235941(Microsoft.Extensions.Logging.ILogger logger)
+ {
+ _logger = logger;
+ }
+
+
+
+ public override async System.Threading.Tasks.Task HandleAsync(Wolverine.Runtime.MessageContext context, System.Threading.CancellationToken cancellation)
+ {
+ var deleteDownloadedImdbDataRequestHandler = new Metadata.Features.DeleteDownloadedImdbData.DeleteDownloadedImdbDataRequestHandler(_logger);
+ // The actual message body
+ var deleteDownloadedImdbDataRequest = (Metadata.Features.DeleteDownloadedImdbData.DeleteDownloadedImdbDataRequest)context.Envelope.Message;
+
+
+ // The actual message execution
+ await deleteDownloadedImdbDataRequestHandler.Handle(deleteDownloadedImdbDataRequest, cancellation).ConfigureAwait(false);
+
+ }
+
+ }
+
+ // END: DeleteDownloadedImdbDataRequestHandler52235941
+
+
+}
+
diff --git a/src/metadata/Internal/Generated/WolverineHandlers/GetImdbDataRequestHandler1674247617.cs b/src/metadata/Internal/Generated/WolverineHandlers/GetImdbDataRequestHandler1674247617.cs
new file mode 100644
index 0000000..6a2e10c
--- /dev/null
+++ b/src/metadata/Internal/Generated/WolverineHandlers/GetImdbDataRequestHandler1674247617.cs
@@ -0,0 +1,47 @@
+//
+#pragma warning disable
+using Microsoft.Extensions.Logging;
+using System.Net.Http;
+
+namespace Internal.Generated.WolverineHandlers
+{
+ // START: GetImdbDataRequestHandler1674247617
+ public class GetImdbDataRequestHandler1674247617 : Wolverine.Runtime.Handlers.MessageHandler
+ {
+ private readonly Microsoft.Extensions.Logging.ILogger _logger2;
+ private readonly Microsoft.Extensions.Logging.ILogger _logger1;
+ private readonly System.Net.Http.IHttpClientFactory _httpClientFactory;
+
+ public GetImdbDataRequestHandler1674247617(Microsoft.Extensions.Logging.ILogger __logger2, Microsoft.Extensions.Logging.ILogger __logger1, System.Net.Http.IHttpClientFactory httpClientFactory)
+ {
+ _logger2 = __logger2;
+ _logger1 = __logger1;
+ _httpClientFactory = httpClientFactory;
+ }
+
+
+
+ public override async System.Threading.Tasks.Task HandleAsync(Wolverine.Runtime.MessageContext context, System.Threading.CancellationToken cancellation)
+ {
+ var imdbFileDownloader = new Metadata.Features.DownloadImdbData.ImdbFileDownloader(_logger1);
+ var getImdbDataRequestHandler = new Metadata.Features.DownloadImdbData.GetImdbDataRequestHandler(_httpClientFactory, imdbFileDownloader, _logger2);
+ // The actual message body
+ var getImdbDataRequest = (Metadata.Features.DownloadImdbData.GetImdbDataRequest)context.Envelope.Message;
+
+
+ // The actual message execution
+ var outgoing1 = await getImdbDataRequestHandler.Handle(getImdbDataRequest, cancellation).ConfigureAwait(false);
+
+
+ // Outgoing, cascaded message
+ await context.EnqueueCascadingAsync(outgoing1).ConfigureAwait(false);
+
+ }
+
+ }
+
+ // END: GetImdbDataRequestHandler1674247617
+
+
+}
+
diff --git a/src/metadata/Internal/Generated/WolverineHandlers/ImportImdbDataRequestHandler968947017.cs b/src/metadata/Internal/Generated/WolverineHandlers/ImportImdbDataRequestHandler968947017.cs
new file mode 100644
index 0000000..27fabcb
--- /dev/null
+++ b/src/metadata/Internal/Generated/WolverineHandlers/ImportImdbDataRequestHandler968947017.cs
@@ -0,0 +1,56 @@
+//
+#pragma warning disable
+using Metadata.Features.Configuration;
+using Microsoft.Extensions.Logging;
+
+namespace Internal.Generated.WolverineHandlers
+{
+ // START: ImportImdbDataRequestHandler968947017
+ public class ImportImdbDataRequestHandler968947017 : Wolverine.Runtime.Handlers.MessageHandler
+ {
+ private readonly Microsoft.Extensions.Logging.ILogger _logger4;
+ private readonly Microsoft.Extensions.Logging.ILogger _logger1;
+ private readonly Metadata.Features.Configuration.ServiceConfiguration _serviceConfiguration;
+ private readonly Microsoft.Extensions.Logging.ILogger _logger2;
+ private readonly Microsoft.Extensions.Logging.ILogger _logger3;
+ private readonly Metadata.Features.Configuration.PostgresConfiguration _postgresConfiguration;
+
+ public ImportImdbDataRequestHandler968947017(Microsoft.Extensions.Logging.ILogger __logger4, Microsoft.Extensions.Logging.ILogger __logger1, Metadata.Features.Configuration.ServiceConfiguration serviceConfiguration, Microsoft.Extensions.Logging.ILogger __logger2, Microsoft.Extensions.Logging.ILogger __logger3, Metadata.Features.Configuration.PostgresConfiguration postgresConfiguration)
+ {
+ _logger4 = __logger4;
+ _logger1 = __logger1;
+ _serviceConfiguration = serviceConfiguration;
+ _logger2 = __logger2;
+ _logger3 = __logger3;
+ _postgresConfiguration = postgresConfiguration;
+ }
+
+
+
+ public override async System.Threading.Tasks.Task HandleAsync(Wolverine.Runtime.MessageContext context, System.Threading.CancellationToken cancellation)
+ {
+ var imdbDbService = new Metadata.Features.ImportImdbData.ImdbDbService(_postgresConfiguration, _logger2);
+ var inline_episodesFile = new Metadata.Features.Files.EpisodesFile(_logger4, imdbDbService);
+ var inline_akasFile = new Metadata.Features.Files.AkasFile(_logger3, imdbDbService);
+ var inline_basicsFile = new Metadata.Features.Files.BasicsFile(_logger1, imdbDbService);
+ var importImdbDataRequestHandler = new Metadata.Features.ImportImdbData.ImportImdbDataRequestHandler(_serviceConfiguration, inline_basicsFile, inline_akasFile, inline_episodesFile);
+ // The actual message body
+ var importImdbDataRequest = (Metadata.Features.ImportImdbData.ImportImdbDataRequest)context.Envelope.Message;
+
+
+ // The actual message execution
+ var outgoing1 = await importImdbDataRequestHandler.Handle(importImdbDataRequest, cancellation).ConfigureAwait(false);
+
+
+ // Outgoing, cascaded message
+ await context.EnqueueCascadingAsync(outgoing1).ConfigureAwait(false);
+
+ }
+
+ }
+
+ // END: ImportImdbDataRequestHandler968947017
+
+
+}
+
diff --git a/src/metadata/Internal/Generated/WolverineHandlers/IndexImdbDataRequestHandler411355483.cs b/src/metadata/Internal/Generated/WolverineHandlers/IndexImdbDataRequestHandler411355483.cs
new file mode 100644
index 0000000..71f7cb5
--- /dev/null
+++ b/src/metadata/Internal/Generated/WolverineHandlers/IndexImdbDataRequestHandler411355483.cs
@@ -0,0 +1,47 @@
+//
+#pragma warning disable
+using Metadata.Features.Configuration;
+using Microsoft.Extensions.Logging;
+
+namespace Internal.Generated.WolverineHandlers
+{
+ // START: IndexImdbDataRequestHandler411355483
+ public class IndexImdbDataRequestHandler411355483 : Wolverine.Runtime.Handlers.MessageHandler
+ {
+ private readonly Microsoft.Extensions.Logging.ILogger _logger2;
+ private readonly Metadata.Features.Configuration.PostgresConfiguration _postgresConfiguration;
+ private readonly Microsoft.Extensions.Logging.ILogger _logger1;
+
+ public IndexImdbDataRequestHandler411355483(Microsoft.Extensions.Logging.ILogger __logger2, Metadata.Features.Configuration.PostgresConfiguration postgresConfiguration, Microsoft.Extensions.Logging.ILogger __logger1)
+ {
+ _logger2 = __logger2;
+ _postgresConfiguration = postgresConfiguration;
+ _logger1 = __logger1;
+ }
+
+
+
+ public override async System.Threading.Tasks.Task HandleAsync(Wolverine.Runtime.MessageContext context, System.Threading.CancellationToken cancellation)
+ {
+ var imdbDbService = new Metadata.Features.ImportImdbData.ImdbDbService(_postgresConfiguration, _logger2);
+ var indexImdbDataRequestHandler = new Metadata.Features.IndexImdbData.IndexImdbDataRequestHandler(_logger1, imdbDbService);
+ // The actual message body
+ var indexImdbDataRequest = (Metadata.Features.IndexImdbData.IndexImdbDataRequest)context.Envelope.Message;
+
+
+ // The actual message execution
+ var outgoing1 = await indexImdbDataRequestHandler.Handle(indexImdbDataRequest, cancellation).ConfigureAwait(false);
+
+
+ // Outgoing, cascaded message
+ await context.EnqueueCascadingAsync(outgoing1).ConfigureAwait(false);
+
+ }
+
+ }
+
+ // END: IndexImdbDataRequestHandler411355483
+
+
+}
+
diff --git a/src/metadata/Metadata.csproj b/src/metadata/Metadata.csproj
index 5769b47..7f17029 100644
--- a/src/metadata/Metadata.csproj
+++ b/src/metadata/Metadata.csproj
@@ -9,15 +9,15 @@
-
+
-
+
-
+
diff --git a/src/metadata/Program.cs b/src/metadata/Program.cs
index 8444cba..353a049 100644
--- a/src/metadata/Program.cs
+++ b/src/metadata/Program.cs
@@ -6,8 +6,10 @@ builder.SetupWolverine();
builder.Services
.AddHttpClients()
- .AddJobSupport();
+ .AddServiceConfiguration()
+ .AddDatabase()
+ .AddImporters();
var host = builder.Build();
-await host.RunAsync();
+return await host.RunOaktonCommands(args);
diff --git a/src/migrator/migrations/002_add_metadata.sql b/src/migrator/migrations/002_add_metadata.sql
new file mode 100644
index 0000000..7518a1d
--- /dev/null
+++ b/src/migrator/migrations/002_add_metadata.sql
@@ -0,0 +1,8 @@
+CREATE TABLE public.imdb_metadata (
+ imdb_id varchar(16) NOT NULL,
+ category varchar(50) NULL,
+ title varchar(1000) NULL,
+ "year" varchar(10) NULL,
+ adult boolean NULL,
+ CONSTRAINT imdb_metadata_pk PRIMARY KEY (imdb_id)
+);
\ No newline at end of file
diff --git a/src/migrator/migrations/003_enable_pgtrm.sql b/src/migrator/migrations/003_enable_pgtrm.sql
new file mode 100644
index 0000000..1e0ef53
--- /dev/null
+++ b/src/migrator/migrations/003_enable_pgtrm.sql
@@ -0,0 +1,2 @@
+CREATE EXTENSION if not exists pg_trgm;
+SET pg_trgm.similarity_threshold = 0.5;
\ No newline at end of file
diff --git a/src/migrator/migrations/004_imdb_metadata_query.sql b/src/migrator/migrations/004_imdb_metadata_query.sql
new file mode 100644
index 0000000..5ba7f72
--- /dev/null
+++ b/src/migrator/migrations/004_imdb_metadata_query.sql
@@ -0,0 +1,14 @@
+CREATE OR REPLACE FUNCTION search_imdb_meta(search_term TEXT, category_param TEXT DEFAULT NULL, year_param TEXT DEFAULT NULL, limit_param INT DEFAULT 10)
+RETURNS TABLE(imdb_id character varying(16), title character varying(1000),category character varying(50),year character varying(10), score REAL) AS $$
+BEGIN
+ RETURN QUERY
+ SELECT imdb_metadata.imdb_id, imdb_metadata.title, imdb_metadata.category, imdb_metadata.year, similarity(imdb_metadata.title, search_term) as score
+ FROM imdb_metadata
+ WHERE (imdb_metadata.title % search_term)
+ AND (imdb_metadata.adult = FALSE)
+ AND (category_param IS NULL OR imdb_metadata.category = category_param)
+ AND (year_param IS NULL OR imdb_metadata.year = year_param)
+ ORDER BY score DESC
+ LIMIT limit_param;
+END; $$
+LANGUAGE plpgsql;
\ No newline at end of file
diff --git a/src/migrator/migrations/005_add_metadata_akas.sql b/src/migrator/migrations/005_add_metadata_akas.sql
new file mode 100644
index 0000000..fa09854
--- /dev/null
+++ b/src/migrator/migrations/005_add_metadata_akas.sql
@@ -0,0 +1,14 @@
+CREATE TABLE public.imdb_metadata_akas (
+ imdb_id varchar(16) NOT NULL,
+ ordering integer NULL,
+ localized_title varchar(8000) NULL,
+ region varchar(10) NULL,
+ "language" varchar(100) NULL,
+ types varchar(200) NULL,
+ attributes varchar(200) NULL,
+ is_original_title boolean NULL,
+ CONSTRAINT fk_imdb_metadata_akas_imdb_id
+ FOREIGN KEY (imdb_id)
+ REFERENCES public.imdb_metadata(imdb_id)
+ ON DELETE CASCADE
+);
diff --git a/src/migrator/migrations/006_add_metadata_episodes.sql b/src/migrator/migrations/006_add_metadata_episodes.sql
new file mode 100644
index 0000000..59f5480
--- /dev/null
+++ b/src/migrator/migrations/006_add_metadata_episodes.sql
@@ -0,0 +1,10 @@
+CREATE TABLE public.imdb_metadata_episodes (
+ episode_id varchar(16) NOT NULL,
+ parent_id varchar(16) NOT NULL,
+ season varchar(10) NOT NULL,
+ episode varchar(10) NOT NULL,
+ CONSTRAINT fk_imdb_metadata_episodes_parent_id
+ FOREIGN KEY (parent_id)
+ REFERENCES public.imdb_metadata(imdb_id)
+ ON DELETE CASCADE
+);
diff --git a/src/migrator/migrations/007_add_is_integer_function.sql b/src/migrator/migrations/007_add_is_integer_function.sql
new file mode 100644
index 0000000..44d9cc9
--- /dev/null
+++ b/src/migrator/migrations/007_add_is_integer_function.sql
@@ -0,0 +1,8 @@
+CREATE OR REPLACE FUNCTION is_integer(s TEXT) RETURNS BOOLEAN AS $$
+BEGIN
+ PERFORM s::INTEGER;
+ RETURN true;
+EXCEPTION WHEN others THEN
+ RETURN false;
+END;
+$$ LANGUAGE plpgsql;
\ No newline at end of file
diff --git a/src/migrator/migrations/008_change_imdb_search_year_plus_minus_one.sql b/src/migrator/migrations/008_change_imdb_search_year_plus_minus_one.sql
new file mode 100644
index 0000000..08bf778
--- /dev/null
+++ b/src/migrator/migrations/008_change_imdb_search_year_plus_minus_one.sql
@@ -0,0 +1,20 @@
+CREATE OR REPLACE FUNCTION search_imdb_meta(search_term TEXT, category_param TEXT DEFAULT NULL, year_param TEXT DEFAULT NULL, limit_param INT DEFAULT 10)
+ RETURNS TABLE(imdb_id character varying(16), title character varying(1000),category character varying(50),year character varying(10), score REAL) AS $$
+DECLARE
+ year_int INT;
+BEGIN
+ IF year_param != '\N' THEN
+ year_int := CAST(year_param AS INT);
+ END IF;
+
+ RETURN QUERY
+ SELECT imdb_metadata.imdb_id, imdb_metadata.title, imdb_metadata.category, imdb_metadata.year, similarity(imdb_metadata.title, search_term) as score
+ FROM imdb_metadata
+ WHERE (imdb_metadata.title % search_term)
+ AND (imdb_metadata.adult = FALSE)
+ AND (category_param IS NULL OR imdb_metadata.category = category_param)
+ AND (year_param IS NULL OR (year_int IS NOT NULL AND is_integer(imdb_metadata.year) AND imdb_metadata.year::INT BETWEEN year_int - 1 AND year_int + 1) OR imdb_metadata.year = year_param)
+ ORDER BY score DESC
+ LIMIT limit_param;
+END; $$
+ LANGUAGE plpgsql;
\ No newline at end of file
diff --git a/src/node/consumer/.dockerignore b/src/node/consumer/.dockerignore
deleted file mode 100644
index 1b76f0d..0000000
--- a/src/node/consumer/.dockerignore
+++ /dev/null
@@ -1,16 +0,0 @@
-node_modules
-Dockerfile*
-docker-compose*
-.dockerignore
-.git
-.gitignore
-README.md
-LICENSE
-.vscode
-Makefile
-helm-charts
-.env
-.editorconfig
-.idea
-coverage*
-.eslint*
diff --git a/src/node/consumer/.eslintignore b/src/node/consumer/.eslintignore
deleted file mode 100644
index 48196bf..0000000
--- a/src/node/consumer/.eslintignore
+++ /dev/null
@@ -1,3 +0,0 @@
-dist/
-esbuild.ts
-jest.config.ts
diff --git a/src/node/consumer/.eslintrc b/src/node/consumer/.eslintrc
deleted file mode 100644
index 7ec3577..0000000
--- a/src/node/consumer/.eslintrc
+++ /dev/null
@@ -1,84 +0,0 @@
-{
- "root": true,
- "extends": [
- "eslint:recommended",
- "plugin:@typescript-eslint/recommended"
- ],
- "parser": "@typescript-eslint/parser",
- "parserOptions": {
- "project": [
- "./tsconfig.json"
- ]
- },
- "plugins": [
- "@typescript-eslint",
- "import",
- "import-helpers"
- ],
- "rules": {
- "default-case": "off",
- "import/no-duplicates": "error",
- "import/no-extraneous-dependencies": "error",
- "import/order": "off",
- "import-helpers/order-imports": [
- "warn",
- {
- "alphabetize": {
- "order": "asc"
- }
- }
- ],
- "lines-between-class-members": [
- "error",
- "always",
- {
- "exceptAfterSingleLine": true
- }
- ],
- "no-continue": "off",
- "no-param-reassign": "off",
- "no-plusplus": [
- "error",
- {
- "allowForLoopAfterthoughts": true
- }
- ],
- "no-restricted-syntax": "off",
- "no-unused-expressions": [
- "off",
- {
- "allowShortCircuit": true
- }
- ],
- "no-unused-vars": "off",
- "no-use-before-define": "off",
- "one-var": [
- "error",
- {
- "uninitialized": "consecutive"
- }
- ],
- "prefer-destructuring": "error",
- "@typescript-eslint/explicit-function-return-type": "error",
- "@typescript-eslint/consistent-type-assertions": [
- "error",
- {
- "assertionStyle": "as",
- "objectLiteralTypeAssertions": "never"
- }
- ]
- },
- "overrides": [
- {
- "files": [
- "*.test.ts"
- ],
- "rules": {
- "@typescript-eslint/consistent-type-assertions": "off",
- "@typescript-eslint/explicit-function-return-type": "off",
- "@typescript-eslint/no-explicit-any": "off",
- "@typescript-eslint/no-unused-vars": "off"
- }
- }
- ]
-}
diff --git a/src/node/consumer/.nvmrc b/src/node/consumer/.nvmrc
deleted file mode 100644
index 790e110..0000000
--- a/src/node/consumer/.nvmrc
+++ /dev/null
@@ -1 +0,0 @@
-v20.10.0
diff --git a/src/node/consumer/Dockerfile b/src/node/consumer/Dockerfile
deleted file mode 100644
index d52fbdd..0000000
--- a/src/node/consumer/Dockerfile
+++ /dev/null
@@ -1,34 +0,0 @@
-FROM node:lts-buster-slim as builder
-
-RUN apt update && apt install -y git procps && rm -rf /var/lib/apt/lists/*
-
-WORKDIR /app
-
-COPY package*.json ./
-RUN npm install
-COPY . .
-RUN npm run build
-RUN npm prune --omit=dev
-
-FROM node:lts-buster-slim
-
-# Install necessary packages, including procps
-RUN apt update && apt install -y git procps && rm -rf /var/lib/apt/lists/*
-
-WORKDIR /app
-
-COPY --from=builder /app ./
-
-ENV NODE_ENV production
-ENV NODE_OPTIONS "--no-deprecation"
-
-# CIS-DI-0001
-RUN useradd -d /home/consumer -m -s /bin/bash consumer
-# CIS-DI-0008
-RUN chmod u-s /usr/bin/wall /usr/bin/expiry /usr/bin/chage /usr/bin/passwd /usr/bin/gpasswd /usr/bin/chsh /usr/bin/newgrp /usr/bin/chfn /sbin/unix_chkpwd /bin/su /bin/mount /bin/umount /usr/bin/chage /usr/bin/expiry /usr/bin/wall
-USER consumer
-
-EXPOSE 7001
-ENTRYPOINT [ "node", "dist/main.cjs" ]
-HEALTHCHECK --interval=30s --timeout=30s --start-period=5s --retries=3 \
- CMD pgrep -x node > /dev/null || exit 1
diff --git a/src/node/consumer/esbuild.ts b/src/node/consumer/esbuild.ts
deleted file mode 100644
index 224ac84..0000000
--- a/src/node/consumer/esbuild.ts
+++ /dev/null
@@ -1,47 +0,0 @@
-import { build } from "esbuild";
-import { readFileSync, rmSync } from "fs";
-
-const start = Date.now();
-
-try {
- const outdir = "dist";
-
- rmSync(outdir, { recursive: true, force: true });
-
- build({
- bundle: true,
- entryPoints: [
- "./src/main.ts",
- ],
- keepNames: true,
- minify: true,
- outbase: "./src",
- outdir,
- outExtension: {
- ".js": ".cjs",
- },
- platform: "node",
- plugins: [
- {
- name: "populate-import-meta",
- setup: ({ onLoad }) => {
- onLoad({ filter: new RegExp(`${import.meta.dirname}/src/.*.(js|ts)$`) }, args => {
- const contents = readFileSync(args.path, "utf8");
-
- const transformedContents = contents
- .replace(/import\.meta/g, `{dirname:__dirname,filename:__filename}`)
- .replace(/import\.meta\.filename/g, "__filename")
- .replace(/import\.meta\.dirname/g, "__dirname");
-
- return { contents: transformedContents, loader: "default" };
- });
- },
- }
- ],
- }).then(() => {
- console.log("⚡ " + "\x1b[32m" + `Done in ${Date.now() - start}ms`);
- });
-} catch (e) {
- console.log(e);
- process.exit(1);
-}
diff --git a/src/node/consumer/jest.config.ts b/src/node/consumer/jest.config.ts
deleted file mode 100644
index 8d0689d..0000000
--- a/src/node/consumer/jest.config.ts
+++ /dev/null
@@ -1,14 +0,0 @@
-import { pathsToModuleNameMapper } from 'ts-jest';
-import { compilerOptions } from './tsconfig.json';
-
-export default {
- preset: 'ts-jest',
- testEnvironment: 'node',
- moduleNameMapper: pathsToModuleNameMapper(compilerOptions.paths, { prefix: '/src/' }),
- modulePaths: [
- ''
- ],
- transform: {
- '^.+\\.tsx?$': 'ts-jest',
- },
-};
diff --git a/src/node/consumer/package-lock.json b/src/node/consumer/package-lock.json
deleted file mode 100644
index 7945098..0000000
--- a/src/node/consumer/package-lock.json
+++ /dev/null
@@ -1,10094 +0,0 @@
-{
- "name": "consumer",
- "version": "0.0.1",
- "lockfileVersion": 3,
- "requires": true,
- "packages": {
- "": {
- "name": "consumer",
- "version": "0.0.1",
- "license": "MIT",
- "dependencies": {
- "@ctrl/video-filename-parser": "^5.2.0",
- "@tirke/node-cache-manager-mongodb": "^1.6.0",
- "amqplib": "^0.10.3",
- "axios": "^1.6.1",
- "bottleneck": "^2.19.5",
- "cache-manager": "^5.4.0",
- "fuse.js": "^7.0.0",
- "inversify": "^6.0.2",
- "magnet-uri": "^6.2.0",
- "moment": "^2.30.1",
- "mongoose": "^8.2.0",
- "name-to-imdb": "^3.0.4",
- "parse-torrent-title": "https://github.com/TheBeastLT/parse-torrent-title.git#022408972c2a040f846331a912a6a8487746a654",
- "pg": "^8.11.3",
- "pg-hstore": "^2.3.4",
- "pino": "^8.18.0",
- "reflect-metadata": "^0.2.1",
- "sequelize": "^6.36.0",
- "sequelize-typescript": "^2.1.6",
- "torrent-stream": "^1.2.1"
- },
- "devDependencies": {
- "@types/amqplib": "^0.10.4",
- "@types/jest": "^29.5.12",
- "@types/magnet-uri": "^5.1.5",
- "@types/node": "^20.11.16",
- "@types/pg": "^8.11.0",
- "@types/torrent-stream": "^0.0.9",
- "@types/validator": "^13.11.8",
- "@typescript-eslint/eslint-plugin": "^6.21.0",
- "@typescript-eslint/parser": "^6.21.0",
- "esbuild": "^0.20.0",
- "eslint": "^8.56.0",
- "eslint-plugin-import": "^2.29.1",
- "eslint-plugin-import-helpers": "^1.3.1",
- "jest": "^29.7.0",
- "msw": "^2.1.7",
- "pino-pretty": "^10.3.1",
- "ts-jest": "^29.1.2",
- "ts-node": "^10.9.2",
- "tsconfig-paths": "^4.2.0",
- "tsx": "^4.7.0",
- "typescript": "^5.3.3"
- }
- },
- "node_modules/@aashutoshrathi/word-wrap": {
- "version": "1.2.6",
- "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz",
- "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==",
- "dev": true,
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/@acuminous/bitsyntax": {
- "version": "0.1.2",
- "resolved": "https://registry.npmjs.org/@acuminous/bitsyntax/-/bitsyntax-0.1.2.tgz",
- "integrity": "sha512-29lUK80d1muEQqiUsSo+3A0yP6CdspgC95EnKBMi22Xlwt79i/En4Vr67+cXhU+cZjbti3TgGGC5wy1stIywVQ==",
- "dependencies": {
- "buffer-more-ints": "~1.0.0",
- "debug": "^4.3.4",
- "safe-buffer": "~5.1.2"
- },
- "engines": {
- "node": ">=0.8"
- }
- },
- "node_modules/@ampproject/remapping": {
- "version": "2.2.1",
- "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz",
- "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==",
- "dev": true,
- "dependencies": {
- "@jridgewell/gen-mapping": "^0.3.0",
- "@jridgewell/trace-mapping": "^0.3.9"
- },
- "engines": {
- "node": ">=6.0.0"
- }
- },
- "node_modules/@babel/code-frame": {
- "version": "7.23.5",
- "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.23.5.tgz",
- "integrity": "sha512-CgH3s1a96LipHCmSUmYFPwY7MNx8C3avkq7i4Wl3cfa662ldtUe4VM1TPXX70pfmrlWTb6jLqTYrZyT2ZTJBgA==",
- "dev": true,
- "dependencies": {
- "@babel/highlight": "^7.23.4",
- "chalk": "^2.4.2"
- },
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/code-frame/node_modules/ansi-styles": {
- "version": "3.2.1",
- "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz",
- "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==",
- "dev": true,
- "dependencies": {
- "color-convert": "^1.9.0"
- },
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/@babel/code-frame/node_modules/chalk": {
- "version": "2.4.2",
- "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
- "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
- "dev": true,
- "dependencies": {
- "ansi-styles": "^3.2.1",
- "escape-string-regexp": "^1.0.5",
- "supports-color": "^5.3.0"
- },
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/@babel/code-frame/node_modules/color-convert": {
- "version": "1.9.3",
- "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
- "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
- "dev": true,
- "dependencies": {
- "color-name": "1.1.3"
- }
- },
- "node_modules/@babel/code-frame/node_modules/color-name": {
- "version": "1.1.3",
- "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
- "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==",
- "dev": true
- },
- "node_modules/@babel/code-frame/node_modules/escape-string-regexp": {
- "version": "1.0.5",
- "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
- "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==",
- "dev": true,
- "engines": {
- "node": ">=0.8.0"
- }
- },
- "node_modules/@babel/code-frame/node_modules/has-flag": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
- "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==",
- "dev": true,
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/@babel/code-frame/node_modules/supports-color": {
- "version": "5.5.0",
- "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
- "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
- "dev": true,
- "dependencies": {
- "has-flag": "^3.0.0"
- },
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/@babel/compat-data": {
- "version": "7.23.5",
- "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.23.5.tgz",
- "integrity": "sha512-uU27kfDRlhfKl+w1U6vp16IuvSLtjAxdArVXPa9BvLkrr7CYIsxH5adpHObeAGY/41+syctUWOZ140a2Rvkgjw==",
- "dev": true,
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/core": {
- "version": "7.23.9",
- "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.23.9.tgz",
- "integrity": "sha512-5q0175NOjddqpvvzU+kDiSOAk4PfdO6FvwCWoQ6RO7rTzEe8vlo+4HVfcnAREhD4npMs0e9uZypjTwzZPCf/cw==",
- "dev": true,
- "dependencies": {
- "@ampproject/remapping": "^2.2.0",
- "@babel/code-frame": "^7.23.5",
- "@babel/generator": "^7.23.6",
- "@babel/helper-compilation-targets": "^7.23.6",
- "@babel/helper-module-transforms": "^7.23.3",
- "@babel/helpers": "^7.23.9",
- "@babel/parser": "^7.23.9",
- "@babel/template": "^7.23.9",
- "@babel/traverse": "^7.23.9",
- "@babel/types": "^7.23.9",
- "convert-source-map": "^2.0.0",
- "debug": "^4.1.0",
- "gensync": "^1.0.0-beta.2",
- "json5": "^2.2.3",
- "semver": "^6.3.1"
- },
- "engines": {
- "node": ">=6.9.0"
- },
- "funding": {
- "type": "opencollective",
- "url": "https://opencollective.com/babel"
- }
- },
- "node_modules/@babel/core/node_modules/semver": {
- "version": "6.3.1",
- "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
- "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
- "dev": true,
- "bin": {
- "semver": "bin/semver.js"
- }
- },
- "node_modules/@babel/generator": {
- "version": "7.23.6",
- "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.23.6.tgz",
- "integrity": "sha512-qrSfCYxYQB5owCmGLbl8XRpX1ytXlpueOb0N0UmQwA073KZxejgQTzAmJezxvpwQD9uGtK2shHdi55QT+MbjIw==",
- "dev": true,
- "dependencies": {
- "@babel/types": "^7.23.6",
- "@jridgewell/gen-mapping": "^0.3.2",
- "@jridgewell/trace-mapping": "^0.3.17",
- "jsesc": "^2.5.1"
- },
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/helper-compilation-targets": {
- "version": "7.23.6",
- "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.23.6.tgz",
- "integrity": "sha512-9JB548GZoQVmzrFgp8o7KxdgkTGm6xs9DW0o/Pim72UDjzr5ObUQ6ZzYPqA+g9OTS2bBQoctLJrky0RDCAWRgQ==",
- "dev": true,
- "dependencies": {
- "@babel/compat-data": "^7.23.5",
- "@babel/helper-validator-option": "^7.23.5",
- "browserslist": "^4.22.2",
- "lru-cache": "^5.1.1",
- "semver": "^6.3.1"
- },
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/helper-compilation-targets/node_modules/lru-cache": {
- "version": "5.1.1",
- "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz",
- "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==",
- "dev": true,
- "dependencies": {
- "yallist": "^3.0.2"
- }
- },
- "node_modules/@babel/helper-compilation-targets/node_modules/semver": {
- "version": "6.3.1",
- "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
- "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
- "dev": true,
- "bin": {
- "semver": "bin/semver.js"
- }
- },
- "node_modules/@babel/helper-compilation-targets/node_modules/yallist": {
- "version": "3.1.1",
- "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz",
- "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==",
- "dev": true
- },
- "node_modules/@babel/helper-environment-visitor": {
- "version": "7.22.20",
- "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.20.tgz",
- "integrity": "sha512-zfedSIzFhat/gFhWfHtgWvlec0nqB9YEIVrpuwjruLlXfUSnA8cJB0miHKwqDnQ7d32aKo2xt88/xZptwxbfhA==",
- "dev": true,
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/helper-function-name": {
- "version": "7.23.0",
- "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.23.0.tgz",
- "integrity": "sha512-OErEqsrxjZTJciZ4Oo+eoZqeW9UIiOcuYKRJA4ZAgV9myA+pOXhhmpfNCKjEH/auVfEYVFJ6y1Tc4r0eIApqiw==",
- "dev": true,
- "dependencies": {
- "@babel/template": "^7.22.15",
- "@babel/types": "^7.23.0"
- },
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/helper-hoist-variables": {
- "version": "7.22.5",
- "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.22.5.tgz",
- "integrity": "sha512-wGjk9QZVzvknA6yKIUURb8zY3grXCcOZt+/7Wcy8O2uctxhplmUPkOdlgoNhmdVee2c92JXbf1xpMtVNbfoxRw==",
- "dev": true,
- "dependencies": {
- "@babel/types": "^7.22.5"
- },
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/helper-module-imports": {
- "version": "7.22.15",
- "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.22.15.tgz",
- "integrity": "sha512-0pYVBnDKZO2fnSPCrgM/6WMc7eS20Fbok+0r88fp+YtWVLZrp4CkafFGIp+W0VKw4a22sgebPT99y+FDNMdP4w==",
- "dev": true,
- "dependencies": {
- "@babel/types": "^7.22.15"
- },
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/helper-module-transforms": {
- "version": "7.23.3",
- "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.23.3.tgz",
- "integrity": "sha512-7bBs4ED9OmswdfDzpz4MpWgSrV7FXlc3zIagvLFjS5H+Mk7Snr21vQ6QwrsoCGMfNC4e4LQPdoULEt4ykz0SRQ==",
- "dev": true,
- "dependencies": {
- "@babel/helper-environment-visitor": "^7.22.20",
- "@babel/helper-module-imports": "^7.22.15",
- "@babel/helper-simple-access": "^7.22.5",
- "@babel/helper-split-export-declaration": "^7.22.6",
- "@babel/helper-validator-identifier": "^7.22.20"
- },
- "engines": {
- "node": ">=6.9.0"
- },
- "peerDependencies": {
- "@babel/core": "^7.0.0"
- }
- },
- "node_modules/@babel/helper-plugin-utils": {
- "version": "7.22.5",
- "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.22.5.tgz",
- "integrity": "sha512-uLls06UVKgFG9QD4OeFYLEGteMIAa5kpTPcFL28yuCIIzsf6ZyKZMllKVOCZFhiZ5ptnwX4mtKdWCBE/uT4amg==",
- "dev": true,
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/helper-simple-access": {
- "version": "7.22.5",
- "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.22.5.tgz",
- "integrity": "sha512-n0H99E/K+Bika3++WNL17POvo4rKWZ7lZEp1Q+fStVbUi8nxPQEBOlTmCOxW/0JsS56SKKQ+ojAe2pHKJHN35w==",
- "dev": true,
- "dependencies": {
- "@babel/types": "^7.22.5"
- },
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/helper-split-export-declaration": {
- "version": "7.22.6",
- "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.22.6.tgz",
- "integrity": "sha512-AsUnxuLhRYsisFiaJwvp1QF+I3KjD5FOxut14q/GzovUe6orHLesW2C7d754kRm53h5gqrz6sFl6sxc4BVtE/g==",
- "dev": true,
- "dependencies": {
- "@babel/types": "^7.22.5"
- },
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/helper-string-parser": {
- "version": "7.23.4",
- "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.23.4.tgz",
- "integrity": "sha512-803gmbQdqwdf4olxrX4AJyFBV/RTr3rSmOj0rKwesmzlfhYNDEs+/iOcznzpNWlJlIlTJC2QfPFcHB6DlzdVLQ==",
- "dev": true,
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/helper-validator-identifier": {
- "version": "7.22.20",
- "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz",
- "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==",
- "dev": true,
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/helper-validator-option": {
- "version": "7.23.5",
- "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.23.5.tgz",
- "integrity": "sha512-85ttAOMLsr53VgXkTbkx8oA6YTfT4q7/HzXSLEYmjcSTJPMPQtvq1BD79Byep5xMUYbGRzEpDsjUf3dyp54IKw==",
- "dev": true,
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/helpers": {
- "version": "7.23.9",
- "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.23.9.tgz",
- "integrity": "sha512-87ICKgU5t5SzOT7sBMfCOZQ2rHjRU+Pcb9BoILMYz600W6DkVRLFBPwQ18gwUVvggqXivaUakpnxWQGbpywbBQ==",
- "dev": true,
- "dependencies": {
- "@babel/template": "^7.23.9",
- "@babel/traverse": "^7.23.9",
- "@babel/types": "^7.23.9"
- },
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/highlight": {
- "version": "7.23.4",
- "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.23.4.tgz",
- "integrity": "sha512-acGdbYSfp2WheJoJm/EBBBLh/ID8KDc64ISZ9DYtBmC8/Q204PZJLHyzeB5qMzJ5trcOkybd78M4x2KWsUq++A==",
- "dev": true,
- "dependencies": {
- "@babel/helper-validator-identifier": "^7.22.20",
- "chalk": "^2.4.2",
- "js-tokens": "^4.0.0"
- },
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/highlight/node_modules/ansi-styles": {
- "version": "3.2.1",
- "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz",
- "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==",
- "dev": true,
- "dependencies": {
- "color-convert": "^1.9.0"
- },
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/@babel/highlight/node_modules/chalk": {
- "version": "2.4.2",
- "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
- "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
- "dev": true,
- "dependencies": {
- "ansi-styles": "^3.2.1",
- "escape-string-regexp": "^1.0.5",
- "supports-color": "^5.3.0"
- },
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/@babel/highlight/node_modules/color-convert": {
- "version": "1.9.3",
- "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
- "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
- "dev": true,
- "dependencies": {
- "color-name": "1.1.3"
- }
- },
- "node_modules/@babel/highlight/node_modules/color-name": {
- "version": "1.1.3",
- "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
- "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==",
- "dev": true
- },
- "node_modules/@babel/highlight/node_modules/escape-string-regexp": {
- "version": "1.0.5",
- "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
- "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==",
- "dev": true,
- "engines": {
- "node": ">=0.8.0"
- }
- },
- "node_modules/@babel/highlight/node_modules/has-flag": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
- "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==",
- "dev": true,
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/@babel/highlight/node_modules/supports-color": {
- "version": "5.5.0",
- "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
- "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
- "dev": true,
- "dependencies": {
- "has-flag": "^3.0.0"
- },
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/@babel/parser": {
- "version": "7.23.9",
- "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.23.9.tgz",
- "integrity": "sha512-9tcKgqKbs3xGJ+NtKF2ndOBBLVwPjl1SHxPQkd36r3Dlirw3xWUeGaTbqr7uGZcTaxkVNwc+03SVP7aCdWrTlA==",
- "dev": true,
- "bin": {
- "parser": "bin/babel-parser.js"
- },
- "engines": {
- "node": ">=6.0.0"
- }
- },
- "node_modules/@babel/plugin-syntax-async-generators": {
- "version": "7.8.4",
- "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz",
- "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==",
- "dev": true,
- "dependencies": {
- "@babel/helper-plugin-utils": "^7.8.0"
- },
- "peerDependencies": {
- "@babel/core": "^7.0.0-0"
- }
- },
- "node_modules/@babel/plugin-syntax-bigint": {
- "version": "7.8.3",
- "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz",
- "integrity": "sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg==",
- "dev": true,
- "dependencies": {
- "@babel/helper-plugin-utils": "^7.8.0"
- },
- "peerDependencies": {
- "@babel/core": "^7.0.0-0"
- }
- },
- "node_modules/@babel/plugin-syntax-class-properties": {
- "version": "7.12.13",
- "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz",
- "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==",
- "dev": true,
- "dependencies": {
- "@babel/helper-plugin-utils": "^7.12.13"
- },
- "peerDependencies": {
- "@babel/core": "^7.0.0-0"
- }
- },
- "node_modules/@babel/plugin-syntax-import-meta": {
- "version": "7.10.4",
- "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz",
- "integrity": "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==",
- "dev": true,
- "dependencies": {
- "@babel/helper-plugin-utils": "^7.10.4"
- },
- "peerDependencies": {
- "@babel/core": "^7.0.0-0"
- }
- },
- "node_modules/@babel/plugin-syntax-json-strings": {
- "version": "7.8.3",
- "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz",
- "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==",
- "dev": true,
- "dependencies": {
- "@babel/helper-plugin-utils": "^7.8.0"
- },
- "peerDependencies": {
- "@babel/core": "^7.0.0-0"
- }
- },
- "node_modules/@babel/plugin-syntax-jsx": {
- "version": "7.23.3",
- "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.23.3.tgz",
- "integrity": "sha512-EB2MELswq55OHUoRZLGg/zC7QWUKfNLpE57m/S2yr1uEneIgsTgrSzXP3NXEsMkVn76OlaVVnzN+ugObuYGwhg==",
- "dev": true,
- "dependencies": {
- "@babel/helper-plugin-utils": "^7.22.5"
- },
- "engines": {
- "node": ">=6.9.0"
- },
- "peerDependencies": {
- "@babel/core": "^7.0.0-0"
- }
- },
- "node_modules/@babel/plugin-syntax-logical-assignment-operators": {
- "version": "7.10.4",
- "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz",
- "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==",
- "dev": true,
- "dependencies": {
- "@babel/helper-plugin-utils": "^7.10.4"
- },
- "peerDependencies": {
- "@babel/core": "^7.0.0-0"
- }
- },
- "node_modules/@babel/plugin-syntax-nullish-coalescing-operator": {
- "version": "7.8.3",
- "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz",
- "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==",
- "dev": true,
- "dependencies": {
- "@babel/helper-plugin-utils": "^7.8.0"
- },
- "peerDependencies": {
- "@babel/core": "^7.0.0-0"
- }
- },
- "node_modules/@babel/plugin-syntax-numeric-separator": {
- "version": "7.10.4",
- "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz",
- "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==",
- "dev": true,
- "dependencies": {
- "@babel/helper-plugin-utils": "^7.10.4"
- },
- "peerDependencies": {
- "@babel/core": "^7.0.0-0"
- }
- },
- "node_modules/@babel/plugin-syntax-object-rest-spread": {
- "version": "7.8.3",
- "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz",
- "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==",
- "dev": true,
- "dependencies": {
- "@babel/helper-plugin-utils": "^7.8.0"
- },
- "peerDependencies": {
- "@babel/core": "^7.0.0-0"
- }
- },
- "node_modules/@babel/plugin-syntax-optional-catch-binding": {
- "version": "7.8.3",
- "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz",
- "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==",
- "dev": true,
- "dependencies": {
- "@babel/helper-plugin-utils": "^7.8.0"
- },
- "peerDependencies": {
- "@babel/core": "^7.0.0-0"
- }
- },
- "node_modules/@babel/plugin-syntax-optional-chaining": {
- "version": "7.8.3",
- "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz",
- "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==",
- "dev": true,
- "dependencies": {
- "@babel/helper-plugin-utils": "^7.8.0"
- },
- "peerDependencies": {
- "@babel/core": "^7.0.0-0"
- }
- },
- "node_modules/@babel/plugin-syntax-top-level-await": {
- "version": "7.14.5",
- "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz",
- "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==",
- "dev": true,
- "dependencies": {
- "@babel/helper-plugin-utils": "^7.14.5"
- },
- "engines": {
- "node": ">=6.9.0"
- },
- "peerDependencies": {
- "@babel/core": "^7.0.0-0"
- }
- },
- "node_modules/@babel/plugin-syntax-typescript": {
- "version": "7.23.3",
- "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.23.3.tgz",
- "integrity": "sha512-9EiNjVJOMwCO+43TqoTrgQ8jMwcAd0sWyXi9RPfIsLTj4R2MADDDQXELhffaUx/uJv2AYcxBgPwH6j4TIA4ytQ==",
- "dev": true,
- "dependencies": {
- "@babel/helper-plugin-utils": "^7.22.5"
- },
- "engines": {
- "node": ">=6.9.0"
- },
- "peerDependencies": {
- "@babel/core": "^7.0.0-0"
- }
- },
- "node_modules/@babel/template": {
- "version": "7.23.9",
- "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.23.9.tgz",
- "integrity": "sha512-+xrD2BWLpvHKNmX2QbpdpsBaWnRxahMwJjO+KZk2JOElj5nSmKezyS1B4u+QbHMTX69t4ukm6hh9lsYQ7GHCKA==",
- "dev": true,
- "dependencies": {
- "@babel/code-frame": "^7.23.5",
- "@babel/parser": "^7.23.9",
- "@babel/types": "^7.23.9"
- },
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/traverse": {
- "version": "7.23.9",
- "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.23.9.tgz",
- "integrity": "sha512-I/4UJ9vs90OkBtY6iiiTORVMyIhJ4kAVmsKo9KFc8UOxMeUfi2hvtIBsET5u9GizXE6/GFSuKCTNfgCswuEjRg==",
- "dev": true,
- "dependencies": {
- "@babel/code-frame": "^7.23.5",
- "@babel/generator": "^7.23.6",
- "@babel/helper-environment-visitor": "^7.22.20",
- "@babel/helper-function-name": "^7.23.0",
- "@babel/helper-hoist-variables": "^7.22.5",
- "@babel/helper-split-export-declaration": "^7.22.6",
- "@babel/parser": "^7.23.9",
- "@babel/types": "^7.23.9",
- "debug": "^4.3.1",
- "globals": "^11.1.0"
- },
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@babel/traverse/node_modules/globals": {
- "version": "11.12.0",
- "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz",
- "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==",
- "dev": true,
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/@babel/types": {
- "version": "7.23.9",
- "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.23.9.tgz",
- "integrity": "sha512-dQjSq/7HaSjRM43FFGnv5keM2HsxpmyV1PfaSVm0nzzjwwTmjOe6J4bC8e3+pTEIgHaHj+1ZlLThRJ2auc/w1Q==",
- "dev": true,
- "dependencies": {
- "@babel/helper-string-parser": "^7.23.4",
- "@babel/helper-validator-identifier": "^7.22.20",
- "to-fast-properties": "^2.0.0"
- },
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/@bcoe/v8-coverage": {
- "version": "0.2.3",
- "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz",
- "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==",
- "dev": true
- },
- "node_modules/@bundled-es-modules/cookie": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/@bundled-es-modules/cookie/-/cookie-2.0.0.tgz",
- "integrity": "sha512-Or6YHg/kamKHpxULAdSqhGqnWFneIXu1NKvvfBBzKGwpVsYuFIQ5aBPHDnnoR3ghW1nvSkALd+EF9iMtY7Vjxw==",
- "dev": true,
- "dependencies": {
- "cookie": "^0.5.0"
- }
- },
- "node_modules/@bundled-es-modules/statuses": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/@bundled-es-modules/statuses/-/statuses-1.0.1.tgz",
- "integrity": "sha512-yn7BklA5acgcBr+7w064fGV+SGIFySjCKpqjcWgBAIfrAkY+4GQTJJHQMeT3V/sgz23VTEVV8TtOmkvJAhFVfg==",
- "dev": true,
- "dependencies": {
- "statuses": "^2.0.1"
- }
- },
- "node_modules/@cspotcode/source-map-support": {
- "version": "0.8.1",
- "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz",
- "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==",
- "dev": true,
- "dependencies": {
- "@jridgewell/trace-mapping": "0.3.9"
- },
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@cspotcode/source-map-support/node_modules/@jridgewell/trace-mapping": {
- "version": "0.3.9",
- "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz",
- "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==",
- "dev": true,
- "dependencies": {
- "@jridgewell/resolve-uri": "^3.0.3",
- "@jridgewell/sourcemap-codec": "^1.4.10"
- }
- },
- "node_modules/@ctrl/video-filename-parser": {
- "version": "5.2.0",
- "resolved": "https://registry.npmjs.org/@ctrl/video-filename-parser/-/video-filename-parser-5.2.0.tgz",
- "integrity": "sha512-6F9inbv+wXc82tG4jGcZX9j0YgpHyyF9dP+6M0GbWbQwLLwpgVcKs70DvmK7unE8cb6FFGlD/n1QDKk86mEJ7A==",
- "workspaces": [
- "demo"
- ],
- "engines": {
- "node": ">=18"
- }
- },
- "node_modules/@esbuild/aix-ppc64": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.20.0.tgz",
- "integrity": "sha512-fGFDEctNh0CcSwsiRPxiaqX0P5rq+AqE0SRhYGZ4PX46Lg1FNR6oCxJghf8YgY0WQEgQuh3lErUFE4KxLeRmmw==",
- "cpu": [
- "ppc64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "aix"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/android-arm": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.20.0.tgz",
- "integrity": "sha512-3bMAfInvByLHfJwYPJRlpTeaQA75n8C/QKpEaiS4HrFWFiJlNI0vzq/zCjBrhAYcPyVPG7Eo9dMrcQXuqmNk5g==",
- "cpu": [
- "arm"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "android"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/android-arm64": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.20.0.tgz",
- "integrity": "sha512-aVpnM4lURNkp0D3qPoAzSG92VXStYmoVPOgXveAUoQBWRSuQzt51yvSju29J6AHPmwY1BjH49uR29oyfH1ra8Q==",
- "cpu": [
- "arm64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "android"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/android-x64": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.20.0.tgz",
- "integrity": "sha512-uK7wAnlRvjkCPzh8jJ+QejFyrP8ObKuR5cBIsQZ+qbMunwR8sbd8krmMbxTLSrDhiPZaJYKQAU5Y3iMDcZPhyQ==",
- "cpu": [
- "x64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "android"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/darwin-arm64": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.20.0.tgz",
- "integrity": "sha512-AjEcivGAlPs3UAcJedMa9qYg9eSfU6FnGHJjT8s346HSKkrcWlYezGE8VaO2xKfvvlZkgAhyvl06OJOxiMgOYQ==",
- "cpu": [
- "arm64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "darwin"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/darwin-x64": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.20.0.tgz",
- "integrity": "sha512-bsgTPoyYDnPv8ER0HqnJggXK6RyFy4PH4rtsId0V7Efa90u2+EifxytE9pZnsDgExgkARy24WUQGv9irVbTvIw==",
- "cpu": [
- "x64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "darwin"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/freebsd-arm64": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.20.0.tgz",
- "integrity": "sha512-kQ7jYdlKS335mpGbMW5tEe3IrQFIok9r84EM3PXB8qBFJPSc6dpWfrtsC/y1pyrz82xfUIn5ZrnSHQQsd6jebQ==",
- "cpu": [
- "arm64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "freebsd"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/freebsd-x64": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.20.0.tgz",
- "integrity": "sha512-uG8B0WSepMRsBNVXAQcHf9+Ko/Tr+XqmK7Ptel9HVmnykupXdS4J7ovSQUIi0tQGIndhbqWLaIL/qO/cWhXKyQ==",
- "cpu": [
- "x64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "freebsd"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/linux-arm": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.20.0.tgz",
- "integrity": "sha512-2ezuhdiZw8vuHf1HKSf4TIk80naTbP9At7sOqZmdVwvvMyuoDiZB49YZKLsLOfKIr77+I40dWpHVeY5JHpIEIg==",
- "cpu": [
- "arm"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/linux-arm64": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.20.0.tgz",
- "integrity": "sha512-uTtyYAP5veqi2z9b6Gr0NUoNv9F/rOzI8tOD5jKcCvRUn7T60Bb+42NDBCWNhMjkQzI0qqwXkQGo1SY41G52nw==",
- "cpu": [
- "arm64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/linux-ia32": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.20.0.tgz",
- "integrity": "sha512-c88wwtfs8tTffPaoJ+SQn3y+lKtgTzyjkD8NgsyCtCmtoIC8RDL7PrJU05an/e9VuAke6eJqGkoMhJK1RY6z4w==",
- "cpu": [
- "ia32"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/linux-loong64": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.20.0.tgz",
- "integrity": "sha512-lR2rr/128/6svngnVta6JN4gxSXle/yZEZL3o4XZ6esOqhyR4wsKyfu6qXAL04S4S5CgGfG+GYZnjFd4YiG3Aw==",
- "cpu": [
- "loong64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/linux-mips64el": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.20.0.tgz",
- "integrity": "sha512-9Sycc+1uUsDnJCelDf6ZNqgZQoK1mJvFtqf2MUz4ujTxGhvCWw+4chYfDLPepMEvVL9PDwn6HrXad5yOrNzIsQ==",
- "cpu": [
- "mips64el"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/linux-ppc64": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.20.0.tgz",
- "integrity": "sha512-CoWSaaAXOZd+CjbUTdXIJE/t7Oz+4g90A3VBCHLbfuc5yUQU/nFDLOzQsN0cdxgXd97lYW/psIIBdjzQIwTBGw==",
- "cpu": [
- "ppc64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/linux-riscv64": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.20.0.tgz",
- "integrity": "sha512-mlb1hg/eYRJUpv8h/x+4ShgoNLL8wgZ64SUr26KwglTYnwAWjkhR2GpoKftDbPOCnodA9t4Y/b68H4J9XmmPzA==",
- "cpu": [
- "riscv64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/linux-s390x": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.20.0.tgz",
- "integrity": "sha512-fgf9ubb53xSnOBqyvWEY6ukBNRl1mVX1srPNu06B6mNsNK20JfH6xV6jECzrQ69/VMiTLvHMicQR/PgTOgqJUQ==",
- "cpu": [
- "s390x"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/linux-x64": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.20.0.tgz",
- "integrity": "sha512-H9Eu6MGse++204XZcYsse1yFHmRXEWgadk2N58O/xd50P9EvFMLJTQLg+lB4E1cF2xhLZU5luSWtGTb0l9UeSg==",
- "cpu": [
- "x64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/netbsd-x64": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.20.0.tgz",
- "integrity": "sha512-lCT675rTN1v8Fo+RGrE5KjSnfY0x9Og4RN7t7lVrN3vMSjy34/+3na0q7RIfWDAj0e0rCh0OL+P88lu3Rt21MQ==",
- "cpu": [
- "x64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "netbsd"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/openbsd-x64": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.20.0.tgz",
- "integrity": "sha512-HKoUGXz/TOVXKQ+67NhxyHv+aDSZf44QpWLa3I1lLvAwGq8x1k0T+e2HHSRvxWhfJrFxaaqre1+YyzQ99KixoA==",
- "cpu": [
- "x64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "openbsd"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/sunos-x64": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.20.0.tgz",
- "integrity": "sha512-GDwAqgHQm1mVoPppGsoq4WJwT3vhnz/2N62CzhvApFD1eJyTroob30FPpOZabN+FgCjhG+AgcZyOPIkR8dfD7g==",
- "cpu": [
- "x64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "sunos"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/win32-arm64": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.20.0.tgz",
- "integrity": "sha512-0vYsP8aC4TvMlOQYozoksiaxjlvUcQrac+muDqj1Fxy6jh9l9CZJzj7zmh8JGfiV49cYLTorFLxg7593pGldwQ==",
- "cpu": [
- "arm64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "win32"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/win32-ia32": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.20.0.tgz",
- "integrity": "sha512-p98u4rIgfh4gdpV00IqknBD5pC84LCub+4a3MO+zjqvU5MVXOc3hqR2UgT2jI2nh3h8s9EQxmOsVI3tyzv1iFg==",
- "cpu": [
- "ia32"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "win32"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@esbuild/win32-x64": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.20.0.tgz",
- "integrity": "sha512-NgJnesu1RtWihtTtXGFMU5YSE6JyyHPMxCwBZK7a6/8d31GuSo9l0Ss7w1Jw5QnKUawG6UEehs883kcXf5fYwg==",
- "cpu": [
- "x64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "win32"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/@eslint-community/eslint-utils": {
- "version": "4.4.0",
- "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz",
- "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==",
- "dev": true,
- "dependencies": {
- "eslint-visitor-keys": "^3.3.0"
- },
- "engines": {
- "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
- },
- "peerDependencies": {
- "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0"
- }
- },
- "node_modules/@eslint-community/regexpp": {
- "version": "4.10.0",
- "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.10.0.tgz",
- "integrity": "sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA==",
- "dev": true,
- "engines": {
- "node": "^12.0.0 || ^14.0.0 || >=16.0.0"
- }
- },
- "node_modules/@eslint/eslintrc": {
- "version": "2.1.4",
- "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz",
- "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==",
- "dev": true,
- "dependencies": {
- "ajv": "^6.12.4",
- "debug": "^4.3.2",
- "espree": "^9.6.0",
- "globals": "^13.19.0",
- "ignore": "^5.2.0",
- "import-fresh": "^3.2.1",
- "js-yaml": "^4.1.0",
- "minimatch": "^3.1.2",
- "strip-json-comments": "^3.1.1"
- },
- "engines": {
- "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
- },
- "funding": {
- "url": "https://opencollective.com/eslint"
- }
- },
- "node_modules/@eslint/eslintrc/node_modules/brace-expansion": {
- "version": "1.1.11",
- "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
- "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
- "dev": true,
- "dependencies": {
- "balanced-match": "^1.0.0",
- "concat-map": "0.0.1"
- }
- },
- "node_modules/@eslint/eslintrc/node_modules/minimatch": {
- "version": "3.1.2",
- "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
- "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
- "dev": true,
- "dependencies": {
- "brace-expansion": "^1.1.7"
- },
- "engines": {
- "node": "*"
- }
- },
- "node_modules/@eslint/js": {
- "version": "8.56.0",
- "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.56.0.tgz",
- "integrity": "sha512-gMsVel9D7f2HLkBma9VbtzZRehRogVRfbr++f06nL2vnCGCNlzOD+/MUov/F4p8myyAHspEhVobgjpX64q5m6A==",
- "dev": true,
- "engines": {
- "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
- }
- },
- "node_modules/@humanwhocodes/config-array": {
- "version": "0.11.14",
- "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.14.tgz",
- "integrity": "sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==",
- "dev": true,
- "dependencies": {
- "@humanwhocodes/object-schema": "^2.0.2",
- "debug": "^4.3.1",
- "minimatch": "^3.0.5"
- },
- "engines": {
- "node": ">=10.10.0"
- }
- },
- "node_modules/@humanwhocodes/config-array/node_modules/brace-expansion": {
- "version": "1.1.11",
- "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
- "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
- "dev": true,
- "dependencies": {
- "balanced-match": "^1.0.0",
- "concat-map": "0.0.1"
- }
- },
- "node_modules/@humanwhocodes/config-array/node_modules/minimatch": {
- "version": "3.1.2",
- "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
- "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
- "dev": true,
- "dependencies": {
- "brace-expansion": "^1.1.7"
- },
- "engines": {
- "node": "*"
- }
- },
- "node_modules/@humanwhocodes/module-importer": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz",
- "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==",
- "dev": true,
- "engines": {
- "node": ">=12.22"
- },
- "funding": {
- "type": "github",
- "url": "https://github.com/sponsors/nzakas"
- }
- },
- "node_modules/@humanwhocodes/object-schema": {
- "version": "2.0.2",
- "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.2.tgz",
- "integrity": "sha512-6EwiSjwWYP7pTckG6I5eyFANjPhmPjUX9JRLUSfNPC7FX7zK9gyZAfUEaECL6ALTpGX5AjnBq3C9XmVWPitNpw==",
- "dev": true
- },
- "node_modules/@istanbuljs/load-nyc-config": {
- "version": "1.1.0",
- "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz",
- "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==",
- "dev": true,
- "dependencies": {
- "camelcase": "^5.3.1",
- "find-up": "^4.1.0",
- "get-package-type": "^0.1.0",
- "js-yaml": "^3.13.1",
- "resolve-from": "^5.0.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/@istanbuljs/load-nyc-config/node_modules/argparse": {
- "version": "1.0.10",
- "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz",
- "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==",
- "dev": true,
- "dependencies": {
- "sprintf-js": "~1.0.2"
- }
- },
- "node_modules/@istanbuljs/load-nyc-config/node_modules/find-up": {
- "version": "4.1.0",
- "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz",
- "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==",
- "dev": true,
- "dependencies": {
- "locate-path": "^5.0.0",
- "path-exists": "^4.0.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/@istanbuljs/load-nyc-config/node_modules/js-yaml": {
- "version": "3.14.1",
- "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz",
- "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==",
- "dev": true,
- "dependencies": {
- "argparse": "^1.0.7",
- "esprima": "^4.0.0"
- },
- "bin": {
- "js-yaml": "bin/js-yaml.js"
- }
- },
- "node_modules/@istanbuljs/load-nyc-config/node_modules/locate-path": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz",
- "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==",
- "dev": true,
- "dependencies": {
- "p-locate": "^4.1.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/@istanbuljs/load-nyc-config/node_modules/p-limit": {
- "version": "2.3.0",
- "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz",
- "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==",
- "dev": true,
- "dependencies": {
- "p-try": "^2.0.0"
- },
- "engines": {
- "node": ">=6"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/@istanbuljs/load-nyc-config/node_modules/p-locate": {
- "version": "4.1.0",
- "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz",
- "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==",
- "dev": true,
- "dependencies": {
- "p-limit": "^2.2.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/@istanbuljs/load-nyc-config/node_modules/resolve-from": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz",
- "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/@istanbuljs/schema": {
- "version": "0.1.3",
- "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz",
- "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/@jest/console": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/@jest/console/-/console-29.7.0.tgz",
- "integrity": "sha512-5Ni4CU7XHQi32IJ398EEP4RrB8eV09sXP2ROqD4bksHrnTree52PsxvX8tpL8LvTZ3pFzXyPbNQReSN41CAhOg==",
- "dev": true,
- "dependencies": {
- "@jest/types": "^29.6.3",
- "@types/node": "*",
- "chalk": "^4.0.0",
- "jest-message-util": "^29.7.0",
- "jest-util": "^29.7.0",
- "slash": "^3.0.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/@jest/core": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/@jest/core/-/core-29.7.0.tgz",
- "integrity": "sha512-n7aeXWKMnGtDA48y8TLWJPJmLmmZ642Ceo78cYWEpiD7FzDgmNDV/GCVRorPABdXLJZ/9wzzgZAlHjXjxDHGsg==",
- "dev": true,
- "dependencies": {
- "@jest/console": "^29.7.0",
- "@jest/reporters": "^29.7.0",
- "@jest/test-result": "^29.7.0",
- "@jest/transform": "^29.7.0",
- "@jest/types": "^29.6.3",
- "@types/node": "*",
- "ansi-escapes": "^4.2.1",
- "chalk": "^4.0.0",
- "ci-info": "^3.2.0",
- "exit": "^0.1.2",
- "graceful-fs": "^4.2.9",
- "jest-changed-files": "^29.7.0",
- "jest-config": "^29.7.0",
- "jest-haste-map": "^29.7.0",
- "jest-message-util": "^29.7.0",
- "jest-regex-util": "^29.6.3",
- "jest-resolve": "^29.7.0",
- "jest-resolve-dependencies": "^29.7.0",
- "jest-runner": "^29.7.0",
- "jest-runtime": "^29.7.0",
- "jest-snapshot": "^29.7.0",
- "jest-util": "^29.7.0",
- "jest-validate": "^29.7.0",
- "jest-watcher": "^29.7.0",
- "micromatch": "^4.0.4",
- "pretty-format": "^29.7.0",
- "slash": "^3.0.0",
- "strip-ansi": "^6.0.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- },
- "peerDependencies": {
- "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0"
- },
- "peerDependenciesMeta": {
- "node-notifier": {
- "optional": true
- }
- }
- },
- "node_modules/@jest/environment": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-29.7.0.tgz",
- "integrity": "sha512-aQIfHDq33ExsN4jP1NWGXhxgQ/wixs60gDiKO+XVMd8Mn0NWPWgc34ZQDTb2jKaUWQ7MuwoitXAsN2XVXNMpAw==",
- "dev": true,
- "dependencies": {
- "@jest/fake-timers": "^29.7.0",
- "@jest/types": "^29.6.3",
- "@types/node": "*",
- "jest-mock": "^29.7.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/@jest/expect": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/@jest/expect/-/expect-29.7.0.tgz",
- "integrity": "sha512-8uMeAMycttpva3P1lBHB8VciS9V0XAr3GymPpipdyQXbBcuhkLQOSe8E/p92RyAdToS6ZD1tFkX+CkhoECE0dQ==",
- "dev": true,
- "dependencies": {
- "expect": "^29.7.0",
- "jest-snapshot": "^29.7.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/@jest/expect-utils": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/@jest/expect-utils/-/expect-utils-29.7.0.tgz",
- "integrity": "sha512-GlsNBWiFQFCVi9QVSx7f5AgMeLxe9YCCs5PuP2O2LdjDAA8Jh9eX7lA1Jq/xdXw3Wb3hyvlFNfZIfcRetSzYcA==",
- "dev": true,
- "dependencies": {
- "jest-get-type": "^29.6.3"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/@jest/fake-timers": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-29.7.0.tgz",
- "integrity": "sha512-q4DH1Ha4TTFPdxLsqDXK1d3+ioSL7yL5oCMJZgDYm6i+6CygW5E5xVr/D1HdsGxjt1ZWSfUAs9OxSB/BNelWrQ==",
- "dev": true,
- "dependencies": {
- "@jest/types": "^29.6.3",
- "@sinonjs/fake-timers": "^10.0.2",
- "@types/node": "*",
- "jest-message-util": "^29.7.0",
- "jest-mock": "^29.7.0",
- "jest-util": "^29.7.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/@jest/globals": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-29.7.0.tgz",
- "integrity": "sha512-mpiz3dutLbkW2MNFubUGUEVLkTGiqW6yLVTA+JbP6fI6J5iL9Y0Nlg8k95pcF8ctKwCS7WVxteBs29hhfAotzQ==",
- "dev": true,
- "dependencies": {
- "@jest/environment": "^29.7.0",
- "@jest/expect": "^29.7.0",
- "@jest/types": "^29.6.3",
- "jest-mock": "^29.7.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/@jest/reporters": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-29.7.0.tgz",
- "integrity": "sha512-DApq0KJbJOEzAFYjHADNNxAE3KbhxQB1y5Kplb5Waqw6zVbuWatSnMjE5gs8FUgEPmNsnZA3NCWl9NG0ia04Pg==",
- "dev": true,
- "dependencies": {
- "@bcoe/v8-coverage": "^0.2.3",
- "@jest/console": "^29.7.0",
- "@jest/test-result": "^29.7.0",
- "@jest/transform": "^29.7.0",
- "@jest/types": "^29.6.3",
- "@jridgewell/trace-mapping": "^0.3.18",
- "@types/node": "*",
- "chalk": "^4.0.0",
- "collect-v8-coverage": "^1.0.0",
- "exit": "^0.1.2",
- "glob": "^7.1.3",
- "graceful-fs": "^4.2.9",
- "istanbul-lib-coverage": "^3.0.0",
- "istanbul-lib-instrument": "^6.0.0",
- "istanbul-lib-report": "^3.0.0",
- "istanbul-lib-source-maps": "^4.0.0",
- "istanbul-reports": "^3.1.3",
- "jest-message-util": "^29.7.0",
- "jest-util": "^29.7.0",
- "jest-worker": "^29.7.0",
- "slash": "^3.0.0",
- "string-length": "^4.0.1",
- "strip-ansi": "^6.0.0",
- "v8-to-istanbul": "^9.0.1"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- },
- "peerDependencies": {
- "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0"
- },
- "peerDependenciesMeta": {
- "node-notifier": {
- "optional": true
- }
- }
- },
- "node_modules/@jest/schemas": {
- "version": "29.6.3",
- "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-29.6.3.tgz",
- "integrity": "sha512-mo5j5X+jIZmJQveBKeS/clAueipV7KgiX1vMgCxam1RNYiqE1w62n0/tJJnHtjW8ZHcQco5gY85jA3mi0L+nSA==",
- "dev": true,
- "dependencies": {
- "@sinclair/typebox": "^0.27.8"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/@jest/source-map": {
- "version": "29.6.3",
- "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-29.6.3.tgz",
- "integrity": "sha512-MHjT95QuipcPrpLM+8JMSzFx6eHp5Bm+4XeFDJlwsvVBjmKNiIAvasGK2fxz2WbGRlnvqehFbh07MMa7n3YJnw==",
- "dev": true,
- "dependencies": {
- "@jridgewell/trace-mapping": "^0.3.18",
- "callsites": "^3.0.0",
- "graceful-fs": "^4.2.9"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/@jest/test-result": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-29.7.0.tgz",
- "integrity": "sha512-Fdx+tv6x1zlkJPcWXmMDAG2HBnaR9XPSd5aDWQVsfrZmLVT3lU1cwyxLgRmXR9yrq4NBoEm9BMsfgFzTQAbJYA==",
- "dev": true,
- "dependencies": {
- "@jest/console": "^29.7.0",
- "@jest/types": "^29.6.3",
- "@types/istanbul-lib-coverage": "^2.0.0",
- "collect-v8-coverage": "^1.0.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/@jest/test-sequencer": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-29.7.0.tgz",
- "integrity": "sha512-GQwJ5WZVrKnOJuiYiAF52UNUJXgTZx1NHjFSEB0qEMmSZKAkdMoIzw/Cj6x6NF4AvV23AUqDpFzQkN/eYCYTxw==",
- "dev": true,
- "dependencies": {
- "@jest/test-result": "^29.7.0",
- "graceful-fs": "^4.2.9",
- "jest-haste-map": "^29.7.0",
- "slash": "^3.0.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/@jest/transform": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-29.7.0.tgz",
- "integrity": "sha512-ok/BTPFzFKVMwO5eOHRrvnBVHdRy9IrsrW1GpMaQ9MCnilNLXQKmAX8s1YXDFaai9xJpac2ySzV0YeRRECr2Vw==",
- "dev": true,
- "dependencies": {
- "@babel/core": "^7.11.6",
- "@jest/types": "^29.6.3",
- "@jridgewell/trace-mapping": "^0.3.18",
- "babel-plugin-istanbul": "^6.1.1",
- "chalk": "^4.0.0",
- "convert-source-map": "^2.0.0",
- "fast-json-stable-stringify": "^2.1.0",
- "graceful-fs": "^4.2.9",
- "jest-haste-map": "^29.7.0",
- "jest-regex-util": "^29.6.3",
- "jest-util": "^29.7.0",
- "micromatch": "^4.0.4",
- "pirates": "^4.0.4",
- "slash": "^3.0.0",
- "write-file-atomic": "^4.0.2"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/@jest/types": {
- "version": "29.6.3",
- "resolved": "https://registry.npmjs.org/@jest/types/-/types-29.6.3.tgz",
- "integrity": "sha512-u3UPsIilWKOM3F9CXtrG8LEJmNxwoCQC/XVj4IKYXvvpx7QIi/Kg1LI5uDmDpKlac62NUtX7eLjRh+jVZcLOzw==",
- "dev": true,
- "dependencies": {
- "@jest/schemas": "^29.6.3",
- "@types/istanbul-lib-coverage": "^2.0.0",
- "@types/istanbul-reports": "^3.0.0",
- "@types/node": "*",
- "@types/yargs": "^17.0.8",
- "chalk": "^4.0.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/@jridgewell/gen-mapping": {
- "version": "0.3.3",
- "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz",
- "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==",
- "dev": true,
- "dependencies": {
- "@jridgewell/set-array": "^1.0.1",
- "@jridgewell/sourcemap-codec": "^1.4.10",
- "@jridgewell/trace-mapping": "^0.3.9"
- },
- "engines": {
- "node": ">=6.0.0"
- }
- },
- "node_modules/@jridgewell/resolve-uri": {
- "version": "3.1.1",
- "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz",
- "integrity": "sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA==",
- "dev": true,
- "engines": {
- "node": ">=6.0.0"
- }
- },
- "node_modules/@jridgewell/set-array": {
- "version": "1.1.2",
- "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz",
- "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==",
- "dev": true,
- "engines": {
- "node": ">=6.0.0"
- }
- },
- "node_modules/@jridgewell/sourcemap-codec": {
- "version": "1.4.15",
- "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz",
- "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==",
- "dev": true
- },
- "node_modules/@jridgewell/trace-mapping": {
- "version": "0.3.22",
- "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.22.tgz",
- "integrity": "sha512-Wf963MzWtA2sjrNt+g18IAln9lKnlRp+K2eH4jjIoF1wYeq3aMREpG09xhlhdzS0EjwU7qmUJYangWa+151vZw==",
- "dev": true,
- "dependencies": {
- "@jridgewell/resolve-uri": "^3.1.0",
- "@jridgewell/sourcemap-codec": "^1.4.14"
- }
- },
- "node_modules/@mongodb-js/saslprep": {
- "version": "1.1.4",
- "resolved": "https://registry.npmjs.org/@mongodb-js/saslprep/-/saslprep-1.1.4.tgz",
- "integrity": "sha512-8zJ8N1x51xo9hwPh6AWnKdLGEC5N3lDa6kms1YHmFBoRhTpJR6HG8wWk0td1MVCu9cD4YBrvjZEtd5Obw0Fbnw==",
- "dependencies": {
- "sparse-bitfield": "^3.0.3"
- }
- },
- "node_modules/@mswjs/cookies": {
- "version": "1.1.0",
- "resolved": "https://registry.npmjs.org/@mswjs/cookies/-/cookies-1.1.0.tgz",
- "integrity": "sha512-0ZcCVQxifZmhwNBoQIrystCb+2sWBY2Zw8lpfJBPCHGCA/HWqehITeCRVIv4VMy8MPlaHo2w2pTHFV2pFfqKPw==",
- "dev": true,
- "engines": {
- "node": ">=18"
- }
- },
- "node_modules/@mswjs/interceptors": {
- "version": "0.25.16",
- "resolved": "https://registry.npmjs.org/@mswjs/interceptors/-/interceptors-0.25.16.tgz",
- "integrity": "sha512-8QC8JyKztvoGAdPgyZy49c9vSHHAZjHagwl4RY9E8carULk8ym3iTaiawrT1YoLF/qb449h48f71XDPgkUSOUg==",
- "dev": true,
- "dependencies": {
- "@open-draft/deferred-promise": "^2.2.0",
- "@open-draft/logger": "^0.3.0",
- "@open-draft/until": "^2.0.0",
- "is-node-process": "^1.2.0",
- "outvariant": "^1.2.1",
- "strict-event-emitter": "^0.5.1"
- },
- "engines": {
- "node": ">=18"
- }
- },
- "node_modules/@nodelib/fs.scandir": {
- "version": "2.1.5",
- "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz",
- "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==",
- "dev": true,
- "dependencies": {
- "@nodelib/fs.stat": "2.0.5",
- "run-parallel": "^1.1.9"
- },
- "engines": {
- "node": ">= 8"
- }
- },
- "node_modules/@nodelib/fs.stat": {
- "version": "2.0.5",
- "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz",
- "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==",
- "dev": true,
- "engines": {
- "node": ">= 8"
- }
- },
- "node_modules/@nodelib/fs.walk": {
- "version": "1.2.8",
- "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz",
- "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==",
- "dev": true,
- "dependencies": {
- "@nodelib/fs.scandir": "2.1.5",
- "fastq": "^1.6.0"
- },
- "engines": {
- "node": ">= 8"
- }
- },
- "node_modules/@open-draft/deferred-promise": {
- "version": "2.2.0",
- "resolved": "https://registry.npmjs.org/@open-draft/deferred-promise/-/deferred-promise-2.2.0.tgz",
- "integrity": "sha512-CecwLWx3rhxVQF6V4bAgPS5t+So2sTbPgAzafKkVizyi7tlwpcFpdFqq+wqF2OwNBmqFuu6tOyouTuxgpMfzmA==",
- "dev": true
- },
- "node_modules/@open-draft/logger": {
- "version": "0.3.0",
- "resolved": "https://registry.npmjs.org/@open-draft/logger/-/logger-0.3.0.tgz",
- "integrity": "sha512-X2g45fzhxH238HKO4xbSr7+wBS8Fvw6ixhTDuvLd5mqh6bJJCFAPwU9mPDxbcrRtfxv4u5IHCEH77BmxvXmmxQ==",
- "dev": true,
- "dependencies": {
- "is-node-process": "^1.2.0",
- "outvariant": "^1.4.0"
- }
- },
- "node_modules/@open-draft/until": {
- "version": "2.1.0",
- "resolved": "https://registry.npmjs.org/@open-draft/until/-/until-2.1.0.tgz",
- "integrity": "sha512-U69T3ItWHvLwGg5eJ0n3I62nWuE6ilHlmz7zM0npLBRvPRd7e6NYmg54vvRtP5mZG7kZqZCFVdsTWo7BPtBujg==",
- "dev": true
- },
- "node_modules/@sinclair/typebox": {
- "version": "0.27.8",
- "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.27.8.tgz",
- "integrity": "sha512-+Fj43pSMwJs4KRrH/938Uf+uAELIgVBmQzg/q1YG10djyfA3TnrU8N8XzqCh/okZdszqBQTZf96idMfE5lnwTA==",
- "dev": true
- },
- "node_modules/@sinonjs/commons": {
- "version": "3.0.1",
- "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-3.0.1.tgz",
- "integrity": "sha512-K3mCHKQ9sVh8o1C9cxkwxaOmXoAMlDxC1mYyHrjqOWEcBjYr76t96zL2zlj5dUGZ3HSw240X1qgH3Mjf1yJWpQ==",
- "dev": true,
- "dependencies": {
- "type-detect": "4.0.8"
- }
- },
- "node_modules/@sinonjs/fake-timers": {
- "version": "10.3.0",
- "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-10.3.0.tgz",
- "integrity": "sha512-V4BG07kuYSUkTCSBHG8G8TNhM+F19jXFWnQtzj+we8DrkpSBCee9Z3Ms8yiGer/dlmhe35/Xdgyo3/0rQKg7YA==",
- "dev": true,
- "dependencies": {
- "@sinonjs/commons": "^3.0.0"
- }
- },
- "node_modules/@tirke/node-cache-manager-mongodb": {
- "version": "1.6.0",
- "resolved": "https://registry.npmjs.org/@tirke/node-cache-manager-mongodb/-/node-cache-manager-mongodb-1.6.0.tgz",
- "integrity": "sha512-3eEtfdriTcYq0bIrxFypwUiiah8IX7tSv+OpzZ9v9iZWrXbR54ot7lCF/kj2LpdBDDOX5eZi74LWGrsB2WFSLg==",
- "dependencies": {
- "mongodb": "^6.0.0"
- },
- "engines": {
- "node": ">=14.20"
- },
- "funding": {
- "url": "https://github.com/sponsors/tirke"
- }
- },
- "node_modules/@tsconfig/node10": {
- "version": "1.0.9",
- "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.9.tgz",
- "integrity": "sha512-jNsYVVxU8v5g43Erja32laIDHXeoNvFEpX33OK4d6hljo3jDhCBDhx5dhCCTMWUojscpAagGiRkBKxpdl9fxqA==",
- "dev": true
- },
- "node_modules/@tsconfig/node12": {
- "version": "1.0.11",
- "resolved": "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.11.tgz",
- "integrity": "sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag==",
- "dev": true
- },
- "node_modules/@tsconfig/node14": {
- "version": "1.0.3",
- "resolved": "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.3.tgz",
- "integrity": "sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow==",
- "dev": true
- },
- "node_modules/@tsconfig/node16": {
- "version": "1.0.4",
- "resolved": "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.4.tgz",
- "integrity": "sha512-vxhUy4J8lyeyinH7Azl1pdd43GJhZH/tP2weN8TntQblOY+A0XbT8DJk1/oCPuOOyg/Ja757rG0CgHcWC8OfMA==",
- "dev": true
- },
- "node_modules/@types/amqplib": {
- "version": "0.10.4",
- "resolved": "https://registry.npmjs.org/@types/amqplib/-/amqplib-0.10.4.tgz",
- "integrity": "sha512-Y5Sqquh/LqDxSgxYaAAFNM0M7GyONtSDCcFMJk+DQwYEjibPyW6y+Yu9H9omdkKc3epyXULmFN3GTaeBHhn2Hg==",
- "dev": true,
- "dependencies": {
- "@types/node": "*"
- }
- },
- "node_modules/@types/babel__core": {
- "version": "7.20.5",
- "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz",
- "integrity": "sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==",
- "dev": true,
- "dependencies": {
- "@babel/parser": "^7.20.7",
- "@babel/types": "^7.20.7",
- "@types/babel__generator": "*",
- "@types/babel__template": "*",
- "@types/babel__traverse": "*"
- }
- },
- "node_modules/@types/babel__generator": {
- "version": "7.6.8",
- "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.8.tgz",
- "integrity": "sha512-ASsj+tpEDsEiFr1arWrlN6V3mdfjRMZt6LtK/Vp/kreFLnr5QH5+DhvD5nINYZXzwJvXeGq+05iUXcAzVrqWtw==",
- "dev": true,
- "dependencies": {
- "@babel/types": "^7.0.0"
- }
- },
- "node_modules/@types/babel__template": {
- "version": "7.4.4",
- "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz",
- "integrity": "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==",
- "dev": true,
- "dependencies": {
- "@babel/parser": "^7.1.0",
- "@babel/types": "^7.0.0"
- }
- },
- "node_modules/@types/babel__traverse": {
- "version": "7.20.5",
- "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.5.tgz",
- "integrity": "sha512-WXCyOcRtH37HAUkpXhUduaxdm82b4GSlyTqajXviN4EfiuPgNYR109xMCKvpl6zPIpua0DGlMEDCq+g8EdoheQ==",
- "dev": true,
- "dependencies": {
- "@babel/types": "^7.20.7"
- }
- },
- "node_modules/@types/cookie": {
- "version": "0.6.0",
- "resolved": "https://registry.npmjs.org/@types/cookie/-/cookie-0.6.0.tgz",
- "integrity": "sha512-4Kh9a6B2bQciAhf7FSuMRRkUWecJgJu9nPnx3yzpsfXX/c50REIqpHY4C82bXP90qrLtXtkDxTZosYO3UpOwlA==",
- "dev": true
- },
- "node_modules/@types/debug": {
- "version": "4.1.12",
- "resolved": "https://registry.npmjs.org/@types/debug/-/debug-4.1.12.tgz",
- "integrity": "sha512-vIChWdVG3LG1SMxEvI/AK+FWJthlrqlTu7fbrlywTkkaONwk/UAGaULXRlf8vkzFBLVm0zkMdCquhL5aOjhXPQ==",
- "dependencies": {
- "@types/ms": "*"
- }
- },
- "node_modules/@types/graceful-fs": {
- "version": "4.1.9",
- "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.9.tgz",
- "integrity": "sha512-olP3sd1qOEe5dXTSaFvQG+02VdRXcdytWLAZsAq1PecU8uqQAhkrnbli7DagjtXKW/Bl7YJbUsa8MPcuc8LHEQ==",
- "dev": true,
- "dependencies": {
- "@types/node": "*"
- }
- },
- "node_modules/@types/istanbul-lib-coverage": {
- "version": "2.0.6",
- "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.6.tgz",
- "integrity": "sha512-2QF/t/auWm0lsy8XtKVPG19v3sSOQlJe/YHZgfjb/KBBHOGSV+J2q/S671rcq9uTBrLAXmZpqJiaQbMT+zNU1w==",
- "dev": true
- },
- "node_modules/@types/istanbul-lib-report": {
- "version": "3.0.3",
- "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.3.tgz",
- "integrity": "sha512-NQn7AHQnk/RSLOxrBbGyJM/aVQ+pjj5HCgasFxc0K/KhoATfQ/47AyUl15I2yBUpihjmas+a+VJBOqecrFH+uA==",
- "dev": true,
- "dependencies": {
- "@types/istanbul-lib-coverage": "*"
- }
- },
- "node_modules/@types/istanbul-reports": {
- "version": "3.0.4",
- "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.4.tgz",
- "integrity": "sha512-pk2B1NWalF9toCRu6gjBzR69syFjP4Od8WRAX+0mmf9lAjCRicLOWc+ZrxZHx/0XRjotgkF9t6iaMJ+aXcOdZQ==",
- "dev": true,
- "dependencies": {
- "@types/istanbul-lib-report": "*"
- }
- },
- "node_modules/@types/jest": {
- "version": "29.5.12",
- "resolved": "https://registry.npmjs.org/@types/jest/-/jest-29.5.12.tgz",
- "integrity": "sha512-eDC8bTvT/QhYdxJAulQikueigY5AsdBRH2yDKW3yveW7svY3+DzN84/2NUgkw10RTiJbWqZrTtoGVdYlvFJdLw==",
- "dev": true,
- "dependencies": {
- "expect": "^29.0.0",
- "pretty-format": "^29.0.0"
- }
- },
- "node_modules/@types/json-schema": {
- "version": "7.0.15",
- "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz",
- "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==",
- "dev": true
- },
- "node_modules/@types/json5": {
- "version": "0.0.29",
- "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz",
- "integrity": "sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ==",
- "dev": true
- },
- "node_modules/@types/magnet-uri": {
- "version": "5.1.5",
- "resolved": "https://registry.npmjs.org/@types/magnet-uri/-/magnet-uri-5.1.5.tgz",
- "integrity": "sha512-SbBjlb1KGe38VfjRR+mwqztJd/4skhdKkRbIzPDhTy7IAeEAPZWIVSEkZw00Qr4ZZOGR3/ATJ20WWPBfrKHGdA==",
- "dev": true,
- "dependencies": {
- "@types/node": "*"
- }
- },
- "node_modules/@types/ms": {
- "version": "0.7.34",
- "resolved": "https://registry.npmjs.org/@types/ms/-/ms-0.7.34.tgz",
- "integrity": "sha512-nG96G3Wp6acyAgJqGasjODb+acrI7KltPiRxzHPXnP3NgI28bpQDRv53olbqGXbfcgF5aiiHmO3xpwEpS5Ld9g=="
- },
- "node_modules/@types/node": {
- "version": "20.11.16",
- "resolved": "https://registry.npmjs.org/@types/node/-/node-20.11.16.tgz",
- "integrity": "sha512-gKb0enTmRCzXSSUJDq6/sPcqrfCv2mkkG6Jt/clpn5eiCbKTY+SgZUxo+p8ZKMof5dCp9vHQUAB7wOUTod22wQ==",
- "dependencies": {
- "undici-types": "~5.26.4"
- }
- },
- "node_modules/@types/pg": {
- "version": "8.11.0",
- "resolved": "https://registry.npmjs.org/@types/pg/-/pg-8.11.0.tgz",
- "integrity": "sha512-sDAlRiBNthGjNFfvt0k6mtotoVYVQ63pA8R4EMWka7crawSR60waVYR0HAgmPRs/e2YaeJTD/43OoZ3PFw80pw==",
- "dev": true,
- "dependencies": {
- "@types/node": "*",
- "pg-protocol": "*",
- "pg-types": "^4.0.1"
- }
- },
- "node_modules/@types/semver": {
- "version": "7.5.6",
- "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.6.tgz",
- "integrity": "sha512-dn1l8LaMea/IjDoHNd9J52uBbInB796CDffS6VdIxvqYCPSG0V0DzHp76GpaWnlhg88uYyPbXCDIowa86ybd5A==",
- "dev": true
- },
- "node_modules/@types/stack-utils": {
- "version": "2.0.3",
- "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.3.tgz",
- "integrity": "sha512-9aEbYZ3TbYMznPdcdr3SmIrLXwC/AKZXQeCf9Pgao5CKb8CyHuEX5jzWPTkvregvhRJHcpRO6BFoGW9ycaOkYw==",
- "dev": true
- },
- "node_modules/@types/statuses": {
- "version": "2.0.4",
- "resolved": "https://registry.npmjs.org/@types/statuses/-/statuses-2.0.4.tgz",
- "integrity": "sha512-eqNDvZsCNY49OAXB0Firg/Sc2BgoWsntsLUdybGFOhAfCD6QJ2n9HXUIHGqt5qjrxmMv4wS8WLAw43ZkKcJ8Pw==",
- "dev": true
- },
- "node_modules/@types/torrent-stream": {
- "version": "0.0.9",
- "resolved": "https://registry.npmjs.org/@types/torrent-stream/-/torrent-stream-0.0.9.tgz",
- "integrity": "sha512-SY0K6HNlDdnU7yk4TWpLjlv65/liZnxmftMuOdjRriC2IGExqnAYfl8dprjU1j1KQMPVM/X174cusUPNPloghQ==",
- "dev": true,
- "dependencies": {
- "@types/node": "*"
- }
- },
- "node_modules/@types/validator": {
- "version": "13.11.9",
- "resolved": "https://registry.npmjs.org/@types/validator/-/validator-13.11.9.tgz",
- "integrity": "sha512-FCTsikRozryfayPuiI46QzH3fnrOoctTjvOYZkho9BTFLCOZ2rgZJHMOVgCOfttjPJcgOx52EpkY0CMfy87MIw=="
- },
- "node_modules/@types/webidl-conversions": {
- "version": "7.0.3",
- "resolved": "https://registry.npmjs.org/@types/webidl-conversions/-/webidl-conversions-7.0.3.tgz",
- "integrity": "sha512-CiJJvcRtIgzadHCYXw7dqEnMNRjhGZlYK05Mj9OyktqV8uVT8fD2BFOB7S1uwBE3Kj2Z+4UyPmFw/Ixgw/LAlA=="
- },
- "node_modules/@types/whatwg-url": {
- "version": "11.0.4",
- "resolved": "https://registry.npmjs.org/@types/whatwg-url/-/whatwg-url-11.0.4.tgz",
- "integrity": "sha512-lXCmTWSHJvf0TRSO58nm978b8HJ/EdsSsEKLd3ODHFjo+3VGAyyTp4v50nWvwtzBxSMQrVOK7tcuN0zGPLICMw==",
- "dependencies": {
- "@types/webidl-conversions": "*"
- }
- },
- "node_modules/@types/yargs": {
- "version": "17.0.32",
- "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.32.tgz",
- "integrity": "sha512-xQ67Yc/laOG5uMfX/093MRlGGCIBzZMarVa+gfNKJxWAIgykYpVGkBdbqEzGDDfCrVUj6Hiff4mTZ5BA6TmAog==",
- "dev": true,
- "dependencies": {
- "@types/yargs-parser": "*"
- }
- },
- "node_modules/@types/yargs-parser": {
- "version": "21.0.3",
- "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.3.tgz",
- "integrity": "sha512-I4q9QU9MQv4oEOz4tAHJtNz1cwuLxn2F3xcc2iV5WdqLPpUnj30aUuxt1mAxYTG+oe8CZMV/+6rU4S4gRDzqtQ==",
- "dev": true
- },
- "node_modules/@typescript-eslint/eslint-plugin": {
- "version": "6.21.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-6.21.0.tgz",
- "integrity": "sha512-oy9+hTPCUFpngkEZUSzbf9MxI65wbKFoQYsgPdILTfbUldp5ovUuphZVe4i30emU9M/kP+T64Di0mxl7dSw3MA==",
- "dev": true,
- "dependencies": {
- "@eslint-community/regexpp": "^4.5.1",
- "@typescript-eslint/scope-manager": "6.21.0",
- "@typescript-eslint/type-utils": "6.21.0",
- "@typescript-eslint/utils": "6.21.0",
- "@typescript-eslint/visitor-keys": "6.21.0",
- "debug": "^4.3.4",
- "graphemer": "^1.4.0",
- "ignore": "^5.2.4",
- "natural-compare": "^1.4.0",
- "semver": "^7.5.4",
- "ts-api-utils": "^1.0.1"
- },
- "engines": {
- "node": "^16.0.0 || >=18.0.0"
- },
- "funding": {
- "type": "opencollective",
- "url": "https://opencollective.com/typescript-eslint"
- },
- "peerDependencies": {
- "@typescript-eslint/parser": "^6.0.0 || ^6.0.0-alpha",
- "eslint": "^7.0.0 || ^8.0.0"
- },
- "peerDependenciesMeta": {
- "typescript": {
- "optional": true
- }
- }
- },
- "node_modules/@typescript-eslint/parser": {
- "version": "6.21.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-6.21.0.tgz",
- "integrity": "sha512-tbsV1jPne5CkFQCgPBcDOt30ItF7aJoZL997JSF7MhGQqOeT3svWRYxiqlfA5RUdlHN6Fi+EI9bxqbdyAUZjYQ==",
- "dev": true,
- "dependencies": {
- "@typescript-eslint/scope-manager": "6.21.0",
- "@typescript-eslint/types": "6.21.0",
- "@typescript-eslint/typescript-estree": "6.21.0",
- "@typescript-eslint/visitor-keys": "6.21.0",
- "debug": "^4.3.4"
- },
- "engines": {
- "node": "^16.0.0 || >=18.0.0"
- },
- "funding": {
- "type": "opencollective",
- "url": "https://opencollective.com/typescript-eslint"
- },
- "peerDependencies": {
- "eslint": "^7.0.0 || ^8.0.0"
- },
- "peerDependenciesMeta": {
- "typescript": {
- "optional": true
- }
- }
- },
- "node_modules/@typescript-eslint/scope-manager": {
- "version": "6.21.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.21.0.tgz",
- "integrity": "sha512-OwLUIWZJry80O99zvqXVEioyniJMa+d2GrqpUTqi5/v5D5rOrppJVBPa0yKCblcigC0/aYAzxxqQ1B+DS2RYsg==",
- "dev": true,
- "dependencies": {
- "@typescript-eslint/types": "6.21.0",
- "@typescript-eslint/visitor-keys": "6.21.0"
- },
- "engines": {
- "node": "^16.0.0 || >=18.0.0"
- },
- "funding": {
- "type": "opencollective",
- "url": "https://opencollective.com/typescript-eslint"
- }
- },
- "node_modules/@typescript-eslint/type-utils": {
- "version": "6.21.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-6.21.0.tgz",
- "integrity": "sha512-rZQI7wHfao8qMX3Rd3xqeYSMCL3SoiSQLBATSiVKARdFGCYSRvmViieZjqc58jKgs8Y8i9YvVVhRbHSTA4VBag==",
- "dev": true,
- "dependencies": {
- "@typescript-eslint/typescript-estree": "6.21.0",
- "@typescript-eslint/utils": "6.21.0",
- "debug": "^4.3.4",
- "ts-api-utils": "^1.0.1"
- },
- "engines": {
- "node": "^16.0.0 || >=18.0.0"
- },
- "funding": {
- "type": "opencollective",
- "url": "https://opencollective.com/typescript-eslint"
- },
- "peerDependencies": {
- "eslint": "^7.0.0 || ^8.0.0"
- },
- "peerDependenciesMeta": {
- "typescript": {
- "optional": true
- }
- }
- },
- "node_modules/@typescript-eslint/types": {
- "version": "6.21.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.21.0.tgz",
- "integrity": "sha512-1kFmZ1rOm5epu9NZEZm1kckCDGj5UJEf7P1kliH4LKu/RkwpsfqqGmY2OOcUs18lSlQBKLDYBOGxRVtrMN5lpg==",
- "dev": true,
- "engines": {
- "node": "^16.0.0 || >=18.0.0"
- },
- "funding": {
- "type": "opencollective",
- "url": "https://opencollective.com/typescript-eslint"
- }
- },
- "node_modules/@typescript-eslint/typescript-estree": {
- "version": "6.21.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.21.0.tgz",
- "integrity": "sha512-6npJTkZcO+y2/kr+z0hc4HwNfrrP4kNYh57ek7yCNlrBjWQ1Y0OS7jiZTkgumrvkX5HkEKXFZkkdFNkaW2wmUQ==",
- "dev": true,
- "dependencies": {
- "@typescript-eslint/types": "6.21.0",
- "@typescript-eslint/visitor-keys": "6.21.0",
- "debug": "^4.3.4",
- "globby": "^11.1.0",
- "is-glob": "^4.0.3",
- "minimatch": "9.0.3",
- "semver": "^7.5.4",
- "ts-api-utils": "^1.0.1"
- },
- "engines": {
- "node": "^16.0.0 || >=18.0.0"
- },
- "funding": {
- "type": "opencollective",
- "url": "https://opencollective.com/typescript-eslint"
- },
- "peerDependenciesMeta": {
- "typescript": {
- "optional": true
- }
- }
- },
- "node_modules/@typescript-eslint/utils": {
- "version": "6.21.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.21.0.tgz",
- "integrity": "sha512-NfWVaC8HP9T8cbKQxHcsJBY5YE1O33+jpMwN45qzWWaPDZgLIbo12toGMWnmhvCpd3sIxkpDw3Wv1B3dYrbDQQ==",
- "dev": true,
- "dependencies": {
- "@eslint-community/eslint-utils": "^4.4.0",
- "@types/json-schema": "^7.0.12",
- "@types/semver": "^7.5.0",
- "@typescript-eslint/scope-manager": "6.21.0",
- "@typescript-eslint/types": "6.21.0",
- "@typescript-eslint/typescript-estree": "6.21.0",
- "semver": "^7.5.4"
- },
- "engines": {
- "node": "^16.0.0 || >=18.0.0"
- },
- "funding": {
- "type": "opencollective",
- "url": "https://opencollective.com/typescript-eslint"
- },
- "peerDependencies": {
- "eslint": "^7.0.0 || ^8.0.0"
- }
- },
- "node_modules/@typescript-eslint/visitor-keys": {
- "version": "6.21.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.21.0.tgz",
- "integrity": "sha512-JJtkDduxLi9bivAB+cYOVMtbkqdPOhZ+ZI5LC47MIRrDV4Yn2o+ZnW10Nkmr28xRpSpdJ6Sm42Hjf2+REYXm0A==",
- "dev": true,
- "dependencies": {
- "@typescript-eslint/types": "6.21.0",
- "eslint-visitor-keys": "^3.4.1"
- },
- "engines": {
- "node": "^16.0.0 || >=18.0.0"
- },
- "funding": {
- "type": "opencollective",
- "url": "https://opencollective.com/typescript-eslint"
- }
- },
- "node_modules/@ungap/structured-clone": {
- "version": "1.2.0",
- "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz",
- "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==",
- "dev": true
- },
- "node_modules/abort-controller": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/abort-controller/-/abort-controller-3.0.0.tgz",
- "integrity": "sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==",
- "dependencies": {
- "event-target-shim": "^5.0.0"
- },
- "engines": {
- "node": ">=6.5"
- }
- },
- "node_modules/acorn": {
- "version": "8.11.3",
- "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz",
- "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==",
- "dev": true,
- "bin": {
- "acorn": "bin/acorn"
- },
- "engines": {
- "node": ">=0.4.0"
- }
- },
- "node_modules/acorn-jsx": {
- "version": "5.3.2",
- "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz",
- "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==",
- "dev": true,
- "peerDependencies": {
- "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0"
- }
- },
- "node_modules/acorn-walk": {
- "version": "8.3.2",
- "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.3.2.tgz",
- "integrity": "sha512-cjkyv4OtNCIeqhHrfS81QWXoCBPExR/J62oyEqepVw8WaQeSqpW2uhuLPh1m9eWhDuOo/jUXVTlifvesOWp/4A==",
- "dev": true,
- "engines": {
- "node": ">=0.4.0"
- }
- },
- "node_modules/addr-to-ip-port": {
- "version": "1.5.4",
- "resolved": "https://registry.npmjs.org/addr-to-ip-port/-/addr-to-ip-port-1.5.4.tgz",
- "integrity": "sha512-ByxmJgv8vjmDcl3IDToxL2yrWFrRtFpZAToY0f46XFXl8zS081t7El5MXIodwm7RC6DhHBRoOSMLFSPKCtHukg=="
- },
- "node_modules/ajv": {
- "version": "6.12.6",
- "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz",
- "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==",
- "dev": true,
- "dependencies": {
- "fast-deep-equal": "^3.1.1",
- "fast-json-stable-stringify": "^2.0.0",
- "json-schema-traverse": "^0.4.1",
- "uri-js": "^4.2.2"
- },
- "funding": {
- "type": "github",
- "url": "https://github.com/sponsors/epoberezkin"
- }
- },
- "node_modules/amqplib": {
- "version": "0.10.3",
- "resolved": "https://registry.npmjs.org/amqplib/-/amqplib-0.10.3.tgz",
- "integrity": "sha512-UHmuSa7n8vVW/a5HGh2nFPqAEr8+cD4dEZ6u9GjP91nHfr1a54RyAKyra7Sb5NH7NBKOUlyQSMXIp0qAixKexw==",
- "dependencies": {
- "@acuminous/bitsyntax": "^0.1.2",
- "buffer-more-ints": "~1.0.0",
- "readable-stream": "1.x >=1.1.9",
- "url-parse": "~1.5.10"
- },
- "engines": {
- "node": ">=10"
- }
- },
- "node_modules/ansi-escapes": {
- "version": "4.3.2",
- "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz",
- "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==",
- "dev": true,
- "dependencies": {
- "type-fest": "^0.21.3"
- },
- "engines": {
- "node": ">=8"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/ansi-escapes/node_modules/type-fest": {
- "version": "0.21.3",
- "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz",
- "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==",
- "dev": true,
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/ansi-regex": {
- "version": "5.0.1",
- "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz",
- "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/ansi-styles": {
- "version": "4.3.0",
- "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
- "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
- "dev": true,
- "dependencies": {
- "color-convert": "^2.0.1"
- },
- "engines": {
- "node": ">=8"
- },
- "funding": {
- "url": "https://github.com/chalk/ansi-styles?sponsor=1"
- }
- },
- "node_modules/anymatch": {
- "version": "3.1.3",
- "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz",
- "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==",
- "dev": true,
- "dependencies": {
- "normalize-path": "^3.0.0",
- "picomatch": "^2.0.4"
- },
- "engines": {
- "node": ">= 8"
- }
- },
- "node_modules/arg": {
- "version": "4.1.3",
- "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz",
- "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==",
- "dev": true
- },
- "node_modules/argparse": {
- "version": "2.0.1",
- "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz",
- "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==",
- "dev": true
- },
- "node_modules/array-buffer-byte-length": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.1.tgz",
- "integrity": "sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.5",
- "is-array-buffer": "^3.0.4"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/array-includes": {
- "version": "3.1.7",
- "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.7.tgz",
- "integrity": "sha512-dlcsNBIiWhPkHdOEEKnehA+RNUWDc4UqFtnIXU4uuYDPtA4LDkr7qip2p0VvFAEXNDr0yWZ9PJyIRiGjRLQzwQ==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2",
- "define-properties": "^1.2.0",
- "es-abstract": "^1.22.1",
- "get-intrinsic": "^1.2.1",
- "is-string": "^1.0.7"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/array-union": {
- "version": "2.1.0",
- "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz",
- "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/array.prototype.filter": {
- "version": "1.0.3",
- "resolved": "https://registry.npmjs.org/array.prototype.filter/-/array.prototype.filter-1.0.3.tgz",
- "integrity": "sha512-VizNcj/RGJiUyQBgzwxzE5oHdeuXY5hSbbmKMlphj1cy1Vl7Pn2asCGbSrru6hSQjmCzqTBPVWAF/whmEOVHbw==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2",
- "define-properties": "^1.2.0",
- "es-abstract": "^1.22.1",
- "es-array-method-boxes-properly": "^1.0.0",
- "is-string": "^1.0.7"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/array.prototype.findlastindex": {
- "version": "1.2.4",
- "resolved": "https://registry.npmjs.org/array.prototype.findlastindex/-/array.prototype.findlastindex-1.2.4.tgz",
- "integrity": "sha512-hzvSHUshSpCflDR1QMUBLHGHP1VIEBegT4pix9H/Z92Xw3ySoy6c2qh7lJWTJnRJ8JCZ9bJNCgTyYaJGcJu6xQ==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.5",
- "define-properties": "^1.2.1",
- "es-abstract": "^1.22.3",
- "es-errors": "^1.3.0",
- "es-shim-unscopables": "^1.0.2"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/array.prototype.flat": {
- "version": "1.3.2",
- "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.3.2.tgz",
- "integrity": "sha512-djYB+Zx2vLewY8RWlNCUdHjDXs2XOgm602S9E7P/UpHgfeHL00cRiIF+IN/G/aUJ7kGPb6yO/ErDI5V2s8iycA==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2",
- "define-properties": "^1.2.0",
- "es-abstract": "^1.22.1",
- "es-shim-unscopables": "^1.0.0"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/array.prototype.flatmap": {
- "version": "1.3.2",
- "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.3.2.tgz",
- "integrity": "sha512-Ewyx0c9PmpcsByhSW4r+9zDU7sGjFc86qf/kKtuSCRdhfbk0SNLLkaT5qvcHnRGgc5NP/ly/y+qkXkqONX54CQ==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2",
- "define-properties": "^1.2.0",
- "es-abstract": "^1.22.1",
- "es-shim-unscopables": "^1.0.0"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/arraybuffer.prototype.slice": {
- "version": "1.0.3",
- "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.3.tgz",
- "integrity": "sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A==",
- "dev": true,
- "dependencies": {
- "array-buffer-byte-length": "^1.0.1",
- "call-bind": "^1.0.5",
- "define-properties": "^1.2.1",
- "es-abstract": "^1.22.3",
- "es-errors": "^1.2.1",
- "get-intrinsic": "^1.2.3",
- "is-array-buffer": "^3.0.4",
- "is-shared-array-buffer": "^1.0.2"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/asynckit": {
- "version": "0.4.0",
- "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz",
- "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q=="
- },
- "node_modules/atomic-sleep": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/atomic-sleep/-/atomic-sleep-1.0.0.tgz",
- "integrity": "sha512-kNOjDqAh7px0XWNI+4QbzoiR/nTkHAWNud2uvnJquD1/x5a7EQZMJT0AczqK0Qn67oY/TTQ1LbUKajZpp3I9tQ==",
- "engines": {
- "node": ">=8.0.0"
- }
- },
- "node_modules/available-typed-arrays": {
- "version": "1.0.6",
- "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.6.tgz",
- "integrity": "sha512-j1QzY8iPNPG4o4xmO3ptzpRxTciqD3MgEHtifP/YnJpIo58Xu+ne4BejlbkuaLfXn/nz6HFiw29bLpj2PNMdGg==",
- "dev": true,
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/axios": {
- "version": "1.6.7",
- "resolved": "https://registry.npmjs.org/axios/-/axios-1.6.7.tgz",
- "integrity": "sha512-/hDJGff6/c7u0hDkvkGxR/oy6CbCs8ziCsC7SqmhjfozqiJGc8Z11wrv9z9lYfY4K8l+H9TpjcMDX0xOZmx+RA==",
- "dependencies": {
- "follow-redirects": "^1.15.4",
- "form-data": "^4.0.0",
- "proxy-from-env": "^1.1.0"
- }
- },
- "node_modules/babel-jest": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-29.7.0.tgz",
- "integrity": "sha512-BrvGY3xZSwEcCzKvKsCi2GgHqDqsYkOP4/by5xCgIwGXQxIEh+8ew3gmrE1y7XRR6LHZIj6yLYnUi/mm2KXKBg==",
- "dev": true,
- "dependencies": {
- "@jest/transform": "^29.7.0",
- "@types/babel__core": "^7.1.14",
- "babel-plugin-istanbul": "^6.1.1",
- "babel-preset-jest": "^29.6.3",
- "chalk": "^4.0.0",
- "graceful-fs": "^4.2.9",
- "slash": "^3.0.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- },
- "peerDependencies": {
- "@babel/core": "^7.8.0"
- }
- },
- "node_modules/babel-plugin-istanbul": {
- "version": "6.1.1",
- "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz",
- "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==",
- "dev": true,
- "dependencies": {
- "@babel/helper-plugin-utils": "^7.0.0",
- "@istanbuljs/load-nyc-config": "^1.0.0",
- "@istanbuljs/schema": "^0.1.2",
- "istanbul-lib-instrument": "^5.0.4",
- "test-exclude": "^6.0.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/babel-plugin-istanbul/node_modules/istanbul-lib-instrument": {
- "version": "5.2.1",
- "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz",
- "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==",
- "dev": true,
- "dependencies": {
- "@babel/core": "^7.12.3",
- "@babel/parser": "^7.14.7",
- "@istanbuljs/schema": "^0.1.2",
- "istanbul-lib-coverage": "^3.2.0",
- "semver": "^6.3.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/babel-plugin-istanbul/node_modules/semver": {
- "version": "6.3.1",
- "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
- "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
- "dev": true,
- "bin": {
- "semver": "bin/semver.js"
- }
- },
- "node_modules/babel-plugin-jest-hoist": {
- "version": "29.6.3",
- "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-29.6.3.tgz",
- "integrity": "sha512-ESAc/RJvGTFEzRwOTT4+lNDk/GNHMkKbNzsvT0qKRfDyyYTskxB5rnU2njIDYVxXCBHHEI1c0YwHob3WaYujOg==",
- "dev": true,
- "dependencies": {
- "@babel/template": "^7.3.3",
- "@babel/types": "^7.3.3",
- "@types/babel__core": "^7.1.14",
- "@types/babel__traverse": "^7.0.6"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/babel-preset-current-node-syntax": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz",
- "integrity": "sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ==",
- "dev": true,
- "dependencies": {
- "@babel/plugin-syntax-async-generators": "^7.8.4",
- "@babel/plugin-syntax-bigint": "^7.8.3",
- "@babel/plugin-syntax-class-properties": "^7.8.3",
- "@babel/plugin-syntax-import-meta": "^7.8.3",
- "@babel/plugin-syntax-json-strings": "^7.8.3",
- "@babel/plugin-syntax-logical-assignment-operators": "^7.8.3",
- "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3",
- "@babel/plugin-syntax-numeric-separator": "^7.8.3",
- "@babel/plugin-syntax-object-rest-spread": "^7.8.3",
- "@babel/plugin-syntax-optional-catch-binding": "^7.8.3",
- "@babel/plugin-syntax-optional-chaining": "^7.8.3",
- "@babel/plugin-syntax-top-level-await": "^7.8.3"
- },
- "peerDependencies": {
- "@babel/core": "^7.0.0"
- }
- },
- "node_modules/babel-preset-jest": {
- "version": "29.6.3",
- "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-29.6.3.tgz",
- "integrity": "sha512-0B3bhxR6snWXJZtR/RliHTDPRgn1sNHOR0yVtq/IiQFyuOVjFS+wuio/R4gSNkyYmKmJB4wGZv2NZanmKmTnNA==",
- "dev": true,
- "dependencies": {
- "babel-plugin-jest-hoist": "^29.6.3",
- "babel-preset-current-node-syntax": "^1.0.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- },
- "peerDependencies": {
- "@babel/core": "^7.0.0"
- }
- },
- "node_modules/balanced-match": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
- "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw=="
- },
- "node_modules/base64-js": {
- "version": "1.5.1",
- "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz",
- "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==",
- "funding": [
- {
- "type": "github",
- "url": "https://github.com/sponsors/feross"
- },
- {
- "type": "patreon",
- "url": "https://www.patreon.com/feross"
- },
- {
- "type": "consulting",
- "url": "https://feross.org/support"
- }
- ]
- },
- "node_modules/bencode": {
- "version": "0.7.0",
- "resolved": "https://registry.npmjs.org/bencode/-/bencode-0.7.0.tgz",
- "integrity": "sha512-MG5AM/hkQIZoz/layZ1JK3xBTfqkLcJ3dJ7u2lx+6vZT1JWyK3OgEFGx1WFzWt6grGH6OSGQvRcCnhWKLp4f1Q=="
- },
- "node_modules/bep53-range": {
- "version": "1.1.1",
- "resolved": "https://registry.npmjs.org/bep53-range/-/bep53-range-1.1.1.tgz",
- "integrity": "sha512-ct6s33iiwRCUPp9KXnJ4QMWDgHIgaw36caK/5XEQ9L8dCzSQlJt1Vk6VmHh1VD4AlGCAI4C2zmtfItifBBPrhQ=="
- },
- "node_modules/binary-extensions": {
- "version": "2.2.0",
- "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz",
- "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/bitfield": {
- "version": "0.1.0",
- "resolved": "https://registry.npmjs.org/bitfield/-/bitfield-0.1.0.tgz",
- "integrity": "sha512-M15ypXCxXd81FSOWL2ejHpB1TDKmz7Y55/VuqfExJi72sHW0JzE5dfV+hrSZafZtWRg/tdMsdte5dgwrlOM7nA=="
- },
- "node_modules/bittorrent-dht": {
- "version": "6.4.2",
- "resolved": "https://registry.npmjs.org/bittorrent-dht/-/bittorrent-dht-6.4.2.tgz",
- "integrity": "sha512-DeBunF1nL/ckThYyU3AVtHFR195zNV06Ob6bKNXA1y6X56GSKMfkNCABB45YcbZevGMW1dytFlm59D/fws5lTg==",
- "dependencies": {
- "bencode": "^0.7.0",
- "buffer-equals": "^1.0.3",
- "debug": "^2.2.0",
- "inherits": "^2.0.1",
- "k-bucket": "^0.6.0",
- "k-rpc": "^3.6.0",
- "lru": "^2.0.0"
- }
- },
- "node_modules/bittorrent-dht/node_modules/debug": {
- "version": "2.6.9",
- "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
- "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
- "dependencies": {
- "ms": "2.0.0"
- }
- },
- "node_modules/bittorrent-dht/node_modules/ms": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
- "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="
- },
- "node_modules/bittorrent-tracker": {
- "version": "7.7.0",
- "resolved": "https://registry.npmjs.org/bittorrent-tracker/-/bittorrent-tracker-7.7.0.tgz",
- "integrity": "sha512-YFgPTVRhUMncZr8tM3ige7gnViMGhKoGF23qaiISRG8xtYebTGHrMSMXsTXo6O1KbtdEI+4jzvGY1K/wdT9GUA==",
- "dependencies": {
- "bencode": "^0.8.0",
- "bn.js": "^4.4.0",
- "compact2string": "^1.2.0",
- "debug": "^2.0.0",
- "hat": "0.0.3",
- "inherits": "^2.0.1",
- "ip": "^1.0.1",
- "minimist": "^1.1.1",
- "once": "^1.3.0",
- "random-iterate": "^1.0.1",
- "run-parallel": "^1.1.2",
- "run-series": "^1.0.2",
- "simple-get": "^2.0.0",
- "simple-peer": "^6.0.0",
- "simple-websocket": "^4.0.0",
- "string2compact": "^1.1.1",
- "uniq": "^1.0.1",
- "ws": "^1.0.0",
- "xtend": "^4.0.0"
- },
- "bin": {
- "bittorrent-tracker": "bin/cmd.js"
- }
- },
- "node_modules/bittorrent-tracker/node_modules/bencode": {
- "version": "0.8.0",
- "resolved": "https://registry.npmjs.org/bencode/-/bencode-0.8.0.tgz",
- "integrity": "sha512-MWs3FqaWOGg5l+quIT9JTx7+SlcMbfPqqpWy+GOYi5rjZkX8i03tkNhAQn3pD2GAKENPpP3ScUR97ZUMffhHZA=="
- },
- "node_modules/bittorrent-tracker/node_modules/debug": {
- "version": "2.6.9",
- "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
- "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
- "dependencies": {
- "ms": "2.0.0"
- }
- },
- "node_modules/bittorrent-tracker/node_modules/ip": {
- "version": "1.1.8",
- "resolved": "https://registry.npmjs.org/ip/-/ip-1.1.8.tgz",
- "integrity": "sha512-PuExPYUiu6qMBQb4l06ecm6T6ujzhmh+MeJcW9wa89PoAz5pvd4zPgN5WJV104mb6S2T1AwNIAaB70JNrLQWhg=="
- },
- "node_modules/bittorrent-tracker/node_modules/ms": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
- "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="
- },
- "node_modules/bl": {
- "version": "4.1.0",
- "resolved": "https://registry.npmjs.org/bl/-/bl-4.1.0.tgz",
- "integrity": "sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w==",
- "dev": true,
- "dependencies": {
- "buffer": "^5.5.0",
- "inherits": "^2.0.4",
- "readable-stream": "^3.4.0"
- }
- },
- "node_modules/bl/node_modules/readable-stream": {
- "version": "3.6.2",
- "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz",
- "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==",
- "dev": true,
- "dependencies": {
- "inherits": "^2.0.3",
- "string_decoder": "^1.1.1",
- "util-deprecate": "^1.0.1"
- },
- "engines": {
- "node": ">= 6"
- }
- },
- "node_modules/bl/node_modules/safe-buffer": {
- "version": "5.2.1",
- "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz",
- "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==",
- "dev": true,
- "funding": [
- {
- "type": "github",
- "url": "https://github.com/sponsors/feross"
- },
- {
- "type": "patreon",
- "url": "https://www.patreon.com/feross"
- },
- {
- "type": "consulting",
- "url": "https://feross.org/support"
- }
- ]
- },
- "node_modules/bl/node_modules/string_decoder": {
- "version": "1.3.0",
- "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz",
- "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==",
- "dev": true,
- "dependencies": {
- "safe-buffer": "~5.2.0"
- }
- },
- "node_modules/bn.js": {
- "version": "4.12.0",
- "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz",
- "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA=="
- },
- "node_modules/bncode": {
- "version": "0.5.3",
- "resolved": "https://registry.npmjs.org/bncode/-/bncode-0.5.3.tgz",
- "integrity": "sha512-0P5VuWobU5Gwbeio8n9Jsdv0tE1IikrV9n4f7RsnXHNtxmdd/oeIO6QyoSEUAEyo5P6i3XMfBppi82WqNsT4JA=="
- },
- "node_modules/bottleneck": {
- "version": "2.19.5",
- "resolved": "https://registry.npmjs.org/bottleneck/-/bottleneck-2.19.5.tgz",
- "integrity": "sha512-VHiNCbI1lKdl44tGrhNfU3lup0Tj/ZBMJB5/2ZbNXRCPuRCO7ed2mgcK4r17y+KB2EfuYuRaVlwNbAeaWGSpbw=="
- },
- "node_modules/brace-expansion": {
- "version": "2.0.1",
- "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz",
- "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==",
- "dev": true,
- "dependencies": {
- "balanced-match": "^1.0.0"
- }
- },
- "node_modules/braces": {
- "version": "3.0.2",
- "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
- "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
- "dev": true,
- "dependencies": {
- "fill-range": "^7.0.1"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/browserslist": {
- "version": "4.22.3",
- "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.22.3.tgz",
- "integrity": "sha512-UAp55yfwNv0klWNapjs/ktHoguxuQNGnOzxYmfnXIS+8AsRDZkSDxg7R1AX3GKzn078SBI5dzwzj/Yx0Or0e3A==",
- "dev": true,
- "funding": [
- {
- "type": "opencollective",
- "url": "https://opencollective.com/browserslist"
- },
- {
- "type": "tidelift",
- "url": "https://tidelift.com/funding/github/npm/browserslist"
- },
- {
- "type": "github",
- "url": "https://github.com/sponsors/ai"
- }
- ],
- "dependencies": {
- "caniuse-lite": "^1.0.30001580",
- "electron-to-chromium": "^1.4.648",
- "node-releases": "^2.0.14",
- "update-browserslist-db": "^1.0.13"
- },
- "bin": {
- "browserslist": "cli.js"
- },
- "engines": {
- "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7"
- }
- },
- "node_modules/bs-logger": {
- "version": "0.2.6",
- "resolved": "https://registry.npmjs.org/bs-logger/-/bs-logger-0.2.6.tgz",
- "integrity": "sha512-pd8DCoxmbgc7hyPKOvxtqNcjYoOsABPQdcCUjGp3d42VR2CX1ORhk2A87oqqu5R1kk+76nsxZupkmyd+MVtCog==",
- "dev": true,
- "dependencies": {
- "fast-json-stable-stringify": "2.x"
- },
- "engines": {
- "node": ">= 6"
- }
- },
- "node_modules/bser": {
- "version": "2.1.1",
- "resolved": "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz",
- "integrity": "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==",
- "dev": true,
- "dependencies": {
- "node-int64": "^0.4.0"
- }
- },
- "node_modules/bson": {
- "version": "6.3.0",
- "resolved": "https://registry.npmjs.org/bson/-/bson-6.3.0.tgz",
- "integrity": "sha512-balJfqwwTBddxfnidJZagCBPP/f48zj9Sdp3OJswREOgsJzHiQSaOIAtApSgDQFYgHqAvFkp53AFSqjMDZoTFw==",
- "engines": {
- "node": ">=16.20.1"
- }
- },
- "node_modules/buffer": {
- "version": "5.7.1",
- "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz",
- "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==",
- "dev": true,
- "funding": [
- {
- "type": "github",
- "url": "https://github.com/sponsors/feross"
- },
- {
- "type": "patreon",
- "url": "https://www.patreon.com/feross"
- },
- {
- "type": "consulting",
- "url": "https://feross.org/support"
- }
- ],
- "dependencies": {
- "base64-js": "^1.3.1",
- "ieee754": "^1.1.13"
- }
- },
- "node_modules/buffer-alloc": {
- "version": "1.2.0",
- "resolved": "https://registry.npmjs.org/buffer-alloc/-/buffer-alloc-1.2.0.tgz",
- "integrity": "sha512-CFsHQgjtW1UChdXgbyJGtnm+O/uLQeZdtbDo8mfUgYXCHSM1wgrVxXm6bSyrUuErEb+4sYVGCzASBRot7zyrow==",
- "dependencies": {
- "buffer-alloc-unsafe": "^1.1.0",
- "buffer-fill": "^1.0.0"
- }
- },
- "node_modules/buffer-alloc-unsafe": {
- "version": "1.1.0",
- "resolved": "https://registry.npmjs.org/buffer-alloc-unsafe/-/buffer-alloc-unsafe-1.1.0.tgz",
- "integrity": "sha512-TEM2iMIEQdJ2yjPJoSIsldnleVaAk1oW3DBVUykyOLsEsFmEc9kn+SFFPz+gl54KQNxlDnAwCXosOS9Okx2xAg=="
- },
- "node_modules/buffer-equal": {
- "version": "0.0.1",
- "resolved": "https://registry.npmjs.org/buffer-equal/-/buffer-equal-0.0.1.tgz",
- "integrity": "sha512-RgSV6InVQ9ODPdLWJ5UAqBqJBOg370Nz6ZQtRzpt6nUjc8v0St97uJ4PYC6NztqIScrAXafKM3mZPMygSe1ggA==",
- "engines": {
- "node": ">=0.4.0"
- }
- },
- "node_modules/buffer-equals": {
- "version": "1.0.4",
- "resolved": "https://registry.npmjs.org/buffer-equals/-/buffer-equals-1.0.4.tgz",
- "integrity": "sha512-99MsCq0j5+RhubVEtKQgKaD6EM+UP3xJgIvQqwJ3SOLDUekzxMX1ylXBng+Wa2sh7mGT0W6RUly8ojjr1Tt6nA==",
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/buffer-fill": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/buffer-fill/-/buffer-fill-1.0.0.tgz",
- "integrity": "sha512-T7zexNBwiiaCOGDg9xNX9PBmjrubblRkENuptryuI64URkXDFum9il/JGL8Lm8wYfAXpredVXXZz7eMHilimiQ=="
- },
- "node_modules/buffer-from": {
- "version": "1.1.2",
- "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz",
- "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ=="
- },
- "node_modules/buffer-more-ints": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/buffer-more-ints/-/buffer-more-ints-1.0.0.tgz",
- "integrity": "sha512-EMetuGFz5SLsT0QTnXzINh4Ksr+oo4i+UGTXEshiGCQWnsgSs7ZhJ8fzlwQ+OzEMs0MpDAMr1hxnblp5a4vcHg=="
- },
- "node_modules/buffer-writer": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/buffer-writer/-/buffer-writer-2.0.0.tgz",
- "integrity": "sha512-a7ZpuTZU1TRtnwyCNW3I5dc0wWNC3VR9S++Ewyk2HHZdrO3CQJqSpd+95Us590V6AL7JqUAH2IwZ/398PmNFgw==",
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/cache-manager": {
- "version": "5.4.0",
- "resolved": "https://registry.npmjs.org/cache-manager/-/cache-manager-5.4.0.tgz",
- "integrity": "sha512-FS7o8vqJosnLpu9rh2gQTo8EOzCRJLF1BJ4XDEUDMqcfvs7SJZs5iuoFTXLauzQ3S5v8sBAST1pCwMaurpyi1A==",
- "dependencies": {
- "lodash.clonedeep": "^4.5.0",
- "lru-cache": "^10.1.0",
- "promise-coalesce": "^1.1.2"
- }
- },
- "node_modules/call-bind": {
- "version": "1.0.6",
- "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.6.tgz",
- "integrity": "sha512-Mj50FLHtlsoVfRfnHaZvyrooHcrlceNZdL/QBvJJVd9Ta55qCQK0gs4ss2oZDeV9zFCs6ewzYgVE5yfVmfFpVg==",
- "dev": true,
- "dependencies": {
- "es-errors": "^1.3.0",
- "function-bind": "^1.1.2",
- "get-intrinsic": "^1.2.3",
- "set-function-length": "^1.2.0"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/callsites": {
- "version": "3.1.0",
- "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
- "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
- "dev": true,
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/camelcase": {
- "version": "5.3.1",
- "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz",
- "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==",
- "dev": true,
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/caniuse-lite": {
- "version": "1.0.30001585",
- "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001585.tgz",
- "integrity": "sha512-yr2BWR1yLXQ8fMpdS/4ZZXpseBgE7o4g41x3a6AJOqZuOi+iE/WdJYAuZ6Y95i4Ohd2Y+9MzIWRR+uGABH4s3Q==",
- "dev": true,
- "funding": [
- {
- "type": "opencollective",
- "url": "https://opencollective.com/browserslist"
- },
- {
- "type": "tidelift",
- "url": "https://tidelift.com/funding/github/npm/caniuse-lite"
- },
- {
- "type": "github",
- "url": "https://github.com/sponsors/ai"
- }
- ]
- },
- "node_modules/chalk": {
- "version": "4.1.2",
- "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
- "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
- "dev": true,
- "dependencies": {
- "ansi-styles": "^4.1.0",
- "supports-color": "^7.1.0"
- },
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/chalk/chalk?sponsor=1"
- }
- },
- "node_modules/char-regex": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz",
- "integrity": "sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw==",
- "dev": true,
- "engines": {
- "node": ">=10"
- }
- },
- "node_modules/chardet": {
- "version": "0.7.0",
- "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz",
- "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==",
- "dev": true
- },
- "node_modules/chokidar": {
- "version": "3.6.0",
- "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz",
- "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==",
- "dev": true,
- "dependencies": {
- "anymatch": "~3.1.2",
- "braces": "~3.0.2",
- "glob-parent": "~5.1.2",
- "is-binary-path": "~2.1.0",
- "is-glob": "~4.0.1",
- "normalize-path": "~3.0.0",
- "readdirp": "~3.6.0"
- },
- "engines": {
- "node": ">= 8.10.0"
- },
- "funding": {
- "url": "https://paulmillr.com/funding/"
- },
- "optionalDependencies": {
- "fsevents": "~2.3.2"
- }
- },
- "node_modules/chokidar/node_modules/glob-parent": {
- "version": "5.1.2",
- "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
- "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
- "dev": true,
- "dependencies": {
- "is-glob": "^4.0.1"
- },
- "engines": {
- "node": ">= 6"
- }
- },
- "node_modules/chrome-dgram": {
- "version": "3.0.6",
- "resolved": "https://registry.npmjs.org/chrome-dgram/-/chrome-dgram-3.0.6.tgz",
- "integrity": "sha512-bqBsUuaOiXiqxXt/zA/jukNJJ4oaOtc7ciwqJpZVEaaXwwxqgI2/ZdG02vXYWUhHGziDlvGMQWk0qObgJwVYKA==",
- "funding": [
- {
- "type": "github",
- "url": "https://github.com/sponsors/feross"
- },
- {
- "type": "patreon",
- "url": "https://www.patreon.com/feross"
- },
- {
- "type": "consulting",
- "url": "https://feross.org/support"
- }
- ],
- "dependencies": {
- "inherits": "^2.0.4",
- "run-series": "^1.1.9"
- }
- },
- "node_modules/chrome-dns": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/chrome-dns/-/chrome-dns-1.0.1.tgz",
- "integrity": "sha512-HqsYJgIc8ljJJOqOzLphjAs79EUuWSX3nzZi2LNkzlw3GIzAeZbaSektC8iT/tKvLqZq8yl1GJu5o6doA4TRbg==",
- "dependencies": {
- "chrome-net": "^3.3.2"
- }
- },
- "node_modules/chrome-net": {
- "version": "3.3.4",
- "resolved": "https://registry.npmjs.org/chrome-net/-/chrome-net-3.3.4.tgz",
- "integrity": "sha512-Jzy2EnzmE+ligqIZUsmWnck9RBXLuUy6CaKyuNMtowFG3ZvLt8d+WBJCTPEludV0DHpIKjAOlwjFmTaEdfdWCw==",
- "funding": [
- {
- "type": "github",
- "url": "https://github.com/sponsors/feross"
- },
- {
- "type": "patreon",
- "url": "https://www.patreon.com/feross"
- },
- {
- "type": "consulting",
- "url": "https://feross.org/support"
- }
- ],
- "dependencies": {
- "inherits": "^2.0.1"
- }
- },
- "node_modules/ci-info": {
- "version": "3.9.0",
- "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.9.0.tgz",
- "integrity": "sha512-NIxF55hv4nSqQswkAeiOi1r83xy8JldOFDTWiug55KBu9Jnblncd2U6ViHmYgHf01TPZS77NJBhBMKdWj9HQMQ==",
- "dev": true,
- "funding": [
- {
- "type": "github",
- "url": "https://github.com/sponsors/sibiraj-s"
- }
- ],
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/cjs-module-lexer": {
- "version": "1.2.3",
- "resolved": "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.2.3.tgz",
- "integrity": "sha512-0TNiGstbQmCFwt4akjjBg5pLRTSyj/PkWQ1ZoO2zntmg9yLqSRxwEa4iCfQLGjqhiqBfOJa7W/E8wfGrTDmlZQ==",
- "dev": true
- },
- "node_modules/cli-cursor": {
- "version": "3.1.0",
- "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz",
- "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==",
- "dev": true,
- "dependencies": {
- "restore-cursor": "^3.1.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/cli-spinners": {
- "version": "2.9.2",
- "resolved": "https://registry.npmjs.org/cli-spinners/-/cli-spinners-2.9.2.tgz",
- "integrity": "sha512-ywqV+5MmyL4E7ybXgKys4DugZbX0FC6LnwrhjuykIjnK9k8OQacQ7axGKnjDXWNhns0xot3bZI5h55H8yo9cJg==",
- "dev": true,
- "engines": {
- "node": ">=6"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/cli-width": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-3.0.0.tgz",
- "integrity": "sha512-FxqpkPPwu1HjuN93Omfm4h8uIanXofW0RxVEW3k5RKx+mJJYSthzNhp32Kzxxy3YAEZ/Dc/EWN1vZRY0+kOhbw==",
- "dev": true,
- "engines": {
- "node": ">= 10"
- }
- },
- "node_modules/cliui": {
- "version": "8.0.1",
- "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz",
- "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==",
- "dev": true,
- "dependencies": {
- "string-width": "^4.2.0",
- "strip-ansi": "^6.0.1",
- "wrap-ansi": "^7.0.0"
- },
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/cliui/node_modules/wrap-ansi": {
- "version": "7.0.0",
- "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
- "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==",
- "dev": true,
- "dependencies": {
- "ansi-styles": "^4.0.0",
- "string-width": "^4.1.0",
- "strip-ansi": "^6.0.0"
- },
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/chalk/wrap-ansi?sponsor=1"
- }
- },
- "node_modules/clone": {
- "version": "1.0.4",
- "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz",
- "integrity": "sha512-JQHZ2QMW6l3aH/j6xCqQThY/9OH4D/9ls34cgkUBiEeocRTU04tHfKPBsUK1PqZCUQM7GiA0IIXJSuXHI64Kbg==",
- "dev": true,
- "engines": {
- "node": ">=0.8"
- }
- },
- "node_modules/co": {
- "version": "4.6.0",
- "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz",
- "integrity": "sha512-QVb0dM5HvG+uaxitm8wONl7jltx8dqhfU33DcqtOZcLSVIKSDDLDi7+0LbAKiyI8hD9u42m2YxXSkMGWThaecQ==",
- "dev": true,
- "engines": {
- "iojs": ">= 1.0.0",
- "node": ">= 0.12.0"
- }
- },
- "node_modules/collect-v8-coverage": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.2.tgz",
- "integrity": "sha512-lHl4d5/ONEbLlJvaJNtsF/Lz+WvB07u2ycqTYbdrq7UypDXailES4valYb2eWiJFxZlVmpGekfqoxQhzyFdT4Q==",
- "dev": true
- },
- "node_modules/color-convert": {
- "version": "2.0.1",
- "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
- "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
- "dev": true,
- "dependencies": {
- "color-name": "~1.1.4"
- },
- "engines": {
- "node": ">=7.0.0"
- }
- },
- "node_modules/color-name": {
- "version": "1.1.4",
- "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
- "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
- "dev": true
- },
- "node_modules/colorette": {
- "version": "2.0.20",
- "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.20.tgz",
- "integrity": "sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w==",
- "dev": true
- },
- "node_modules/combined-stream": {
- "version": "1.0.8",
- "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz",
- "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==",
- "dependencies": {
- "delayed-stream": "~1.0.0"
- },
- "engines": {
- "node": ">= 0.8"
- }
- },
- "node_modules/compact2string": {
- "version": "1.4.1",
- "resolved": "https://registry.npmjs.org/compact2string/-/compact2string-1.4.1.tgz",
- "integrity": "sha512-3D+EY5nsRhqnOwDxveBv5T8wGo4DEvYxjDtPGmdOX+gfr5gE92c2RC0w2wa+xEefm07QuVqqcF3nZJUZ92l/og==",
- "dependencies": {
- "ipaddr.js": ">= 0.1.5"
- }
- },
- "node_modules/concat-map": {
- "version": "0.0.1",
- "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
- "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg=="
- },
- "node_modules/convert-source-map": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz",
- "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==",
- "dev": true
- },
- "node_modules/cookie": {
- "version": "0.5.0",
- "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz",
- "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==",
- "dev": true,
- "engines": {
- "node": ">= 0.6"
- }
- },
- "node_modules/core-util-is": {
- "version": "1.0.3",
- "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz",
- "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ=="
- },
- "node_modules/create-jest": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/create-jest/-/create-jest-29.7.0.tgz",
- "integrity": "sha512-Adz2bdH0Vq3F53KEMJOoftQFutWCukm6J24wbPWRO4k1kMY7gS7ds/uoJkNuV8wDCtWWnuwGcJwpWcih+zEW1Q==",
- "dev": true,
- "dependencies": {
- "@jest/types": "^29.6.3",
- "chalk": "^4.0.0",
- "exit": "^0.1.2",
- "graceful-fs": "^4.2.9",
- "jest-config": "^29.7.0",
- "jest-util": "^29.7.0",
- "prompts": "^2.0.1"
- },
- "bin": {
- "create-jest": "bin/create-jest.js"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/create-require": {
- "version": "1.1.1",
- "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz",
- "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==",
- "dev": true
- },
- "node_modules/cross-spawn": {
- "version": "7.0.3",
- "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz",
- "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==",
- "dev": true,
- "dependencies": {
- "path-key": "^3.1.0",
- "shebang-command": "^2.0.0",
- "which": "^2.0.1"
- },
- "engines": {
- "node": ">= 8"
- }
- },
- "node_modules/cyclist": {
- "version": "0.1.1",
- "resolved": "https://registry.npmjs.org/cyclist/-/cyclist-0.1.1.tgz",
- "integrity": "sha512-w8a8nQk9YSCkMmH2wDbFqpH1XMz7l409mSvWnnG6Iu6D0Ydhvq61XASE7QIaA46FxfG2Ag524ZuGgAy2cXPfsw=="
- },
- "node_modules/dateformat": {
- "version": "4.6.3",
- "resolved": "https://registry.npmjs.org/dateformat/-/dateformat-4.6.3.tgz",
- "integrity": "sha512-2P0p0pFGzHS5EMnhdxQi7aJN+iMheud0UhG4dlE1DLAlvL8JHjJJTX/CSm4JXwV0Ka5nGk3zC5mcb5bUQUxxMA==",
- "dev": true,
- "engines": {
- "node": "*"
- }
- },
- "node_modules/debug": {
- "version": "4.3.4",
- "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz",
- "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==",
- "dependencies": {
- "ms": "2.1.2"
- },
- "engines": {
- "node": ">=6.0"
- },
- "peerDependenciesMeta": {
- "supports-color": {
- "optional": true
- }
- }
- },
- "node_modules/decompress-response": {
- "version": "3.3.0",
- "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz",
- "integrity": "sha512-BzRPQuY1ip+qDonAOz42gRm/pg9F768C+npV/4JOsxRC2sq+Rlk+Q4ZCAsOhnIaMrgarILY+RMUIvMmmX1qAEA==",
- "dependencies": {
- "mimic-response": "^1.0.0"
- },
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/dedent": {
- "version": "1.5.1",
- "resolved": "https://registry.npmjs.org/dedent/-/dedent-1.5.1.tgz",
- "integrity": "sha512-+LxW+KLWxu3HW3M2w2ympwtqPrqYRzU8fqi6Fhd18fBALe15blJPI/I4+UHveMVG6lJqB4JNd4UG0S5cnVHwIg==",
- "dev": true,
- "peerDependencies": {
- "babel-plugin-macros": "^3.1.0"
- },
- "peerDependenciesMeta": {
- "babel-plugin-macros": {
- "optional": true
- }
- }
- },
- "node_modules/deep-is": {
- "version": "0.1.4",
- "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz",
- "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==",
- "dev": true
- },
- "node_modules/deepmerge": {
- "version": "4.3.1",
- "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz",
- "integrity": "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==",
- "dev": true,
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/defaults": {
- "version": "1.0.4",
- "resolved": "https://registry.npmjs.org/defaults/-/defaults-1.0.4.tgz",
- "integrity": "sha512-eFuaLoy/Rxalv2kr+lqMlUnrDWV+3j4pljOIJgLIhI058IQfWJ7vXhyEIHu+HtC738klGALYxOKDO0bQP3tg8A==",
- "dev": true,
- "dependencies": {
- "clone": "^1.0.2"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/define-data-property": {
- "version": "1.1.2",
- "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.2.tgz",
- "integrity": "sha512-SRtsSqsDbgpJBbW3pABMCOt6rQyeM8s8RiyeSN8jYG8sYmt/kGJejbydttUsnDs1tadr19tvhT4ShwMyoqAm4g==",
- "dev": true,
- "dependencies": {
- "es-errors": "^1.3.0",
- "get-intrinsic": "^1.2.2",
- "gopd": "^1.0.1",
- "has-property-descriptors": "^1.0.1"
- },
- "engines": {
- "node": ">= 0.4"
- }
- },
- "node_modules/define-properties": {
- "version": "1.2.1",
- "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz",
- "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==",
- "dev": true,
- "dependencies": {
- "define-data-property": "^1.0.1",
- "has-property-descriptors": "^1.0.0",
- "object-keys": "^1.1.1"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/delayed-stream": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz",
- "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==",
- "engines": {
- "node": ">=0.4.0"
- }
- },
- "node_modules/detect-newline": {
- "version": "3.1.0",
- "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz",
- "integrity": "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/diacritics": {
- "version": "1.3.0",
- "resolved": "https://registry.npmjs.org/diacritics/-/diacritics-1.3.0.tgz",
- "integrity": "sha512-wlwEkqcsaxvPJML+rDh/2iS824jbREk6DUMUKkEaSlxdYHeS43cClJtsWglvw2RfeXGm6ohKDqsXteJ5sP5enA=="
- },
- "node_modules/diff": {
- "version": "4.0.2",
- "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz",
- "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==",
- "dev": true,
- "engines": {
- "node": ">=0.3.1"
- }
- },
- "node_modules/diff-sequences": {
- "version": "29.6.3",
- "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-29.6.3.tgz",
- "integrity": "sha512-EjePK1srD3P08o2j4f0ExnylqRs5B9tJjcp9t1krH2qRi8CCdsYfwe9JgSLurFBWwq4uOlipzfk5fHNvwFKr8Q==",
- "dev": true,
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/dir-glob": {
- "version": "3.0.1",
- "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz",
- "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==",
- "dev": true,
- "dependencies": {
- "path-type": "^4.0.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/doctrine": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz",
- "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==",
- "dev": true,
- "dependencies": {
- "esutils": "^2.0.2"
- },
- "engines": {
- "node": ">=6.0.0"
- }
- },
- "node_modules/dottie": {
- "version": "2.0.6",
- "resolved": "https://registry.npmjs.org/dottie/-/dottie-2.0.6.tgz",
- "integrity": "sha512-iGCHkfUc5kFekGiqhe8B/mdaurD+lakO9txNnTvKtA6PISrw86LgqHvRzWYPyoE2Ph5aMIrCw9/uko6XHTKCwA=="
- },
- "node_modules/electron-to-chromium": {
- "version": "1.4.661",
- "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.661.tgz",
- "integrity": "sha512-AFg4wDHSOk5F+zA8aR+SVIOabu7m0e7BiJnigCvPXzIGy731XENw/lmNxTySpVFtkFEy+eyt4oHhh5FF3NjQNw==",
- "dev": true
- },
- "node_modules/emittery": {
- "version": "0.13.1",
- "resolved": "https://registry.npmjs.org/emittery/-/emittery-0.13.1.tgz",
- "integrity": "sha512-DeWwawk6r5yR9jFgnDKYt4sLS0LmHJJi3ZOnb5/JdbYwj3nW+FxQnHIjhBKz8YLC7oRNPVM9NQ47I3CVx34eqQ==",
- "dev": true,
- "engines": {
- "node": ">=12"
- },
- "funding": {
- "url": "https://github.com/sindresorhus/emittery?sponsor=1"
- }
- },
- "node_modules/emoji-regex": {
- "version": "8.0.0",
- "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz",
- "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==",
- "dev": true
- },
- "node_modules/encoding": {
- "version": "0.1.13",
- "resolved": "https://registry.npmjs.org/encoding/-/encoding-0.1.13.tgz",
- "integrity": "sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A==",
- "optional": true,
- "peer": true,
- "dependencies": {
- "iconv-lite": "^0.6.2"
- }
- },
- "node_modules/encoding/node_modules/iconv-lite": {
- "version": "0.6.3",
- "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz",
- "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==",
- "optional": true,
- "peer": true,
- "dependencies": {
- "safer-buffer": ">= 2.1.2 < 3.0.0"
- },
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/end-of-stream": {
- "version": "1.4.4",
- "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz",
- "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==",
- "dev": true,
- "dependencies": {
- "once": "^1.4.0"
- }
- },
- "node_modules/error-ex": {
- "version": "1.3.2",
- "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz",
- "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==",
- "dev": true,
- "dependencies": {
- "is-arrayish": "^0.2.1"
- }
- },
- "node_modules/es-abstract": {
- "version": "1.22.3",
- "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.22.3.tgz",
- "integrity": "sha512-eiiY8HQeYfYH2Con2berK+To6GrK2RxbPawDkGq4UiCQQfZHb6wX9qQqkbpPqaxQFcl8d9QzZqo0tGE0VcrdwA==",
- "dev": true,
- "dependencies": {
- "array-buffer-byte-length": "^1.0.0",
- "arraybuffer.prototype.slice": "^1.0.2",
- "available-typed-arrays": "^1.0.5",
- "call-bind": "^1.0.5",
- "es-set-tostringtag": "^2.0.1",
- "es-to-primitive": "^1.2.1",
- "function.prototype.name": "^1.1.6",
- "get-intrinsic": "^1.2.2",
- "get-symbol-description": "^1.0.0",
- "globalthis": "^1.0.3",
- "gopd": "^1.0.1",
- "has-property-descriptors": "^1.0.0",
- "has-proto": "^1.0.1",
- "has-symbols": "^1.0.3",
- "hasown": "^2.0.0",
- "internal-slot": "^1.0.5",
- "is-array-buffer": "^3.0.2",
- "is-callable": "^1.2.7",
- "is-negative-zero": "^2.0.2",
- "is-regex": "^1.1.4",
- "is-shared-array-buffer": "^1.0.2",
- "is-string": "^1.0.7",
- "is-typed-array": "^1.1.12",
- "is-weakref": "^1.0.2",
- "object-inspect": "^1.13.1",
- "object-keys": "^1.1.1",
- "object.assign": "^4.1.4",
- "regexp.prototype.flags": "^1.5.1",
- "safe-array-concat": "^1.0.1",
- "safe-regex-test": "^1.0.0",
- "string.prototype.trim": "^1.2.8",
- "string.prototype.trimend": "^1.0.7",
- "string.prototype.trimstart": "^1.0.7",
- "typed-array-buffer": "^1.0.0",
- "typed-array-byte-length": "^1.0.0",
- "typed-array-byte-offset": "^1.0.0",
- "typed-array-length": "^1.0.4",
- "unbox-primitive": "^1.0.2",
- "which-typed-array": "^1.1.13"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/es-array-method-boxes-properly": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/es-array-method-boxes-properly/-/es-array-method-boxes-properly-1.0.0.tgz",
- "integrity": "sha512-wd6JXUmyHmt8T5a2xreUwKcGPq6f1f+WwIJkijUqiGcJz1qqnZgP6XIK+QyIWU5lT7imeNxUll48bziG+TSYcA==",
- "dev": true
- },
- "node_modules/es-errors": {
- "version": "1.3.0",
- "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz",
- "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==",
- "dev": true,
- "engines": {
- "node": ">= 0.4"
- }
- },
- "node_modules/es-set-tostringtag": {
- "version": "2.0.2",
- "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.2.tgz",
- "integrity": "sha512-BuDyupZt65P9D2D2vA/zqcI3G5xRsklm5N3xCwuiy+/vKy8i0ifdsQP1sLgO4tZDSCaQUSnmC48khknGMV3D2Q==",
- "dev": true,
- "dependencies": {
- "get-intrinsic": "^1.2.2",
- "has-tostringtag": "^1.0.0",
- "hasown": "^2.0.0"
- },
- "engines": {
- "node": ">= 0.4"
- }
- },
- "node_modules/es-shim-unscopables": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.2.tgz",
- "integrity": "sha512-J3yBRXCzDu4ULnQwxyToo/OjdMx6akgVC7K6few0a7F/0wLtmKKN7I73AH5T2836UuXRqN7Qg+IIUw/+YJksRw==",
- "dev": true,
- "dependencies": {
- "hasown": "^2.0.0"
- }
- },
- "node_modules/es-to-primitive": {
- "version": "1.2.1",
- "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz",
- "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==",
- "dev": true,
- "dependencies": {
- "is-callable": "^1.1.4",
- "is-date-object": "^1.0.1",
- "is-symbol": "^1.0.2"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/esbuild": {
- "version": "0.20.0",
- "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.20.0.tgz",
- "integrity": "sha512-6iwE3Y2RVYCME1jLpBqq7LQWK3MW6vjV2bZy6gt/WrqkY+WE74Spyc0ThAOYpMtITvnjX09CrC6ym7A/m9mebA==",
- "dev": true,
- "hasInstallScript": true,
- "bin": {
- "esbuild": "bin/esbuild"
- },
- "engines": {
- "node": ">=12"
- },
- "optionalDependencies": {
- "@esbuild/aix-ppc64": "0.20.0",
- "@esbuild/android-arm": "0.20.0",
- "@esbuild/android-arm64": "0.20.0",
- "@esbuild/android-x64": "0.20.0",
- "@esbuild/darwin-arm64": "0.20.0",
- "@esbuild/darwin-x64": "0.20.0",
- "@esbuild/freebsd-arm64": "0.20.0",
- "@esbuild/freebsd-x64": "0.20.0",
- "@esbuild/linux-arm": "0.20.0",
- "@esbuild/linux-arm64": "0.20.0",
- "@esbuild/linux-ia32": "0.20.0",
- "@esbuild/linux-loong64": "0.20.0",
- "@esbuild/linux-mips64el": "0.20.0",
- "@esbuild/linux-ppc64": "0.20.0",
- "@esbuild/linux-riscv64": "0.20.0",
- "@esbuild/linux-s390x": "0.20.0",
- "@esbuild/linux-x64": "0.20.0",
- "@esbuild/netbsd-x64": "0.20.0",
- "@esbuild/openbsd-x64": "0.20.0",
- "@esbuild/sunos-x64": "0.20.0",
- "@esbuild/win32-arm64": "0.20.0",
- "@esbuild/win32-ia32": "0.20.0",
- "@esbuild/win32-x64": "0.20.0"
- }
- },
- "node_modules/escalade": {
- "version": "3.1.2",
- "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.2.tgz",
- "integrity": "sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA==",
- "dev": true,
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/escape-string-regexp": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz",
- "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==",
- "dev": true,
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/eslint": {
- "version": "8.56.0",
- "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.56.0.tgz",
- "integrity": "sha512-Go19xM6T9puCOWntie1/P997aXxFsOi37JIHRWI514Hc6ZnaHGKY9xFhrU65RT6CcBEzZoGG1e6Nq+DT04ZtZQ==",
- "dev": true,
- "dependencies": {
- "@eslint-community/eslint-utils": "^4.2.0",
- "@eslint-community/regexpp": "^4.6.1",
- "@eslint/eslintrc": "^2.1.4",
- "@eslint/js": "8.56.0",
- "@humanwhocodes/config-array": "^0.11.13",
- "@humanwhocodes/module-importer": "^1.0.1",
- "@nodelib/fs.walk": "^1.2.8",
- "@ungap/structured-clone": "^1.2.0",
- "ajv": "^6.12.4",
- "chalk": "^4.0.0",
- "cross-spawn": "^7.0.2",
- "debug": "^4.3.2",
- "doctrine": "^3.0.0",
- "escape-string-regexp": "^4.0.0",
- "eslint-scope": "^7.2.2",
- "eslint-visitor-keys": "^3.4.3",
- "espree": "^9.6.1",
- "esquery": "^1.4.2",
- "esutils": "^2.0.2",
- "fast-deep-equal": "^3.1.3",
- "file-entry-cache": "^6.0.1",
- "find-up": "^5.0.0",
- "glob-parent": "^6.0.2",
- "globals": "^13.19.0",
- "graphemer": "^1.4.0",
- "ignore": "^5.2.0",
- "imurmurhash": "^0.1.4",
- "is-glob": "^4.0.0",
- "is-path-inside": "^3.0.3",
- "js-yaml": "^4.1.0",
- "json-stable-stringify-without-jsonify": "^1.0.1",
- "levn": "^0.4.1",
- "lodash.merge": "^4.6.2",
- "minimatch": "^3.1.2",
- "natural-compare": "^1.4.0",
- "optionator": "^0.9.3",
- "strip-ansi": "^6.0.1",
- "text-table": "^0.2.0"
- },
- "bin": {
- "eslint": "bin/eslint.js"
- },
- "engines": {
- "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
- },
- "funding": {
- "url": "https://opencollective.com/eslint"
- }
- },
- "node_modules/eslint-import-resolver-node": {
- "version": "0.3.9",
- "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.9.tgz",
- "integrity": "sha512-WFj2isz22JahUv+B788TlO3N6zL3nNJGU8CcZbPZvVEkBPaJdCV4vy5wyghty5ROFbCRnm132v8BScu5/1BQ8g==",
- "dev": true,
- "dependencies": {
- "debug": "^3.2.7",
- "is-core-module": "^2.13.0",
- "resolve": "^1.22.4"
- }
- },
- "node_modules/eslint-import-resolver-node/node_modules/debug": {
- "version": "3.2.7",
- "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz",
- "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==",
- "dev": true,
- "dependencies": {
- "ms": "^2.1.1"
- }
- },
- "node_modules/eslint-module-utils": {
- "version": "2.8.0",
- "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.8.0.tgz",
- "integrity": "sha512-aWajIYfsqCKRDgUfjEXNN/JlrzauMuSEy5sbd7WXbtW3EH6A6MpwEh42c7qD+MqQo9QMJ6fWLAeIJynx0g6OAw==",
- "dev": true,
- "dependencies": {
- "debug": "^3.2.7"
- },
- "engines": {
- "node": ">=4"
- },
- "peerDependenciesMeta": {
- "eslint": {
- "optional": true
- }
- }
- },
- "node_modules/eslint-module-utils/node_modules/debug": {
- "version": "3.2.7",
- "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz",
- "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==",
- "dev": true,
- "dependencies": {
- "ms": "^2.1.1"
- }
- },
- "node_modules/eslint-plugin-import": {
- "version": "2.29.1",
- "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.29.1.tgz",
- "integrity": "sha512-BbPC0cuExzhiMo4Ff1BTVwHpjjv28C5R+btTOGaCRC7UEz801up0JadwkeSk5Ued6TG34uaczuVuH6qyy5YUxw==",
- "dev": true,
- "dependencies": {
- "array-includes": "^3.1.7",
- "array.prototype.findlastindex": "^1.2.3",
- "array.prototype.flat": "^1.3.2",
- "array.prototype.flatmap": "^1.3.2",
- "debug": "^3.2.7",
- "doctrine": "^2.1.0",
- "eslint-import-resolver-node": "^0.3.9",
- "eslint-module-utils": "^2.8.0",
- "hasown": "^2.0.0",
- "is-core-module": "^2.13.1",
- "is-glob": "^4.0.3",
- "minimatch": "^3.1.2",
- "object.fromentries": "^2.0.7",
- "object.groupby": "^1.0.1",
- "object.values": "^1.1.7",
- "semver": "^6.3.1",
- "tsconfig-paths": "^3.15.0"
- },
- "engines": {
- "node": ">=4"
- },
- "peerDependencies": {
- "eslint": "^2 || ^3 || ^4 || ^5 || ^6 || ^7.2.0 || ^8"
- }
- },
- "node_modules/eslint-plugin-import-helpers": {
- "version": "1.3.1",
- "resolved": "https://registry.npmjs.org/eslint-plugin-import-helpers/-/eslint-plugin-import-helpers-1.3.1.tgz",
- "integrity": "sha512-MrACDozK6TmTJoCFHD71Ew3r5210Za3zlTrhX+fQGsyvxceaFvAI9AcvZ/8oSU0pZ61G3nDEn6mXY0T4S8cJEg==",
- "dev": true,
- "peerDependencies": {
- "eslint": "5.x - 8.x"
- }
- },
- "node_modules/eslint-plugin-import/node_modules/brace-expansion": {
- "version": "1.1.11",
- "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
- "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
- "dev": true,
- "dependencies": {
- "balanced-match": "^1.0.0",
- "concat-map": "0.0.1"
- }
- },
- "node_modules/eslint-plugin-import/node_modules/debug": {
- "version": "3.2.7",
- "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz",
- "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==",
- "dev": true,
- "dependencies": {
- "ms": "^2.1.1"
- }
- },
- "node_modules/eslint-plugin-import/node_modules/doctrine": {
- "version": "2.1.0",
- "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz",
- "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==",
- "dev": true,
- "dependencies": {
- "esutils": "^2.0.2"
- },
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/eslint-plugin-import/node_modules/json5": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.2.tgz",
- "integrity": "sha512-g1MWMLBiz8FKi1e4w0UyVL3w+iJceWAFBAaBnnGKOpNa5f8TLktkbre1+s6oICydWAm+HRUGTmI+//xv2hvXYA==",
- "dev": true,
- "dependencies": {
- "minimist": "^1.2.0"
- },
- "bin": {
- "json5": "lib/cli.js"
- }
- },
- "node_modules/eslint-plugin-import/node_modules/minimatch": {
- "version": "3.1.2",
- "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
- "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
- "dev": true,
- "dependencies": {
- "brace-expansion": "^1.1.7"
- },
- "engines": {
- "node": "*"
- }
- },
- "node_modules/eslint-plugin-import/node_modules/semver": {
- "version": "6.3.1",
- "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
- "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
- "dev": true,
- "bin": {
- "semver": "bin/semver.js"
- }
- },
- "node_modules/eslint-plugin-import/node_modules/strip-bom": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz",
- "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==",
- "dev": true,
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/eslint-plugin-import/node_modules/tsconfig-paths": {
- "version": "3.15.0",
- "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.15.0.tgz",
- "integrity": "sha512-2Ac2RgzDe/cn48GvOe3M+o82pEFewD3UPbyoUHHdKasHwJKjds4fLXWf/Ux5kATBKN20oaFGu+jbElp1pos0mg==",
- "dev": true,
- "dependencies": {
- "@types/json5": "^0.0.29",
- "json5": "^1.0.2",
- "minimist": "^1.2.6",
- "strip-bom": "^3.0.0"
- }
- },
- "node_modules/eslint-scope": {
- "version": "7.2.2",
- "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz",
- "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==",
- "dev": true,
- "dependencies": {
- "esrecurse": "^4.3.0",
- "estraverse": "^5.2.0"
- },
- "engines": {
- "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
- },
- "funding": {
- "url": "https://opencollective.com/eslint"
- }
- },
- "node_modules/eslint-visitor-keys": {
- "version": "3.4.3",
- "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz",
- "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==",
- "dev": true,
- "engines": {
- "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
- },
- "funding": {
- "url": "https://opencollective.com/eslint"
- }
- },
- "node_modules/eslint/node_modules/brace-expansion": {
- "version": "1.1.11",
- "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
- "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
- "dev": true,
- "dependencies": {
- "balanced-match": "^1.0.0",
- "concat-map": "0.0.1"
- }
- },
- "node_modules/eslint/node_modules/minimatch": {
- "version": "3.1.2",
- "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
- "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
- "dev": true,
- "dependencies": {
- "brace-expansion": "^1.1.7"
- },
- "engines": {
- "node": "*"
- }
- },
- "node_modules/espree": {
- "version": "9.6.1",
- "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz",
- "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==",
- "dev": true,
- "dependencies": {
- "acorn": "^8.9.0",
- "acorn-jsx": "^5.3.2",
- "eslint-visitor-keys": "^3.4.1"
- },
- "engines": {
- "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
- },
- "funding": {
- "url": "https://opencollective.com/eslint"
- }
- },
- "node_modules/esprima": {
- "version": "4.0.1",
- "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz",
- "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==",
- "dev": true,
- "bin": {
- "esparse": "bin/esparse.js",
- "esvalidate": "bin/esvalidate.js"
- },
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/esquery": {
- "version": "1.5.0",
- "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz",
- "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==",
- "dev": true,
- "dependencies": {
- "estraverse": "^5.1.0"
- },
- "engines": {
- "node": ">=0.10"
- }
- },
- "node_modules/esrecurse": {
- "version": "4.3.0",
- "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz",
- "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==",
- "dev": true,
- "dependencies": {
- "estraverse": "^5.2.0"
- },
- "engines": {
- "node": ">=4.0"
- }
- },
- "node_modules/estraverse": {
- "version": "5.3.0",
- "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz",
- "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==",
- "dev": true,
- "engines": {
- "node": ">=4.0"
- }
- },
- "node_modules/esutils": {
- "version": "2.0.3",
- "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz",
- "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==",
- "dev": true,
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/event-target-shim": {
- "version": "5.0.1",
- "resolved": "https://registry.npmjs.org/event-target-shim/-/event-target-shim-5.0.1.tgz",
- "integrity": "sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ==",
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/events": {
- "version": "3.3.0",
- "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz",
- "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==",
- "engines": {
- "node": ">=0.8.x"
- }
- },
- "node_modules/execa": {
- "version": "5.1.1",
- "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz",
- "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==",
- "dev": true,
- "dependencies": {
- "cross-spawn": "^7.0.3",
- "get-stream": "^6.0.0",
- "human-signals": "^2.1.0",
- "is-stream": "^2.0.0",
- "merge-stream": "^2.0.0",
- "npm-run-path": "^4.0.1",
- "onetime": "^5.1.2",
- "signal-exit": "^3.0.3",
- "strip-final-newline": "^2.0.0"
- },
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/sindresorhus/execa?sponsor=1"
- }
- },
- "node_modules/exit": {
- "version": "0.1.2",
- "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz",
- "integrity": "sha512-Zk/eNKV2zbjpKzrsQ+n1G6poVbErQxJ0LBOJXaKZ1EViLzH+hrLu9cdXI4zw9dBQJslwBEpbQ2P1oS7nDxs6jQ==",
- "dev": true,
- "engines": {
- "node": ">= 0.8.0"
- }
- },
- "node_modules/expect": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/expect/-/expect-29.7.0.tgz",
- "integrity": "sha512-2Zks0hf1VLFYI1kbh0I5jP3KHHyCHpkfyHBzsSXRFgl/Bg9mWYfMW8oD+PdMPlEwy5HNsR9JutYy6pMeOh61nw==",
- "dev": true,
- "dependencies": {
- "@jest/expect-utils": "^29.7.0",
- "jest-get-type": "^29.6.3",
- "jest-matcher-utils": "^29.7.0",
- "jest-message-util": "^29.7.0",
- "jest-util": "^29.7.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/external-editor": {
- "version": "3.1.0",
- "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz",
- "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==",
- "dev": true,
- "dependencies": {
- "chardet": "^0.7.0",
- "iconv-lite": "^0.4.24",
- "tmp": "^0.0.33"
- },
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/fast-copy": {
- "version": "3.0.1",
- "resolved": "https://registry.npmjs.org/fast-copy/-/fast-copy-3.0.1.tgz",
- "integrity": "sha512-Knr7NOtK3HWRYGtHoJrjkaWepqT8thIVGAwt0p0aUs1zqkAzXZV4vo9fFNwyb5fcqK1GKYFYxldQdIDVKhUAfA==",
- "dev": true
- },
- "node_modules/fast-deep-equal": {
- "version": "3.1.3",
- "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
- "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==",
- "dev": true
- },
- "node_modules/fast-glob": {
- "version": "3.3.2",
- "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz",
- "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==",
- "dev": true,
- "dependencies": {
- "@nodelib/fs.stat": "^2.0.2",
- "@nodelib/fs.walk": "^1.2.3",
- "glob-parent": "^5.1.2",
- "merge2": "^1.3.0",
- "micromatch": "^4.0.4"
- },
- "engines": {
- "node": ">=8.6.0"
- }
- },
- "node_modules/fast-glob/node_modules/glob-parent": {
- "version": "5.1.2",
- "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
- "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
- "dev": true,
- "dependencies": {
- "is-glob": "^4.0.1"
- },
- "engines": {
- "node": ">= 6"
- }
- },
- "node_modules/fast-json-stable-stringify": {
- "version": "2.1.0",
- "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz",
- "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==",
- "dev": true
- },
- "node_modules/fast-levenshtein": {
- "version": "2.0.6",
- "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
- "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==",
- "dev": true
- },
- "node_modules/fast-redact": {
- "version": "3.3.0",
- "resolved": "https://registry.npmjs.org/fast-redact/-/fast-redact-3.3.0.tgz",
- "integrity": "sha512-6T5V1QK1u4oF+ATxs1lWUmlEk6P2T9HqJG3e2DnHOdVgZy2rFJBoEnrIedcTXlkAHU/zKC+7KETJ+KGGKwxgMQ==",
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/fast-safe-stringify": {
- "version": "2.1.1",
- "resolved": "https://registry.npmjs.org/fast-safe-stringify/-/fast-safe-stringify-2.1.1.tgz",
- "integrity": "sha512-W+KJc2dmILlPplD/H4K9l9LcAHAfPtP6BY84uVLXQ6Evcz9Lcg33Y2z1IVblT6xdY54PXYVHEv+0Wpq8Io6zkA==",
- "dev": true
- },
- "node_modules/fastq": {
- "version": "1.17.1",
- "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz",
- "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==",
- "dev": true,
- "dependencies": {
- "reusify": "^1.0.4"
- }
- },
- "node_modules/fb-watchman": {
- "version": "2.0.2",
- "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.2.tgz",
- "integrity": "sha512-p5161BqbuCaSnB8jIbzQHOlpgsPmK5rJVDfDKO91Axs5NC1uu3HRQm6wt9cd9/+GtQQIO53JdGXXoyDpTAsgYA==",
- "dev": true,
- "dependencies": {
- "bser": "2.1.1"
- }
- },
- "node_modules/fifo": {
- "version": "0.1.4",
- "resolved": "https://registry.npmjs.org/fifo/-/fifo-0.1.4.tgz",
- "integrity": "sha512-CpKgwraLo4YWY9cUEICNJ1WcOVR2WE1Jvot3Nvr7FGBiGOKgkn1CmF4zuCl9VxvEh1nQsdYXtQg+V0etPiED6g=="
- },
- "node_modules/figures": {
- "version": "3.2.0",
- "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz",
- "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==",
- "dev": true,
- "dependencies": {
- "escape-string-regexp": "^1.0.5"
- },
- "engines": {
- "node": ">=8"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/figures/node_modules/escape-string-regexp": {
- "version": "1.0.5",
- "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
- "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==",
- "dev": true,
- "engines": {
- "node": ">=0.8.0"
- }
- },
- "node_modules/file-entry-cache": {
- "version": "6.0.1",
- "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz",
- "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==",
- "dev": true,
- "dependencies": {
- "flat-cache": "^3.0.4"
- },
- "engines": {
- "node": "^10.12.0 || >=12.0.0"
- }
- },
- "node_modules/fill-range": {
- "version": "7.0.1",
- "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
- "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
- "dev": true,
- "dependencies": {
- "to-regex-range": "^5.0.1"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/find-up": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz",
- "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==",
- "dev": true,
- "dependencies": {
- "locate-path": "^6.0.0",
- "path-exists": "^4.0.0"
- },
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/flat-cache": {
- "version": "3.2.0",
- "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz",
- "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==",
- "dev": true,
- "dependencies": {
- "flatted": "^3.2.9",
- "keyv": "^4.5.3",
- "rimraf": "^3.0.2"
- },
- "engines": {
- "node": "^10.12.0 || >=12.0.0"
- }
- },
- "node_modules/flatted": {
- "version": "3.2.9",
- "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.9.tgz",
- "integrity": "sha512-36yxDn5H7OFZQla0/jFJmbIKTdZAQHngCedGxiMmpNfEZM0sdEeT+WczLQrjK6D7o2aiyLYDnkw0R3JK0Qv1RQ==",
- "dev": true
- },
- "node_modules/flatten": {
- "version": "0.0.1",
- "resolved": "https://registry.npmjs.org/flatten/-/flatten-0.0.1.tgz",
- "integrity": "sha512-pzNZh42/A2HmcRIpddSP0T+zBofd119o5rNB2u1YHv36CM2C/ietI2ZsjWZ2LSL7J0BNVkFn1a9Ad+cmO2lDQg==",
- "deprecated": "flatten is deprecated in favor of utility frameworks such as lodash.",
- "engines": {
- "node": "*"
- }
- },
- "node_modules/follow-redirects": {
- "version": "1.15.5",
- "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.5.tgz",
- "integrity": "sha512-vSFWUON1B+yAw1VN4xMfxgn5fTUiaOzAJCKBwIIgT/+7CuGy9+r+5gITvP62j3RmaD5Ph65UaERdOSRGUzZtgw==",
- "funding": [
- {
- "type": "individual",
- "url": "https://github.com/sponsors/RubenVerborgh"
- }
- ],
- "engines": {
- "node": ">=4.0"
- },
- "peerDependenciesMeta": {
- "debug": {
- "optional": true
- }
- }
- },
- "node_modules/for-each": {
- "version": "0.3.3",
- "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz",
- "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==",
- "dev": true,
- "dependencies": {
- "is-callable": "^1.1.3"
- }
- },
- "node_modules/form-data": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz",
- "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==",
- "dependencies": {
- "asynckit": "^0.4.0",
- "combined-stream": "^1.0.8",
- "mime-types": "^2.1.12"
- },
- "engines": {
- "node": ">= 6"
- }
- },
- "node_modules/fs-chunk-store": {
- "version": "1.7.0",
- "resolved": "https://registry.npmjs.org/fs-chunk-store/-/fs-chunk-store-1.7.0.tgz",
- "integrity": "sha512-KhjJmZAs2eqfhCb6PdPx4RcZtheGTz86tpTC5JTvqBn/xda+Nb+0C7dCyjOSN7T76H6a56LvH0SVXQMchLXDRw==",
- "dependencies": {
- "mkdirp": "^0.5.1",
- "random-access-file": "^2.0.1",
- "randombytes": "^2.0.3",
- "rimraf": "^2.4.2",
- "run-parallel": "^1.1.2",
- "thunky": "^1.0.1"
- }
- },
- "node_modules/fs-chunk-store/node_modules/mkdirp": {
- "version": "0.5.6",
- "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz",
- "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==",
- "dependencies": {
- "minimist": "^1.2.6"
- },
- "bin": {
- "mkdirp": "bin/cmd.js"
- }
- },
- "node_modules/fs-chunk-store/node_modules/rimraf": {
- "version": "2.7.1",
- "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz",
- "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==",
- "dependencies": {
- "glob": "^7.1.3"
- },
- "bin": {
- "rimraf": "bin.js"
- }
- },
- "node_modules/fs.realpath": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz",
- "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw=="
- },
- "node_modules/fsevents": {
- "version": "2.3.3",
- "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz",
- "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==",
- "dev": true,
- "hasInstallScript": true,
- "optional": true,
- "os": [
- "darwin"
- ],
- "engines": {
- "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
- }
- },
- "node_modules/function-bind": {
- "version": "1.1.2",
- "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz",
- "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==",
- "dev": true,
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/function.prototype.name": {
- "version": "1.1.6",
- "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz",
- "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2",
- "define-properties": "^1.2.0",
- "es-abstract": "^1.22.1",
- "functions-have-names": "^1.2.3"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/functions-have-names": {
- "version": "1.2.3",
- "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz",
- "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==",
- "dev": true,
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/fuse.js": {
- "version": "7.0.0",
- "resolved": "https://registry.npmjs.org/fuse.js/-/fuse.js-7.0.0.tgz",
- "integrity": "sha512-14F4hBIxqKvD4Zz/XjDc3y94mNZN6pRv3U13Udo0lNLCWRBUsrMv2xwcF/y/Z5sV6+FQW+/ow68cHpm4sunt8Q==",
- "engines": {
- "node": ">=10"
- }
- },
- "node_modules/gensync": {
- "version": "1.0.0-beta.2",
- "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz",
- "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==",
- "dev": true,
- "engines": {
- "node": ">=6.9.0"
- }
- },
- "node_modules/get-browser-rtc": {
- "version": "1.1.0",
- "resolved": "https://registry.npmjs.org/get-browser-rtc/-/get-browser-rtc-1.1.0.tgz",
- "integrity": "sha512-MghbMJ61EJrRsDe7w1Bvqt3ZsBuqhce5nrn/XAwgwOXhcsz53/ltdxOse1h/8eKXj5slzxdsz56g5rzOFSGwfQ=="
- },
- "node_modules/get-caller-file": {
- "version": "2.0.5",
- "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz",
- "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==",
- "dev": true,
- "engines": {
- "node": "6.* || 8.* || >= 10.*"
- }
- },
- "node_modules/get-intrinsic": {
- "version": "1.2.4",
- "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz",
- "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==",
- "dev": true,
- "dependencies": {
- "es-errors": "^1.3.0",
- "function-bind": "^1.1.2",
- "has-proto": "^1.0.1",
- "has-symbols": "^1.0.3",
- "hasown": "^2.0.0"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/get-package-type": {
- "version": "0.1.0",
- "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz",
- "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==",
- "dev": true,
- "engines": {
- "node": ">=8.0.0"
- }
- },
- "node_modules/get-stream": {
- "version": "6.0.1",
- "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz",
- "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==",
- "dev": true,
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/get-symbol-description": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.2.tgz",
- "integrity": "sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.5",
- "es-errors": "^1.3.0",
- "get-intrinsic": "^1.2.4"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/get-tsconfig": {
- "version": "4.7.2",
- "resolved": "https://registry.npmjs.org/get-tsconfig/-/get-tsconfig-4.7.2.tgz",
- "integrity": "sha512-wuMsz4leaj5hbGgg4IvDU0bqJagpftG5l5cXIAvo8uZrqn0NJqwtfupTN00VnkQJPcIRrxYrm1Ue24btpCha2A==",
- "dev": true,
- "dependencies": {
- "resolve-pkg-maps": "^1.0.0"
- },
- "funding": {
- "url": "https://github.com/privatenumber/get-tsconfig?sponsor=1"
- }
- },
- "node_modules/glob": {
- "version": "7.2.3",
- "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz",
- "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==",
- "dependencies": {
- "fs.realpath": "^1.0.0",
- "inflight": "^1.0.4",
- "inherits": "2",
- "minimatch": "^3.1.1",
- "once": "^1.3.0",
- "path-is-absolute": "^1.0.0"
- },
- "engines": {
- "node": "*"
- },
- "funding": {
- "url": "https://github.com/sponsors/isaacs"
- }
- },
- "node_modules/glob-parent": {
- "version": "6.0.2",
- "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz",
- "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==",
- "dev": true,
- "dependencies": {
- "is-glob": "^4.0.3"
- },
- "engines": {
- "node": ">=10.13.0"
- }
- },
- "node_modules/glob/node_modules/brace-expansion": {
- "version": "1.1.11",
- "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
- "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
- "dependencies": {
- "balanced-match": "^1.0.0",
- "concat-map": "0.0.1"
- }
- },
- "node_modules/glob/node_modules/minimatch": {
- "version": "3.1.2",
- "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
- "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
- "dependencies": {
- "brace-expansion": "^1.1.7"
- },
- "engines": {
- "node": "*"
- }
- },
- "node_modules/globals": {
- "version": "13.24.0",
- "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz",
- "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==",
- "dev": true,
- "dependencies": {
- "type-fest": "^0.20.2"
- },
- "engines": {
- "node": ">=8"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/globalthis": {
- "version": "1.0.3",
- "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.3.tgz",
- "integrity": "sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA==",
- "dev": true,
- "dependencies": {
- "define-properties": "^1.1.3"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/globby": {
- "version": "11.1.0",
- "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz",
- "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==",
- "dev": true,
- "dependencies": {
- "array-union": "^2.1.0",
- "dir-glob": "^3.0.1",
- "fast-glob": "^3.2.9",
- "ignore": "^5.2.0",
- "merge2": "^1.4.1",
- "slash": "^3.0.0"
- },
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/gopd": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz",
- "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==",
- "dev": true,
- "dependencies": {
- "get-intrinsic": "^1.1.3"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/graceful-fs": {
- "version": "4.2.11",
- "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz",
- "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==",
- "dev": true
- },
- "node_modules/graphemer": {
- "version": "1.4.0",
- "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz",
- "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==",
- "dev": true
- },
- "node_modules/graphql": {
- "version": "16.8.1",
- "resolved": "https://registry.npmjs.org/graphql/-/graphql-16.8.1.tgz",
- "integrity": "sha512-59LZHPdGZVh695Ud9lRzPBVTtlX9ZCV150Er2W43ro37wVof0ctenSaskPPjN7lVTIN8mSZt8PHUNKZuNQUuxw==",
- "dev": true,
- "engines": {
- "node": "^12.22.0 || ^14.16.0 || ^16.0.0 || >=17.0.0"
- }
- },
- "node_modules/has-bigints": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz",
- "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==",
- "dev": true,
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/has-flag": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
- "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/has-property-descriptors": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.1.tgz",
- "integrity": "sha512-VsX8eaIewvas0xnvinAe9bw4WfIeODpGYikiWYLH+dma0Jw6KHYqWiWfhQlgOVK8D6PvjubK5Uc4P0iIhIcNVg==",
- "dev": true,
- "dependencies": {
- "get-intrinsic": "^1.2.2"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/has-proto": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz",
- "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==",
- "dev": true,
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/has-symbols": {
- "version": "1.0.3",
- "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz",
- "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==",
- "dev": true,
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/has-tostringtag": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz",
- "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==",
- "dev": true,
- "dependencies": {
- "has-symbols": "^1.0.3"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/hasown": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.0.tgz",
- "integrity": "sha512-vUptKVTpIJhcczKBbgnS+RtcuYMB8+oNzPK2/Hp3hanz8JmpATdmmgLgSaadVREkDm+e2giHwY3ZRkyjSIDDFA==",
- "dev": true,
- "dependencies": {
- "function-bind": "^1.1.2"
- },
- "engines": {
- "node": ">= 0.4"
- }
- },
- "node_modules/hat": {
- "version": "0.0.3",
- "resolved": "https://registry.npmjs.org/hat/-/hat-0.0.3.tgz",
- "integrity": "sha512-zpImx2GoKXy42fVDSEad2BPKuSQdLcqsCYa48K3zHSzM/ugWuYjLDr8IXxpVuL7uCLHw56eaiLxCRthhOzf5ug==",
- "engines": {
- "node": "*"
- }
- },
- "node_modules/headers-polyfill": {
- "version": "4.0.2",
- "resolved": "https://registry.npmjs.org/headers-polyfill/-/headers-polyfill-4.0.2.tgz",
- "integrity": "sha512-EWGTfnTqAO2L/j5HZgoM/3z82L7necsJ0pO9Tp0X1wil3PDLrkypTBRgVO2ExehEEvUycejZD3FuRaXpZZc3kw==",
- "dev": true
- },
- "node_modules/help-me": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/help-me/-/help-me-5.0.0.tgz",
- "integrity": "sha512-7xgomUX6ADmcYzFik0HzAxh/73YlKR9bmFzf51CZwR+b6YtzU2m0u49hQCqV6SvlqIqsaxovfwdvbnsw3b/zpg==",
- "dev": true
- },
- "node_modules/html-escaper": {
- "version": "2.0.2",
- "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz",
- "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==",
- "dev": true
- },
- "node_modules/human-signals": {
- "version": "2.1.0",
- "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz",
- "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==",
- "dev": true,
- "engines": {
- "node": ">=10.17.0"
- }
- },
- "node_modules/iconv-lite": {
- "version": "0.4.24",
- "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
- "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
- "dependencies": {
- "safer-buffer": ">= 2.1.2 < 3"
- },
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/ieee754": {
- "version": "1.2.1",
- "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz",
- "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==",
- "funding": [
- {
- "type": "github",
- "url": "https://github.com/sponsors/feross"
- },
- {
- "type": "patreon",
- "url": "https://www.patreon.com/feross"
- },
- {
- "type": "consulting",
- "url": "https://feross.org/support"
- }
- ]
- },
- "node_modules/ignore": {
- "version": "5.3.1",
- "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.1.tgz",
- "integrity": "sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw==",
- "dev": true,
- "engines": {
- "node": ">= 4"
- }
- },
- "node_modules/immediate-chunk-store": {
- "version": "1.0.8",
- "resolved": "https://registry.npmjs.org/immediate-chunk-store/-/immediate-chunk-store-1.0.8.tgz",
- "integrity": "sha512-0tQyTytUaIUskpv5j5L5ZeQuEjYDl9QIekwDUisdqpAM81OZjBaEIriW7hoiRLaLNxj1fXE8e1yx5JaCGrrE7A=="
- },
- "node_modules/import-fresh": {
- "version": "3.3.0",
- "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz",
- "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==",
- "dev": true,
- "dependencies": {
- "parent-module": "^1.0.0",
- "resolve-from": "^4.0.0"
- },
- "engines": {
- "node": ">=6"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/import-local": {
- "version": "3.1.0",
- "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz",
- "integrity": "sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg==",
- "dev": true,
- "dependencies": {
- "pkg-dir": "^4.2.0",
- "resolve-cwd": "^3.0.0"
- },
- "bin": {
- "import-local-fixture": "fixtures/cli.js"
- },
- "engines": {
- "node": ">=8"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/imurmurhash": {
- "version": "0.1.4",
- "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
- "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==",
- "dev": true,
- "engines": {
- "node": ">=0.8.19"
- }
- },
- "node_modules/inflection": {
- "version": "1.13.4",
- "resolved": "https://registry.npmjs.org/inflection/-/inflection-1.13.4.tgz",
- "integrity": "sha512-6I/HUDeYFfuNCVS3td055BaXBwKYuzw7K3ExVMStBowKo9oOAMJIXIHvdyR3iboTCp1b+1i5DSkIZTcwIktuDw==",
- "engines": [
- "node >= 0.4.0"
- ]
- },
- "node_modules/inflight": {
- "version": "1.0.6",
- "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz",
- "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==",
- "dependencies": {
- "once": "^1.3.0",
- "wrappy": "1"
- }
- },
- "node_modules/inherits": {
- "version": "2.0.4",
- "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
- "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ=="
- },
- "node_modules/inquirer": {
- "version": "8.2.6",
- "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-8.2.6.tgz",
- "integrity": "sha512-M1WuAmb7pn9zdFRtQYk26ZBoY043Sse0wVDdk4Bppr+JOXyQYybdtvK+l9wUibhtjdjvtoiNy8tk+EgsYIUqKg==",
- "dev": true,
- "dependencies": {
- "ansi-escapes": "^4.2.1",
- "chalk": "^4.1.1",
- "cli-cursor": "^3.1.0",
- "cli-width": "^3.0.0",
- "external-editor": "^3.0.3",
- "figures": "^3.0.0",
- "lodash": "^4.17.21",
- "mute-stream": "0.0.8",
- "ora": "^5.4.1",
- "run-async": "^2.4.0",
- "rxjs": "^7.5.5",
- "string-width": "^4.1.0",
- "strip-ansi": "^6.0.0",
- "through": "^2.3.6",
- "wrap-ansi": "^6.0.1"
- },
- "engines": {
- "node": ">=12.0.0"
- }
- },
- "node_modules/internal-slot": {
- "version": "1.0.7",
- "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.7.tgz",
- "integrity": "sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==",
- "dev": true,
- "dependencies": {
- "es-errors": "^1.3.0",
- "hasown": "^2.0.0",
- "side-channel": "^1.0.4"
- },
- "engines": {
- "node": ">= 0.4"
- }
- },
- "node_modules/inversify": {
- "version": "6.0.2",
- "resolved": "https://registry.npmjs.org/inversify/-/inversify-6.0.2.tgz",
- "integrity": "sha512-i9m8j/7YIv4mDuYXUAcrpKPSaju/CIly9AHK5jvCBeoiM/2KEsuCQTTP+rzSWWpLYWRukdXFSl6ZTk2/uumbiA=="
- },
- "node_modules/ip": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/ip/-/ip-2.0.0.tgz",
- "integrity": "sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ==",
- "optional": true,
- "peer": true
- },
- "node_modules/ip-set": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/ip-set/-/ip-set-1.0.2.tgz",
- "integrity": "sha512-Mb6kv78bTi4RNAIIWL8Bbre7hXOR2pNUi3j8FaQkLaitf/ZWxkq3/iIwXNYk2ACO3IMfdVdQrOkUtwZblO7uBA==",
- "dependencies": {
- "ip": "^1.1.3"
- }
- },
- "node_modules/ip-set/node_modules/ip": {
- "version": "1.1.8",
- "resolved": "https://registry.npmjs.org/ip/-/ip-1.1.8.tgz",
- "integrity": "sha512-PuExPYUiu6qMBQb4l06ecm6T6ujzhmh+MeJcW9wa89PoAz5pvd4zPgN5WJV104mb6S2T1AwNIAaB70JNrLQWhg=="
- },
- "node_modules/ipaddr.js": {
- "version": "2.1.0",
- "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-2.1.0.tgz",
- "integrity": "sha512-LlbxQ7xKzfBusov6UMi4MFpEg0m+mAm9xyNGEduwXMEDuf4WfzB/RZwMVYEd7IKGvh4IUkEXYxtAVu9T3OelJQ==",
- "engines": {
- "node": ">= 10"
- }
- },
- "node_modules/is-array-buffer": {
- "version": "3.0.4",
- "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.4.tgz",
- "integrity": "sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2",
- "get-intrinsic": "^1.2.1"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/is-arrayish": {
- "version": "0.2.1",
- "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz",
- "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==",
- "dev": true
- },
- "node_modules/is-bigint": {
- "version": "1.0.4",
- "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz",
- "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==",
- "dev": true,
- "dependencies": {
- "has-bigints": "^1.0.1"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/is-binary-path": {
- "version": "2.1.0",
- "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
- "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
- "dev": true,
- "dependencies": {
- "binary-extensions": "^2.0.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/is-boolean-object": {
- "version": "1.1.2",
- "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz",
- "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2",
- "has-tostringtag": "^1.0.0"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/is-callable": {
- "version": "1.2.7",
- "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz",
- "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==",
- "dev": true,
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/is-core-module": {
- "version": "2.13.1",
- "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz",
- "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==",
- "dev": true,
- "dependencies": {
- "hasown": "^2.0.0"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/is-date-object": {
- "version": "1.0.5",
- "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz",
- "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==",
- "dev": true,
- "dependencies": {
- "has-tostringtag": "^1.0.0"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/is-extglob": {
- "version": "2.1.1",
- "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
- "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==",
- "dev": true,
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/is-fullwidth-code-point": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
- "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/is-generator-fn": {
- "version": "2.1.0",
- "resolved": "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz",
- "integrity": "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==",
- "dev": true,
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/is-glob": {
- "version": "4.0.3",
- "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
- "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
- "dev": true,
- "dependencies": {
- "is-extglob": "^2.1.1"
- },
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/is-interactive": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/is-interactive/-/is-interactive-1.0.0.tgz",
- "integrity": "sha512-2HvIEKRoqS62guEC+qBjpvRubdX910WCMuJTZ+I9yvqKU2/12eSL549HMwtabb4oupdj2sMP50k+XJfB/8JE6w==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/is-negative-zero": {
- "version": "2.0.2",
- "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.2.tgz",
- "integrity": "sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA==",
- "dev": true,
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/is-node-process": {
- "version": "1.2.0",
- "resolved": "https://registry.npmjs.org/is-node-process/-/is-node-process-1.2.0.tgz",
- "integrity": "sha512-Vg4o6/fqPxIjtxgUH5QLJhwZ7gW5diGCVlXpuUfELC62CuxM1iHcRe51f2W1FDy04Ai4KJkagKjx3XaqyfRKXw==",
- "dev": true
- },
- "node_modules/is-number": {
- "version": "7.0.0",
- "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
- "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
- "dev": true,
- "engines": {
- "node": ">=0.12.0"
- }
- },
- "node_modules/is-number-object": {
- "version": "1.0.7",
- "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz",
- "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==",
- "dev": true,
- "dependencies": {
- "has-tostringtag": "^1.0.0"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/is-path-inside": {
- "version": "3.0.3",
- "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz",
- "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/is-regex": {
- "version": "1.1.4",
- "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz",
- "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2",
- "has-tostringtag": "^1.0.0"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/is-shared-array-buffer": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz",
- "integrity": "sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/is-stream": {
- "version": "2.0.1",
- "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz",
- "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==",
- "dev": true,
- "engines": {
- "node": ">=8"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/is-string": {
- "version": "1.0.7",
- "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz",
- "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==",
- "dev": true,
- "dependencies": {
- "has-tostringtag": "^1.0.0"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/is-symbol": {
- "version": "1.0.4",
- "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz",
- "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==",
- "dev": true,
- "dependencies": {
- "has-symbols": "^1.0.2"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/is-typed-array": {
- "version": "1.1.13",
- "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.13.tgz",
- "integrity": "sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==",
- "dev": true,
- "dependencies": {
- "which-typed-array": "^1.1.14"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/is-unicode-supported": {
- "version": "0.1.0",
- "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz",
- "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==",
- "dev": true,
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/is-weakref": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz",
- "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/isarray": {
- "version": "0.0.1",
- "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz",
- "integrity": "sha512-D2S+3GLxWH+uhrNEcoh/fnmYeP8E8/zHl644d/jdA0g2uyXvy3sb0qxotE+ne0LtccHknQzWwZEzhak7oJ0COQ=="
- },
- "node_modules/isexe": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
- "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==",
- "dev": true
- },
- "node_modules/istanbul-lib-coverage": {
- "version": "3.2.2",
- "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.2.tgz",
- "integrity": "sha512-O8dpsF+r0WV/8MNRKfnmrtCWhuKjxrq2w+jpzBL5UZKTi2LeVWnWOmWRxFlesJONmc+wLAGvKQZEOanko0LFTg==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/istanbul-lib-instrument": {
- "version": "6.0.1",
- "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-6.0.1.tgz",
- "integrity": "sha512-EAMEJBsYuyyztxMxW3g7ugGPkrZsV57v0Hmv3mm1uQsmB+QnZuepg731CRaIgeUVSdmsTngOkSnauNF8p7FIhA==",
- "dev": true,
- "dependencies": {
- "@babel/core": "^7.12.3",
- "@babel/parser": "^7.14.7",
- "@istanbuljs/schema": "^0.1.2",
- "istanbul-lib-coverage": "^3.2.0",
- "semver": "^7.5.4"
- },
- "engines": {
- "node": ">=10"
- }
- },
- "node_modules/istanbul-lib-report": {
- "version": "3.0.1",
- "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.1.tgz",
- "integrity": "sha512-GCfE1mtsHGOELCU8e/Z7YWzpmybrx/+dSTfLrvY8qRmaY6zXTKWn6WQIjaAFw069icm6GVMNkgu0NzI4iPZUNw==",
- "dev": true,
- "dependencies": {
- "istanbul-lib-coverage": "^3.0.0",
- "make-dir": "^4.0.0",
- "supports-color": "^7.1.0"
- },
- "engines": {
- "node": ">=10"
- }
- },
- "node_modules/istanbul-lib-source-maps": {
- "version": "4.0.1",
- "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz",
- "integrity": "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==",
- "dev": true,
- "dependencies": {
- "debug": "^4.1.1",
- "istanbul-lib-coverage": "^3.0.0",
- "source-map": "^0.6.1"
- },
- "engines": {
- "node": ">=10"
- }
- },
- "node_modules/istanbul-reports": {
- "version": "3.1.6",
- "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.6.tgz",
- "integrity": "sha512-TLgnMkKg3iTDsQ9PbPTdpfAK2DzjF9mqUG7RMgcQl8oFjad8ob4laGxv5XV5U9MAfx8D6tSJiUyuAwzLicaxlg==",
- "dev": true,
- "dependencies": {
- "html-escaper": "^2.0.0",
- "istanbul-lib-report": "^3.0.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/jest": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest/-/jest-29.7.0.tgz",
- "integrity": "sha512-NIy3oAFp9shda19hy4HK0HRTWKtPJmGdnvywu01nOqNC2vZg+Z+fvJDxpMQA88eb2I9EcafcdjYgsDthnYTvGw==",
- "dev": true,
- "dependencies": {
- "@jest/core": "^29.7.0",
- "@jest/types": "^29.6.3",
- "import-local": "^3.0.2",
- "jest-cli": "^29.7.0"
- },
- "bin": {
- "jest": "bin/jest.js"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- },
- "peerDependencies": {
- "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0"
- },
- "peerDependenciesMeta": {
- "node-notifier": {
- "optional": true
- }
- }
- },
- "node_modules/jest-changed-files": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-29.7.0.tgz",
- "integrity": "sha512-fEArFiwf1BpQ+4bXSprcDc3/x4HSzL4al2tozwVpDFpsxALjLYdyiIK4e5Vz66GQJIbXJ82+35PtysofptNX2w==",
- "dev": true,
- "dependencies": {
- "execa": "^5.0.0",
- "jest-util": "^29.7.0",
- "p-limit": "^3.1.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-circus": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-circus/-/jest-circus-29.7.0.tgz",
- "integrity": "sha512-3E1nCMgipcTkCocFwM90XXQab9bS+GMsjdpmPrlelaxwD93Ad8iVEjX/vvHPdLPnFf+L40u+5+iutRdA1N9myw==",
- "dev": true,
- "dependencies": {
- "@jest/environment": "^29.7.0",
- "@jest/expect": "^29.7.0",
- "@jest/test-result": "^29.7.0",
- "@jest/types": "^29.6.3",
- "@types/node": "*",
- "chalk": "^4.0.0",
- "co": "^4.6.0",
- "dedent": "^1.0.0",
- "is-generator-fn": "^2.0.0",
- "jest-each": "^29.7.0",
- "jest-matcher-utils": "^29.7.0",
- "jest-message-util": "^29.7.0",
- "jest-runtime": "^29.7.0",
- "jest-snapshot": "^29.7.0",
- "jest-util": "^29.7.0",
- "p-limit": "^3.1.0",
- "pretty-format": "^29.7.0",
- "pure-rand": "^6.0.0",
- "slash": "^3.0.0",
- "stack-utils": "^2.0.3"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-cli": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-29.7.0.tgz",
- "integrity": "sha512-OVVobw2IubN/GSYsxETi+gOe7Ka59EFMR/twOU3Jb2GnKKeMGJB5SGUUrEz3SFVmJASUdZUzy83sLNNQ2gZslg==",
- "dev": true,
- "dependencies": {
- "@jest/core": "^29.7.0",
- "@jest/test-result": "^29.7.0",
- "@jest/types": "^29.6.3",
- "chalk": "^4.0.0",
- "create-jest": "^29.7.0",
- "exit": "^0.1.2",
- "import-local": "^3.0.2",
- "jest-config": "^29.7.0",
- "jest-util": "^29.7.0",
- "jest-validate": "^29.7.0",
- "yargs": "^17.3.1"
- },
- "bin": {
- "jest": "bin/jest.js"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- },
- "peerDependencies": {
- "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0"
- },
- "peerDependenciesMeta": {
- "node-notifier": {
- "optional": true
- }
- }
- },
- "node_modules/jest-config": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-29.7.0.tgz",
- "integrity": "sha512-uXbpfeQ7R6TZBqI3/TxCU4q4ttk3u0PJeC+E0zbfSoSjq6bJ7buBPxzQPL0ifrkY4DNu4JUdk0ImlBUYi840eQ==",
- "dev": true,
- "dependencies": {
- "@babel/core": "^7.11.6",
- "@jest/test-sequencer": "^29.7.0",
- "@jest/types": "^29.6.3",
- "babel-jest": "^29.7.0",
- "chalk": "^4.0.0",
- "ci-info": "^3.2.0",
- "deepmerge": "^4.2.2",
- "glob": "^7.1.3",
- "graceful-fs": "^4.2.9",
- "jest-circus": "^29.7.0",
- "jest-environment-node": "^29.7.0",
- "jest-get-type": "^29.6.3",
- "jest-regex-util": "^29.6.3",
- "jest-resolve": "^29.7.0",
- "jest-runner": "^29.7.0",
- "jest-util": "^29.7.0",
- "jest-validate": "^29.7.0",
- "micromatch": "^4.0.4",
- "parse-json": "^5.2.0",
- "pretty-format": "^29.7.0",
- "slash": "^3.0.0",
- "strip-json-comments": "^3.1.1"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- },
- "peerDependencies": {
- "@types/node": "*",
- "ts-node": ">=9.0.0"
- },
- "peerDependenciesMeta": {
- "@types/node": {
- "optional": true
- },
- "ts-node": {
- "optional": true
- }
- }
- },
- "node_modules/jest-diff": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-29.7.0.tgz",
- "integrity": "sha512-LMIgiIrhigmPrs03JHpxUh2yISK3vLFPkAodPeo0+BuF7wA2FoQbkEg1u8gBYBThncu7e1oEDUfIXVuTqLRUjw==",
- "dev": true,
- "dependencies": {
- "chalk": "^4.0.0",
- "diff-sequences": "^29.6.3",
- "jest-get-type": "^29.6.3",
- "pretty-format": "^29.7.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-docblock": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-29.7.0.tgz",
- "integrity": "sha512-q617Auw3A612guyaFgsbFeYpNP5t2aoUNLwBUbc/0kD1R4t9ixDbyFTHd1nok4epoVFpr7PmeWHrhvuV3XaJ4g==",
- "dev": true,
- "dependencies": {
- "detect-newline": "^3.0.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-each": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-29.7.0.tgz",
- "integrity": "sha512-gns+Er14+ZrEoC5fhOfYCY1LOHHr0TI+rQUHZS8Ttw2l7gl+80eHc/gFf2Ktkw0+SIACDTeWvpFcv3B04VembQ==",
- "dev": true,
- "dependencies": {
- "@jest/types": "^29.6.3",
- "chalk": "^4.0.0",
- "jest-get-type": "^29.6.3",
- "jest-util": "^29.7.0",
- "pretty-format": "^29.7.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-environment-node": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-29.7.0.tgz",
- "integrity": "sha512-DOSwCRqXirTOyheM+4d5YZOrWcdu0LNZ87ewUoywbcb2XR4wKgqiG8vNeYwhjFMbEkfju7wx2GYH0P2gevGvFw==",
- "dev": true,
- "dependencies": {
- "@jest/environment": "^29.7.0",
- "@jest/fake-timers": "^29.7.0",
- "@jest/types": "^29.6.3",
- "@types/node": "*",
- "jest-mock": "^29.7.0",
- "jest-util": "^29.7.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-get-type": {
- "version": "29.6.3",
- "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-29.6.3.tgz",
- "integrity": "sha512-zrteXnqYxfQh7l5FHyL38jL39di8H8rHoecLH3JNxH3BwOrBsNeabdap5e0I23lD4HHI8W5VFBZqG4Eaq5LNcw==",
- "dev": true,
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-haste-map": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-29.7.0.tgz",
- "integrity": "sha512-fP8u2pyfqx0K1rGn1R9pyE0/KTn+G7PxktWidOBTqFPLYX0b9ksaMFkhK5vrS3DVun09pckLdlx90QthlW7AmA==",
- "dev": true,
- "dependencies": {
- "@jest/types": "^29.6.3",
- "@types/graceful-fs": "^4.1.3",
- "@types/node": "*",
- "anymatch": "^3.0.3",
- "fb-watchman": "^2.0.0",
- "graceful-fs": "^4.2.9",
- "jest-regex-util": "^29.6.3",
- "jest-util": "^29.7.0",
- "jest-worker": "^29.7.0",
- "micromatch": "^4.0.4",
- "walker": "^1.0.8"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- },
- "optionalDependencies": {
- "fsevents": "^2.3.2"
- }
- },
- "node_modules/jest-leak-detector": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-29.7.0.tgz",
- "integrity": "sha512-kYA8IJcSYtST2BY9I+SMC32nDpBT3J2NvWJx8+JCuCdl/CR1I4EKUJROiP8XtCcxqgTTBGJNdbB1A8XRKbTetw==",
- "dev": true,
- "dependencies": {
- "jest-get-type": "^29.6.3",
- "pretty-format": "^29.7.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-matcher-utils": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-29.7.0.tgz",
- "integrity": "sha512-sBkD+Xi9DtcChsI3L3u0+N0opgPYnCRPtGcQYrgXmR+hmt/fYfWAL0xRXYU8eWOdfuLgBe0YCW3AFtnRLagq/g==",
- "dev": true,
- "dependencies": {
- "chalk": "^4.0.0",
- "jest-diff": "^29.7.0",
- "jest-get-type": "^29.6.3",
- "pretty-format": "^29.7.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-message-util": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-29.7.0.tgz",
- "integrity": "sha512-GBEV4GRADeP+qtB2+6u61stea8mGcOT4mCtrYISZwfu9/ISHFJ/5zOMXYbpBE9RsS5+Gb63DW4FgmnKJ79Kf6w==",
- "dev": true,
- "dependencies": {
- "@babel/code-frame": "^7.12.13",
- "@jest/types": "^29.6.3",
- "@types/stack-utils": "^2.0.0",
- "chalk": "^4.0.0",
- "graceful-fs": "^4.2.9",
- "micromatch": "^4.0.4",
- "pretty-format": "^29.7.0",
- "slash": "^3.0.0",
- "stack-utils": "^2.0.3"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-mock": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-29.7.0.tgz",
- "integrity": "sha512-ITOMZn+UkYS4ZFh83xYAOzWStloNzJFO2s8DWrE4lhtGD+AorgnbkiKERe4wQVBydIGPx059g6riW5Btp6Llnw==",
- "dev": true,
- "dependencies": {
- "@jest/types": "^29.6.3",
- "@types/node": "*",
- "jest-util": "^29.7.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-pnp-resolver": {
- "version": "1.2.3",
- "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.3.tgz",
- "integrity": "sha512-+3NpwQEnRoIBtx4fyhblQDPgJI0H1IEIkX7ShLUjPGA7TtUTvI1oiKi3SR4oBR0hQhQR80l4WAe5RrXBwWMA8w==",
- "dev": true,
- "engines": {
- "node": ">=6"
- },
- "peerDependencies": {
- "jest-resolve": "*"
- },
- "peerDependenciesMeta": {
- "jest-resolve": {
- "optional": true
- }
- }
- },
- "node_modules/jest-regex-util": {
- "version": "29.6.3",
- "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-29.6.3.tgz",
- "integrity": "sha512-KJJBsRCyyLNWCNBOvZyRDnAIfUiRJ8v+hOBQYGn8gDyF3UegwiP4gwRR3/SDa42g1YbVycTidUF3rKjyLFDWbg==",
- "dev": true,
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-resolve": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-29.7.0.tgz",
- "integrity": "sha512-IOVhZSrg+UvVAshDSDtHyFCCBUl/Q3AAJv8iZ6ZjnZ74xzvwuzLXid9IIIPgTnY62SJjfuupMKZsZQRsCvxEgA==",
- "dev": true,
- "dependencies": {
- "chalk": "^4.0.0",
- "graceful-fs": "^4.2.9",
- "jest-haste-map": "^29.7.0",
- "jest-pnp-resolver": "^1.2.2",
- "jest-util": "^29.7.0",
- "jest-validate": "^29.7.0",
- "resolve": "^1.20.0",
- "resolve.exports": "^2.0.0",
- "slash": "^3.0.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-resolve-dependencies": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-29.7.0.tgz",
- "integrity": "sha512-un0zD/6qxJ+S0et7WxeI3H5XSe9lTBBR7bOHCHXkKR6luG5mwDDlIzVQ0V5cZCuoTgEdcdwzTghYkTWfubi+nA==",
- "dev": true,
- "dependencies": {
- "jest-regex-util": "^29.6.3",
- "jest-snapshot": "^29.7.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-runner": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-29.7.0.tgz",
- "integrity": "sha512-fsc4N6cPCAahybGBfTRcq5wFR6fpLznMg47sY5aDpsoejOcVYFb07AHuSnR0liMcPTgBsA3ZJL6kFOjPdoNipQ==",
- "dev": true,
- "dependencies": {
- "@jest/console": "^29.7.0",
- "@jest/environment": "^29.7.0",
- "@jest/test-result": "^29.7.0",
- "@jest/transform": "^29.7.0",
- "@jest/types": "^29.6.3",
- "@types/node": "*",
- "chalk": "^4.0.0",
- "emittery": "^0.13.1",
- "graceful-fs": "^4.2.9",
- "jest-docblock": "^29.7.0",
- "jest-environment-node": "^29.7.0",
- "jest-haste-map": "^29.7.0",
- "jest-leak-detector": "^29.7.0",
- "jest-message-util": "^29.7.0",
- "jest-resolve": "^29.7.0",
- "jest-runtime": "^29.7.0",
- "jest-util": "^29.7.0",
- "jest-watcher": "^29.7.0",
- "jest-worker": "^29.7.0",
- "p-limit": "^3.1.0",
- "source-map-support": "0.5.13"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-runtime": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-29.7.0.tgz",
- "integrity": "sha512-gUnLjgwdGqW7B4LvOIkbKs9WGbn+QLqRQQ9juC6HndeDiezIwhDP+mhMwHWCEcfQ5RUXa6OPnFF8BJh5xegwwQ==",
- "dev": true,
- "dependencies": {
- "@jest/environment": "^29.7.0",
- "@jest/fake-timers": "^29.7.0",
- "@jest/globals": "^29.7.0",
- "@jest/source-map": "^29.6.3",
- "@jest/test-result": "^29.7.0",
- "@jest/transform": "^29.7.0",
- "@jest/types": "^29.6.3",
- "@types/node": "*",
- "chalk": "^4.0.0",
- "cjs-module-lexer": "^1.0.0",
- "collect-v8-coverage": "^1.0.0",
- "glob": "^7.1.3",
- "graceful-fs": "^4.2.9",
- "jest-haste-map": "^29.7.0",
- "jest-message-util": "^29.7.0",
- "jest-mock": "^29.7.0",
- "jest-regex-util": "^29.6.3",
- "jest-resolve": "^29.7.0",
- "jest-snapshot": "^29.7.0",
- "jest-util": "^29.7.0",
- "slash": "^3.0.0",
- "strip-bom": "^4.0.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-snapshot": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-29.7.0.tgz",
- "integrity": "sha512-Rm0BMWtxBcioHr1/OX5YCP8Uov4riHvKPknOGs804Zg9JGZgmIBkbtlxJC/7Z4msKYVbIJtfU+tKb8xlYNfdkw==",
- "dev": true,
- "dependencies": {
- "@babel/core": "^7.11.6",
- "@babel/generator": "^7.7.2",
- "@babel/plugin-syntax-jsx": "^7.7.2",
- "@babel/plugin-syntax-typescript": "^7.7.2",
- "@babel/types": "^7.3.3",
- "@jest/expect-utils": "^29.7.0",
- "@jest/transform": "^29.7.0",
- "@jest/types": "^29.6.3",
- "babel-preset-current-node-syntax": "^1.0.0",
- "chalk": "^4.0.0",
- "expect": "^29.7.0",
- "graceful-fs": "^4.2.9",
- "jest-diff": "^29.7.0",
- "jest-get-type": "^29.6.3",
- "jest-matcher-utils": "^29.7.0",
- "jest-message-util": "^29.7.0",
- "jest-util": "^29.7.0",
- "natural-compare": "^1.4.0",
- "pretty-format": "^29.7.0",
- "semver": "^7.5.3"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-util": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-29.7.0.tgz",
- "integrity": "sha512-z6EbKajIpqGKU56y5KBUgy1dt1ihhQJgWzUlZHArA/+X2ad7Cb5iF+AK1EWVL/Bo7Rz9uurpqw6SiBCefUbCGA==",
- "dev": true,
- "dependencies": {
- "@jest/types": "^29.6.3",
- "@types/node": "*",
- "chalk": "^4.0.0",
- "ci-info": "^3.2.0",
- "graceful-fs": "^4.2.9",
- "picomatch": "^2.2.3"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-validate": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-29.7.0.tgz",
- "integrity": "sha512-ZB7wHqaRGVw/9hST/OuFUReG7M8vKeq0/J2egIGLdvjHCmYqGARhzXmtgi+gVeZ5uXFF219aOc3Ls2yLg27tkw==",
- "dev": true,
- "dependencies": {
- "@jest/types": "^29.6.3",
- "camelcase": "^6.2.0",
- "chalk": "^4.0.0",
- "jest-get-type": "^29.6.3",
- "leven": "^3.1.0",
- "pretty-format": "^29.7.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-validate/node_modules/camelcase": {
- "version": "6.3.0",
- "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz",
- "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==",
- "dev": true,
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/jest-watcher": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-29.7.0.tgz",
- "integrity": "sha512-49Fg7WXkU3Vl2h6LbLtMQ/HyB6rXSIX7SqvBLQmssRBGN9I0PNvPmAmCWSOY6SOvrjhI/F7/bGAv9RtnsPA03g==",
- "dev": true,
- "dependencies": {
- "@jest/test-result": "^29.7.0",
- "@jest/types": "^29.6.3",
- "@types/node": "*",
- "ansi-escapes": "^4.2.1",
- "chalk": "^4.0.0",
- "emittery": "^0.13.1",
- "jest-util": "^29.7.0",
- "string-length": "^4.0.1"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-worker": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-29.7.0.tgz",
- "integrity": "sha512-eIz2msL/EzL9UFTFFx7jBTkeZfku0yUAyZZZmJ93H2TYEiroIx2PQjEXcwYtYl8zXCxb+PAmA2hLIt/6ZEkPHw==",
- "dev": true,
- "dependencies": {
- "@types/node": "*",
- "jest-util": "^29.7.0",
- "merge-stream": "^2.0.0",
- "supports-color": "^8.0.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/jest-worker/node_modules/supports-color": {
- "version": "8.1.1",
- "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz",
- "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==",
- "dev": true,
- "dependencies": {
- "has-flag": "^4.0.0"
- },
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/chalk/supports-color?sponsor=1"
- }
- },
- "node_modules/joycon": {
- "version": "3.1.1",
- "resolved": "https://registry.npmjs.org/joycon/-/joycon-3.1.1.tgz",
- "integrity": "sha512-34wB/Y7MW7bzjKRjUKTa46I2Z7eV62Rkhva+KkopW7Qvv/OSWBqvkSY7vusOPrNuZcUG3tApvdVgNB8POj3SPw==",
- "dev": true,
- "engines": {
- "node": ">=10"
- }
- },
- "node_modules/js-tokens": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz",
- "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==",
- "dev": true
- },
- "node_modules/js-yaml": {
- "version": "4.1.0",
- "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz",
- "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==",
- "dev": true,
- "dependencies": {
- "argparse": "^2.0.1"
- },
- "bin": {
- "js-yaml": "bin/js-yaml.js"
- }
- },
- "node_modules/jsesc": {
- "version": "2.5.2",
- "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz",
- "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==",
- "dev": true,
- "bin": {
- "jsesc": "bin/jsesc"
- },
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/json-buffer": {
- "version": "3.0.1",
- "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz",
- "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==",
- "dev": true
- },
- "node_modules/json-parse-even-better-errors": {
- "version": "2.3.1",
- "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz",
- "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==",
- "dev": true
- },
- "node_modules/json-schema-traverse": {
- "version": "0.4.1",
- "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
- "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
- "dev": true
- },
- "node_modules/json-stable-stringify-without-jsonify": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz",
- "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==",
- "dev": true
- },
- "node_modules/json5": {
- "version": "2.2.3",
- "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz",
- "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==",
- "dev": true,
- "bin": {
- "json5": "lib/cli.js"
- },
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/k-bucket": {
- "version": "0.6.0",
- "resolved": "https://registry.npmjs.org/k-bucket/-/k-bucket-0.6.0.tgz",
- "integrity": "sha512-1zJpqkrLYgolqdO1TE1/FWf+mHfhJKLC2Wpi4JaMFZKi4b6tFEn9/d+JqscBIJw5auWFewp16CSAEetFGEC4NQ==",
- "dependencies": {
- "buffer-equal": "0.0.1",
- "inherits": "^2.0.1"
- }
- },
- "node_modules/k-rpc": {
- "version": "3.7.0",
- "resolved": "https://registry.npmjs.org/k-rpc/-/k-rpc-3.7.0.tgz",
- "integrity": "sha512-XFL8PatIToQ/qhSSAq9FSK73wk4fX4DcHqjnkvSCrWC59PV02Oj1KeYa3KnREAXgA1DlCSzcKjk7M8usnT/dUw==",
- "dependencies": {
- "buffer-equals": "^1.0.3",
- "k-bucket": "^2.0.0",
- "k-rpc-socket": "^1.5.0"
- }
- },
- "node_modules/k-rpc-socket": {
- "version": "1.11.1",
- "resolved": "https://registry.npmjs.org/k-rpc-socket/-/k-rpc-socket-1.11.1.tgz",
- "integrity": "sha512-8xtA8oqbZ6v1Niryp2/g4GxW16EQh5MvrUylQoOG+zcrDff5CKttON2XUXvMwlIHq4/2zfPVFiinAccJ+WhxoA==",
- "dependencies": {
- "bencode": "^2.0.0",
- "chrome-dgram": "^3.0.2",
- "chrome-dns": "^1.0.0",
- "chrome-net": "^3.3.2"
- }
- },
- "node_modules/k-rpc-socket/node_modules/bencode": {
- "version": "2.0.3",
- "resolved": "https://registry.npmjs.org/bencode/-/bencode-2.0.3.tgz",
- "integrity": "sha512-D/vrAD4dLVX23NalHwb8dSvsUsxeRPO8Y7ToKA015JQYq69MLDOMkC0uGZYA/MPpltLO8rt8eqFC2j8DxjTZ/w=="
- },
- "node_modules/k-rpc/node_modules/k-bucket": {
- "version": "2.0.1",
- "resolved": "https://registry.npmjs.org/k-bucket/-/k-bucket-2.0.1.tgz",
- "integrity": "sha512-Xuye90xBBDJJbvNSuy3z/Yl8ceVX02/sopqGUEwJkMgRw+//TQXx0/Hbgp60GsoVfZcCBllQXXp6AWe2INu8pw==",
- "dependencies": {
- "buffer-equal": "0.0.1",
- "randombytes": "^2.0.3"
- }
- },
- "node_modules/kareem": {
- "version": "2.5.1",
- "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.5.1.tgz",
- "integrity": "sha512-7jFxRVm+jD+rkq3kY0iZDJfsO2/t4BBPeEb2qKn2lR/9KhuksYk5hxzfRYWMPV8P/x2d0kHD306YyWLzjjH+uA==",
- "engines": {
- "node": ">=12.0.0"
- }
- },
- "node_modules/keyv": {
- "version": "4.5.4",
- "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz",
- "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==",
- "dev": true,
- "dependencies": {
- "json-buffer": "3.0.1"
- }
- },
- "node_modules/kleur": {
- "version": "3.0.3",
- "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz",
- "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==",
- "dev": true,
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/leven": {
- "version": "3.1.0",
- "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz",
- "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==",
- "dev": true,
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/levn": {
- "version": "0.4.1",
- "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz",
- "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==",
- "dev": true,
- "dependencies": {
- "prelude-ls": "^1.2.1",
- "type-check": "~0.4.0"
- },
- "engines": {
- "node": ">= 0.8.0"
- }
- },
- "node_modules/lines-and-columns": {
- "version": "1.2.4",
- "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz",
- "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==",
- "dev": true
- },
- "node_modules/locate-path": {
- "version": "6.0.0",
- "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz",
- "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==",
- "dev": true,
- "dependencies": {
- "p-locate": "^5.0.0"
- },
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/lodash": {
- "version": "4.17.21",
- "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz",
- "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg=="
- },
- "node_modules/lodash.clonedeep": {
- "version": "4.5.0",
- "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz",
- "integrity": "sha512-H5ZhCF25riFd9uB5UCkVKo61m3S/xZk1x4wA6yp/L3RFP6Z/eHH1ymQcGLo7J3GMPfm0V/7m1tryHuGVxpqEBQ=="
- },
- "node_modules/lodash.memoize": {
- "version": "4.1.2",
- "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz",
- "integrity": "sha512-t7j+NzmgnQzTAYXcsHYLgimltOV1MXHtlOWf6GjL9Kj8GK5FInw5JotxvbOs+IvV1/Dzo04/fCGfLVs7aXb4Ag==",
- "dev": true
- },
- "node_modules/lodash.merge": {
- "version": "4.6.2",
- "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz",
- "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==",
- "dev": true
- },
- "node_modules/log-symbols": {
- "version": "4.1.0",
- "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz",
- "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==",
- "dev": true,
- "dependencies": {
- "chalk": "^4.1.0",
- "is-unicode-supported": "^0.1.0"
- },
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/lru": {
- "version": "2.0.1",
- "resolved": "https://registry.npmjs.org/lru/-/lru-2.0.1.tgz",
- "integrity": "sha512-JGRd3IHM64MPsGVw1Mqbz2Y2HDIePqi/MLfPtdrkHQwvvJnSrS9b6gM3KS9PFR5xJnufXJczHHZSmGqfuII1ew==",
- "dependencies": {
- "inherits": "^2.0.1"
- },
- "engines": {
- "node": ">= 0.4.0"
- }
- },
- "node_modules/lru-cache": {
- "version": "10.2.0",
- "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.2.0.tgz",
- "integrity": "sha512-2bIM8x+VAf6JT4bKAljS1qUWgMsqZRPGJS6FSahIMPVvctcNhyVp7AJu7quxOW9jwkryBReKZY5tY5JYv2n/7Q==",
- "engines": {
- "node": "14 || >=16.14"
- }
- },
- "node_modules/magnet-uri": {
- "version": "6.2.0",
- "resolved": "https://registry.npmjs.org/magnet-uri/-/magnet-uri-6.2.0.tgz",
- "integrity": "sha512-O9AgdDwT771fnUj0giPYu/rACpz8173y8UXCSOdLITjOVfBenZ9H9q3FqQmveK+ORUMuD+BkKNSZP8C3+IMAKQ==",
- "funding": [
- {
- "type": "github",
- "url": "https://github.com/sponsors/feross"
- },
- {
- "type": "patreon",
- "url": "https://www.patreon.com/feross"
- },
- {
- "type": "consulting",
- "url": "https://feross.org/support"
- }
- ],
- "dependencies": {
- "bep53-range": "^1.1.0",
- "thirty-two": "^1.0.2"
- }
- },
- "node_modules/make-dir": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-4.0.0.tgz",
- "integrity": "sha512-hXdUTZYIVOt1Ex//jAQi+wTZZpUpwBj/0QsOzqegb3rGMMeJiSEu5xLHnYfBrRV4RH2+OCSOO95Is/7x1WJ4bw==",
- "dev": true,
- "dependencies": {
- "semver": "^7.5.3"
- },
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/make-error": {
- "version": "1.3.6",
- "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz",
- "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==",
- "dev": true
- },
- "node_modules/makeerror": {
- "version": "1.0.12",
- "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz",
- "integrity": "sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg==",
- "dev": true,
- "dependencies": {
- "tmpl": "1.0.5"
- }
- },
- "node_modules/memory-pager": {
- "version": "1.5.0",
- "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz",
- "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg=="
- },
- "node_modules/merge-stream": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz",
- "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==",
- "dev": true
- },
- "node_modules/merge2": {
- "version": "1.4.1",
- "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz",
- "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==",
- "dev": true,
- "engines": {
- "node": ">= 8"
- }
- },
- "node_modules/micromatch": {
- "version": "4.0.5",
- "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz",
- "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==",
- "dev": true,
- "dependencies": {
- "braces": "^3.0.2",
- "picomatch": "^2.3.1"
- },
- "engines": {
- "node": ">=8.6"
- }
- },
- "node_modules/mime-db": {
- "version": "1.52.0",
- "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz",
- "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==",
- "engines": {
- "node": ">= 0.6"
- }
- },
- "node_modules/mime-types": {
- "version": "2.1.35",
- "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz",
- "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==",
- "dependencies": {
- "mime-db": "1.52.0"
- },
- "engines": {
- "node": ">= 0.6"
- }
- },
- "node_modules/mimic-fn": {
- "version": "2.1.0",
- "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz",
- "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==",
- "dev": true,
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/mimic-response": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz",
- "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==",
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/minimatch": {
- "version": "9.0.3",
- "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz",
- "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==",
- "dev": true,
- "dependencies": {
- "brace-expansion": "^2.0.1"
- },
- "engines": {
- "node": ">=16 || 14 >=14.17"
- },
- "funding": {
- "url": "https://github.com/sponsors/isaacs"
- }
- },
- "node_modules/minimist": {
- "version": "1.2.8",
- "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz",
- "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==",
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/mkdirp-classic": {
- "version": "0.5.3",
- "resolved": "https://registry.npmjs.org/mkdirp-classic/-/mkdirp-classic-0.5.3.tgz",
- "integrity": "sha512-gKLcREMhtuZRwRAfqP3RFW+TK4JqApVBtOIftVgjuABpAtpxhPGaDcfvbhNvD0B8iD1oUr/txX35NjcaY6Ns/A=="
- },
- "node_modules/moment": {
- "version": "2.30.1",
- "resolved": "https://registry.npmjs.org/moment/-/moment-2.30.1.tgz",
- "integrity": "sha512-uEmtNhbDOrWPFS+hdjFCBfy9f2YoyzRpwcl+DqpC6taX21FzsTLQVbMV/W7PzNSX6x/bhC1zA3c2UQ5NzH6how==",
- "engines": {
- "node": "*"
- }
- },
- "node_modules/moment-timezone": {
- "version": "0.5.45",
- "resolved": "https://registry.npmjs.org/moment-timezone/-/moment-timezone-0.5.45.tgz",
- "integrity": "sha512-HIWmqA86KcmCAhnMAN0wuDOARV/525R2+lOLotuGFzn4HO+FH+/645z2wx0Dt3iDv6/p61SIvKnDstISainhLQ==",
- "dependencies": {
- "moment": "^2.29.4"
- },
- "engines": {
- "node": "*"
- }
- },
- "node_modules/mongodb": {
- "version": "6.3.0",
- "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-6.3.0.tgz",
- "integrity": "sha512-tt0KuGjGtLUhLoU263+xvQmPHEGTw5LbcNC73EoFRYgSHwZt5tsoJC110hDyO1kjQzpgNrpdcSza9PknWN4LrA==",
- "dependencies": {
- "@mongodb-js/saslprep": "^1.1.0",
- "bson": "^6.2.0",
- "mongodb-connection-string-url": "^3.0.0"
- },
- "engines": {
- "node": ">=16.20.1"
- },
- "peerDependencies": {
- "@aws-sdk/credential-providers": "^3.188.0",
- "@mongodb-js/zstd": "^1.1.0",
- "gcp-metadata": "^5.2.0",
- "kerberos": "^2.0.1",
- "mongodb-client-encryption": ">=6.0.0 <7",
- "snappy": "^7.2.2",
- "socks": "^2.7.1"
- },
- "peerDependenciesMeta": {
- "@aws-sdk/credential-providers": {
- "optional": true
- },
- "@mongodb-js/zstd": {
- "optional": true
- },
- "gcp-metadata": {
- "optional": true
- },
- "kerberos": {
- "optional": true
- },
- "mongodb-client-encryption": {
- "optional": true
- },
- "snappy": {
- "optional": true
- },
- "socks": {
- "optional": true
- }
- }
- },
- "node_modules/mongodb-connection-string-url": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/mongodb-connection-string-url/-/mongodb-connection-string-url-3.0.0.tgz",
- "integrity": "sha512-t1Vf+m1I5hC2M5RJx/7AtxgABy1cZmIPQRMXw+gEIPn/cZNF3Oiy+l0UIypUwVB5trcWHq3crg2g3uAR9aAwsQ==",
- "dependencies": {
- "@types/whatwg-url": "^11.0.2",
- "whatwg-url": "^13.0.0"
- }
- },
- "node_modules/mongoose": {
- "version": "8.2.0",
- "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-8.2.0.tgz",
- "integrity": "sha512-la93n6zCYRbPS+c5N9oTDAktvREy5OT9OCljp1Tah0y3+p8UPMTAoabWaLZMdzYruOtF9/9GRf6MasaZjiZP1A==",
- "dependencies": {
- "bson": "^6.2.0",
- "kareem": "2.5.1",
- "mongodb": "6.3.0",
- "mpath": "0.9.0",
- "mquery": "5.0.0",
- "ms": "2.1.3",
- "sift": "16.0.1"
- },
- "engines": {
- "node": ">=16.20.1"
- },
- "funding": {
- "type": "opencollective",
- "url": "https://opencollective.com/mongoose"
- }
- },
- "node_modules/mongoose/node_modules/ms": {
- "version": "2.1.3",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
- "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA=="
- },
- "node_modules/mpath": {
- "version": "0.9.0",
- "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.9.0.tgz",
- "integrity": "sha512-ikJRQTk8hw5DEoFVxHG1Gn9T/xcjtdnOKIU1JTmGjZZlg9LST2mBLmcX3/ICIbgJydT2GOc15RnNy5mHmzfSew==",
- "engines": {
- "node": ">=4.0.0"
- }
- },
- "node_modules/mquery": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/mquery/-/mquery-5.0.0.tgz",
- "integrity": "sha512-iQMncpmEK8R8ncT8HJGsGc9Dsp8xcgYMVSbs5jgnm1lFHTZqMJTUWTDx1LBO8+mK3tPNZWFLBghQEIOULSTHZg==",
- "dependencies": {
- "debug": "4.x"
- },
- "engines": {
- "node": ">=14.0.0"
- }
- },
- "node_modules/ms": {
- "version": "2.1.2",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
- "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w=="
- },
- "node_modules/msw": {
- "version": "2.1.7",
- "resolved": "https://registry.npmjs.org/msw/-/msw-2.1.7.tgz",
- "integrity": "sha512-yTIYqEMqDSrdbVMrfmqP6rTKQsnIbglTvVmAHDWwNegyXPXRcV+RjsaFEqubRS266gwWCDLm9YdOkWSKLdDvJQ==",
- "dev": true,
- "hasInstallScript": true,
- "dependencies": {
- "@bundled-es-modules/cookie": "^2.0.0",
- "@bundled-es-modules/statuses": "^1.0.1",
- "@mswjs/cookies": "^1.1.0",
- "@mswjs/interceptors": "^0.25.16",
- "@open-draft/until": "^2.1.0",
- "@types/cookie": "^0.6.0",
- "@types/statuses": "^2.0.4",
- "chalk": "^4.1.2",
- "chokidar": "^3.4.2",
- "graphql": "^16.8.1",
- "headers-polyfill": "^4.0.2",
- "inquirer": "^8.2.0",
- "is-node-process": "^1.2.0",
- "outvariant": "^1.4.2",
- "path-to-regexp": "^6.2.0",
- "strict-event-emitter": "^0.5.1",
- "type-fest": "^4.9.0",
- "yargs": "^17.7.2"
- },
- "bin": {
- "msw": "cli/index.js"
- },
- "engines": {
- "node": ">=18"
- },
- "funding": {
- "type": "opencollective",
- "url": "https://opencollective.com/mswjs"
- },
- "peerDependencies": {
- "typescript": ">= 4.7.x <= 5.3.x"
- },
- "peerDependenciesMeta": {
- "typescript": {
- "optional": true
- }
- }
- },
- "node_modules/msw/node_modules/type-fest": {
- "version": "4.10.2",
- "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-4.10.2.tgz",
- "integrity": "sha512-anpAG63wSpdEbLwOqH8L84urkL6PiVIov3EMmgIhhThevh9aiMQov+6Btx0wldNcvm4wV+e2/Rt1QdDwKHFbHw==",
- "dev": true,
- "engines": {
- "node": ">=16"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/mute-stream": {
- "version": "0.0.8",
- "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz",
- "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==",
- "dev": true
- },
- "node_modules/name-to-imdb": {
- "version": "3.0.4",
- "resolved": "https://registry.npmjs.org/name-to-imdb/-/name-to-imdb-3.0.4.tgz",
- "integrity": "sha512-OVmDvWoAZso2eHxK51UK7TMIpUpM4LnI3KhvvZe+JkDatEda9WS3/YXZVQnand5skI38shoniOFcyrw08QsNeA==",
- "dependencies": {
- "diacritics": "~1.3.0",
- "named-queue": "^2.1.0",
- "needle": "^1.1.2",
- "node-fetch": "^2.2.0"
- }
- },
- "node_modules/named-queue": {
- "version": "2.2.1",
- "resolved": "https://registry.npmjs.org/named-queue/-/named-queue-2.2.1.tgz",
- "integrity": "sha512-ssW6R5DZza+ixfGgu+piZAqszqRViHNZjjazXknCWyRYZfRJkBmbSPd1nIcH29aejsyBNPNrn3AdMfB+qvb2Hw=="
- },
- "node_modules/natural-compare": {
- "version": "1.4.0",
- "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz",
- "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==",
- "dev": true
- },
- "node_modules/needle": {
- "version": "1.6.0",
- "resolved": "https://registry.npmjs.org/needle/-/needle-1.6.0.tgz",
- "integrity": "sha512-ogVK1D/Cgemw2vM1KJN6B83DwcKbDepdkMNtVJcXIe+xoaCOdC+aJHzhEov7xjsY9S7rBIuHP59W1fLsbGqDhA==",
- "dependencies": {
- "debug": "^2.1.2",
- "iconv-lite": "^0.4.4"
- },
- "bin": {
- "needle": "bin/needle"
- },
- "engines": {
- "node": ">= 0.10.x"
- }
- },
- "node_modules/needle/node_modules/debug": {
- "version": "2.6.9",
- "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
- "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
- "dependencies": {
- "ms": "2.0.0"
- }
- },
- "node_modules/needle/node_modules/ms": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
- "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="
- },
- "node_modules/node-fetch": {
- "version": "2.7.0",
- "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.7.0.tgz",
- "integrity": "sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A==",
- "dependencies": {
- "whatwg-url": "^5.0.0"
- },
- "engines": {
- "node": "4.x || >=6.0.0"
- },
- "peerDependencies": {
- "encoding": "^0.1.0"
- },
- "peerDependenciesMeta": {
- "encoding": {
- "optional": true
- }
- }
- },
- "node_modules/node-fetch/node_modules/tr46": {
- "version": "0.0.3",
- "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz",
- "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw=="
- },
- "node_modules/node-fetch/node_modules/webidl-conversions": {
- "version": "3.0.1",
- "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz",
- "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ=="
- },
- "node_modules/node-fetch/node_modules/whatwg-url": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz",
- "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==",
- "dependencies": {
- "tr46": "~0.0.3",
- "webidl-conversions": "^3.0.0"
- }
- },
- "node_modules/node-int64": {
- "version": "0.4.0",
- "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz",
- "integrity": "sha512-O5lz91xSOeoXP6DulyHfllpq+Eg00MWitZIbtPfoSEvqIHdl5gfcY6hYzDWnj0qD5tz52PI08u9qUvSVeUBeHw==",
- "dev": true
- },
- "node_modules/node-releases": {
- "version": "2.0.14",
- "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.14.tgz",
- "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==",
- "dev": true
- },
- "node_modules/normalize-path": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
- "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
- "dev": true,
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/npm-run-path": {
- "version": "4.0.1",
- "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz",
- "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==",
- "dev": true,
- "dependencies": {
- "path-key": "^3.0.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/object-inspect": {
- "version": "1.13.1",
- "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.1.tgz",
- "integrity": "sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==",
- "dev": true,
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/object-keys": {
- "version": "1.1.1",
- "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz",
- "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==",
- "dev": true,
- "engines": {
- "node": ">= 0.4"
- }
- },
- "node_modules/object.assign": {
- "version": "4.1.5",
- "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.5.tgz",
- "integrity": "sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.5",
- "define-properties": "^1.2.1",
- "has-symbols": "^1.0.3",
- "object-keys": "^1.1.1"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/object.fromentries": {
- "version": "2.0.7",
- "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.7.tgz",
- "integrity": "sha512-UPbPHML6sL8PI/mOqPwsH4G6iyXcCGzLin8KvEPenOZN5lpCNBZZQ+V62vdjB1mQHrmqGQt5/OJzemUA+KJmEA==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2",
- "define-properties": "^1.2.0",
- "es-abstract": "^1.22.1"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/object.groupby": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/object.groupby/-/object.groupby-1.0.2.tgz",
- "integrity": "sha512-bzBq58S+x+uo0VjurFT0UktpKHOZmv4/xePiOA1nbB9pMqpGK7rUPNgf+1YC+7mE+0HzhTMqNUuCqvKhj6FnBw==",
- "dev": true,
- "dependencies": {
- "array.prototype.filter": "^1.0.3",
- "call-bind": "^1.0.5",
- "define-properties": "^1.2.1",
- "es-abstract": "^1.22.3",
- "es-errors": "^1.0.0"
- }
- },
- "node_modules/object.values": {
- "version": "1.1.7",
- "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.7.tgz",
- "integrity": "sha512-aU6xnDFYT3x17e/f0IiiwlGPTy2jzMySGfUB4fq6z7CV8l85CWHDk5ErhyhpfDHhrOMwGFhSQkhMGHaIotA6Ng==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2",
- "define-properties": "^1.2.0",
- "es-abstract": "^1.22.1"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/obuf": {
- "version": "1.1.2",
- "resolved": "https://registry.npmjs.org/obuf/-/obuf-1.1.2.tgz",
- "integrity": "sha512-PX1wu0AmAdPqOL1mWhqmlOd8kOIZQwGZw6rh7uby9fTc5lhaOWFLX3I6R1hrF9k3zUY40e6igsLGkDXK92LJNg==",
- "dev": true
- },
- "node_modules/on-exit-leak-free": {
- "version": "2.1.2",
- "resolved": "https://registry.npmjs.org/on-exit-leak-free/-/on-exit-leak-free-2.1.2.tgz",
- "integrity": "sha512-0eJJY6hXLGf1udHwfNftBqH+g73EU4B504nZeKpz1sYRKafAghwxEJunB2O7rDZkL4PGfsMVnTXZ2EjibbqcsA==",
- "engines": {
- "node": ">=14.0.0"
- }
- },
- "node_modules/once": {
- "version": "1.4.0",
- "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
- "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==",
- "dependencies": {
- "wrappy": "1"
- }
- },
- "node_modules/onetime": {
- "version": "5.1.2",
- "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz",
- "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==",
- "dev": true,
- "dependencies": {
- "mimic-fn": "^2.1.0"
- },
- "engines": {
- "node": ">=6"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/optionator": {
- "version": "0.9.3",
- "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz",
- "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==",
- "dev": true,
- "dependencies": {
- "@aashutoshrathi/word-wrap": "^1.2.3",
- "deep-is": "^0.1.3",
- "fast-levenshtein": "^2.0.6",
- "levn": "^0.4.1",
- "prelude-ls": "^1.2.1",
- "type-check": "^0.4.0"
- },
- "engines": {
- "node": ">= 0.8.0"
- }
- },
- "node_modules/options": {
- "version": "0.0.6",
- "resolved": "https://registry.npmjs.org/options/-/options-0.0.6.tgz",
- "integrity": "sha512-bOj3L1ypm++N+n7CEbbe473A414AB7z+amKYshRb//iuL3MpdDCLhPnw6aVTdKB9g5ZRVHIEp8eUln6L2NUStg==",
- "engines": {
- "node": ">=0.4.0"
- }
- },
- "node_modules/ora": {
- "version": "5.4.1",
- "resolved": "https://registry.npmjs.org/ora/-/ora-5.4.1.tgz",
- "integrity": "sha512-5b6Y85tPxZZ7QytO+BQzysW31HJku27cRIlkbAXaNx+BdcVi+LlRFmVXzeF6a7JCwJpyw5c4b+YSVImQIrBpuQ==",
- "dev": true,
- "dependencies": {
- "bl": "^4.1.0",
- "chalk": "^4.1.0",
- "cli-cursor": "^3.1.0",
- "cli-spinners": "^2.5.0",
- "is-interactive": "^1.0.0",
- "is-unicode-supported": "^0.1.0",
- "log-symbols": "^4.1.0",
- "strip-ansi": "^6.0.0",
- "wcwidth": "^1.0.1"
- },
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/os-tmpdir": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz",
- "integrity": "sha512-D2FR03Vir7FIu45XBY20mTb+/ZSWB00sjU9jdQXt83gDrI4Ztz5Fs7/yy74g2N5SVQY4xY1qDr4rNddwYRVX0g==",
- "dev": true,
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/outvariant": {
- "version": "1.4.2",
- "resolved": "https://registry.npmjs.org/outvariant/-/outvariant-1.4.2.tgz",
- "integrity": "sha512-Ou3dJ6bA/UJ5GVHxah4LnqDwZRwAmWxrG3wtrHrbGnP4RnLCtA64A4F+ae7Y8ww660JaddSoArUR5HjipWSHAQ==",
- "dev": true
- },
- "node_modules/p-limit": {
- "version": "3.1.0",
- "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz",
- "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==",
- "dev": true,
- "dependencies": {
- "yocto-queue": "^0.1.0"
- },
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/p-locate": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz",
- "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==",
- "dev": true,
- "dependencies": {
- "p-limit": "^3.0.2"
- },
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/p-try": {
- "version": "2.2.0",
- "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz",
- "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==",
- "dev": true,
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/packet-reader": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/packet-reader/-/packet-reader-1.0.0.tgz",
- "integrity": "sha512-HAKu/fG3HpHFO0AA8WE8q2g+gBJaZ9MG7fcKk+IJPLTGAD6Psw4443l+9DGRbOIh3/aXr7Phy0TjilYivJo5XQ=="
- },
- "node_modules/parent-module": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz",
- "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==",
- "dev": true,
- "dependencies": {
- "callsites": "^3.0.0"
- },
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/parse-json": {
- "version": "5.2.0",
- "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz",
- "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==",
- "dev": true,
- "dependencies": {
- "@babel/code-frame": "^7.0.0",
- "error-ex": "^1.3.1",
- "json-parse-even-better-errors": "^2.3.0",
- "lines-and-columns": "^1.1.6"
- },
- "engines": {
- "node": ">=8"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/parse-torrent": {
- "version": "4.1.0",
- "resolved": "https://registry.npmjs.org/parse-torrent/-/parse-torrent-4.1.0.tgz",
- "integrity": "sha512-FeoGe8bOYmSzxO31kYy44A03FjuULCMOIMom8KyuGvO8/lLVPJyo2nr9CwH/iYmNHm74hk7h70o59DOfk9Rq+A==",
- "dependencies": {
- "magnet-uri": "^4.0.0",
- "parse-torrent-file": "^2.0.0"
- },
- "bin": {
- "parse-torrent": "bin/cmd.js"
- }
- },
- "node_modules/parse-torrent-file": {
- "version": "2.1.4",
- "resolved": "https://registry.npmjs.org/parse-torrent-file/-/parse-torrent-file-2.1.4.tgz",
- "integrity": "sha512-u2MgLOjZPDDer1oRg1c+H/+54iIQYY5TKgQ5G8KrGLT1Dcwdo7Lj+QfQR123+u8J0AMSFGbQUvsBlSB7uIJcCA==",
- "deprecated": "Use the parse-torrent package instead",
- "dependencies": {
- "bencode": "^0.7.0",
- "simple-sha1": "^2.0.0"
- },
- "bin": {
- "parse-torrent-file": "bin/cmd.js"
- }
- },
- "node_modules/parse-torrent-title": {
- "version": "1.3.0",
- "resolved": "git+ssh://git@github.com/TheBeastLT/parse-torrent-title.git#022408972c2a040f846331a912a6a8487746a654",
- "integrity": "sha512-2Y0gkYUyrT5sRo5cnpOt90HpciJk7oqa1iOt/AQxr186oOvth7Llj2+aqDB9MzNHX7IZ3QpfRs5fr9TZ2zAIfg==",
- "license": "MIT",
- "dependencies": {
- "moment": "^2.24.0"
- },
- "engines": {
- "node": ">=10"
- }
- },
- "node_modules/parse-torrent/node_modules/magnet-uri": {
- "version": "4.2.3",
- "resolved": "https://registry.npmjs.org/magnet-uri/-/magnet-uri-4.2.3.tgz",
- "integrity": "sha512-aHhR49CRBOq3BX6jQOBdGMXhNT2+9LIH3CCIwHlR+aFE8nWMfBD1aNYxfm2u2LsCOwvfPeyCsdIg9KXSwdsOLQ==",
- "dependencies": {
- "flatten": "0.0.1",
- "thirty-two": "^0.0.2",
- "xtend": "^4.0.0"
- }
- },
- "node_modules/parse-torrent/node_modules/thirty-two": {
- "version": "0.0.2",
- "resolved": "https://registry.npmjs.org/thirty-two/-/thirty-two-0.0.2.tgz",
- "integrity": "sha512-0j1A9eqbP8dSEtkqqEJGpYFN2lPgQR1d0qKS2KNAmIxkK6gV37D5hRa5b/mYzVL1fyAVWBkeUDIXybZdCLVBzA==",
- "engines": {
- "node": ">=0.2.6"
- }
- },
- "node_modules/path-exists": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz",
- "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/path-is-absolute": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
- "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==",
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/path-key": {
- "version": "3.1.1",
- "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz",
- "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/path-parse": {
- "version": "1.0.7",
- "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz",
- "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==",
- "dev": true
- },
- "node_modules/path-to-regexp": {
- "version": "6.2.1",
- "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.2.1.tgz",
- "integrity": "sha512-JLyh7xT1kizaEvcaXOQwOc2/Yhw6KZOvPf1S8401UyLk86CU79LN3vl7ztXGm/pZ+YjoyAJ4rxmHwbkBXJX+yw==",
- "dev": true
- },
- "node_modules/path-type": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz",
- "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/peer-wire-protocol": {
- "version": "0.7.1",
- "resolved": "https://registry.npmjs.org/peer-wire-protocol/-/peer-wire-protocol-0.7.1.tgz",
- "integrity": "sha512-V9oTa/ZcfNNz9fAST28Gg0fXbPeFPk3SBImsYO8GDDG5D0E195vxXmjZ+SPrzr4BJyMQmdDmwUfTf9MZ62z4mw==",
- "dependencies": {
- "bitfield": "^0.1.0",
- "bncode": "^0.2.3",
- "buffer-alloc": "^1.1.0",
- "buffer-from": "^1.0.0",
- "readable-stream": "^1.0.2",
- "speedometer": "^0.1.2"
- }
- },
- "node_modules/peer-wire-protocol/node_modules/bncode": {
- "version": "0.2.3",
- "resolved": "https://registry.npmjs.org/bncode/-/bncode-0.2.3.tgz",
- "integrity": "sha512-IXGfySD68R/J2X/it8GZqAM+Vb3ByZvAlUi0Gysq4ZACq6hXGQ3YshKo0QS/f3S9wOWKjJnEjP6x3ELxqBnAOA=="
- },
- "node_modules/peer-wire-swarm": {
- "version": "0.12.2",
- "resolved": "https://registry.npmjs.org/peer-wire-swarm/-/peer-wire-swarm-0.12.2.tgz",
- "integrity": "sha512-sIWZ1nTL9l6mI9J18kW1AeByBwagvNzGJlMmQA9pM+otKQtTIwnigK8SR0nEFrNZYqZelI6RQ6g4udvtQ2TI1g==",
- "dependencies": {
- "buffer-from": "^1.0.0",
- "fifo": "^0.1.4",
- "once": "^1.1.1",
- "peer-wire-protocol": "^0.7.0",
- "speedometer": "^0.1.2",
- "utp": "0.0.7"
- }
- },
- "node_modules/pg": {
- "version": "8.11.3",
- "resolved": "https://registry.npmjs.org/pg/-/pg-8.11.3.tgz",
- "integrity": "sha512-+9iuvG8QfaaUrrph+kpF24cXkH1YOOUeArRNYIxq1viYHZagBxrTno7cecY1Fa44tJeZvaoG+Djpkc3JwehN5g==",
- "dependencies": {
- "buffer-writer": "2.0.0",
- "packet-reader": "1.0.0",
- "pg-connection-string": "^2.6.2",
- "pg-pool": "^3.6.1",
- "pg-protocol": "^1.6.0",
- "pg-types": "^2.1.0",
- "pgpass": "1.x"
- },
- "engines": {
- "node": ">= 8.0.0"
- },
- "optionalDependencies": {
- "pg-cloudflare": "^1.1.1"
- },
- "peerDependencies": {
- "pg-native": ">=3.0.1"
- },
- "peerDependenciesMeta": {
- "pg-native": {
- "optional": true
- }
- }
- },
- "node_modules/pg-cloudflare": {
- "version": "1.1.1",
- "resolved": "https://registry.npmjs.org/pg-cloudflare/-/pg-cloudflare-1.1.1.tgz",
- "integrity": "sha512-xWPagP/4B6BgFO+EKz3JONXv3YDgvkbVrGw2mTo3D6tVDQRh1e7cqVGvyR3BE+eQgAvx1XhW/iEASj4/jCWl3Q==",
- "optional": true
- },
- "node_modules/pg-connection-string": {
- "version": "2.6.2",
- "resolved": "https://registry.npmjs.org/pg-connection-string/-/pg-connection-string-2.6.2.tgz",
- "integrity": "sha512-ch6OwaeaPYcova4kKZ15sbJ2hKb/VP48ZD2gE7i1J+L4MspCtBMAx8nMgz7bksc7IojCIIWuEhHibSMFH8m8oA=="
- },
- "node_modules/pg-hstore": {
- "version": "2.3.4",
- "resolved": "https://registry.npmjs.org/pg-hstore/-/pg-hstore-2.3.4.tgz",
- "integrity": "sha512-N3SGs/Rf+xA1M2/n0JBiXFDVMzdekwLZLAO0g7mpDY9ouX+fDI7jS6kTq3JujmYbtNSJ53TJ0q4G98KVZSM4EA==",
- "dependencies": {
- "underscore": "^1.13.1"
- },
- "engines": {
- "node": ">= 0.8.x"
- }
- },
- "node_modules/pg-int8": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/pg-int8/-/pg-int8-1.0.1.tgz",
- "integrity": "sha512-WCtabS6t3c8SkpDBUlb1kjOs7l66xsGdKpIPZsg4wR+B3+u9UAum2odSsF9tnvxg80h4ZxLWMy4pRjOsFIqQpw==",
- "engines": {
- "node": ">=4.0.0"
- }
- },
- "node_modules/pg-numeric": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/pg-numeric/-/pg-numeric-1.0.2.tgz",
- "integrity": "sha512-BM/Thnrw5jm2kKLE5uJkXqqExRUY/toLHda65XgFTBTFYZyopbKjBe29Ii3RbkvlsMoFwD+tHeGaCjjv0gHlyw==",
- "dev": true,
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/pg-pool": {
- "version": "3.6.1",
- "resolved": "https://registry.npmjs.org/pg-pool/-/pg-pool-3.6.1.tgz",
- "integrity": "sha512-jizsIzhkIitxCGfPRzJn1ZdcosIt3pz9Sh3V01fm1vZnbnCMgmGl5wvGGdNN2EL9Rmb0EcFoCkixH4Pu+sP9Og==",
- "peerDependencies": {
- "pg": ">=8.0"
- }
- },
- "node_modules/pg-protocol": {
- "version": "1.6.0",
- "resolved": "https://registry.npmjs.org/pg-protocol/-/pg-protocol-1.6.0.tgz",
- "integrity": "sha512-M+PDm637OY5WM307051+bsDia5Xej6d9IR4GwJse1qA1DIhiKlksvrneZOYQq42OM+spubpcNYEo2FcKQrDk+Q=="
- },
- "node_modules/pg-types": {
- "version": "4.0.2",
- "resolved": "https://registry.npmjs.org/pg-types/-/pg-types-4.0.2.tgz",
- "integrity": "sha512-cRL3JpS3lKMGsKaWndugWQoLOCoP+Cic8oseVcbr0qhPzYD5DWXK+RZ9LY9wxRf7RQia4SCwQlXk0q6FCPrVng==",
- "dev": true,
- "dependencies": {
- "pg-int8": "1.0.1",
- "pg-numeric": "1.0.2",
- "postgres-array": "~3.0.1",
- "postgres-bytea": "~3.0.0",
- "postgres-date": "~2.1.0",
- "postgres-interval": "^3.0.0",
- "postgres-range": "^1.1.1"
- },
- "engines": {
- "node": ">=10"
- }
- },
- "node_modules/pg/node_modules/pg-types": {
- "version": "2.2.0",
- "resolved": "https://registry.npmjs.org/pg-types/-/pg-types-2.2.0.tgz",
- "integrity": "sha512-qTAAlrEsl8s4OiEQY69wDvcMIdQN6wdz5ojQiOy6YRMuynxenON0O5oCpJI6lshc6scgAY8qvJ2On/p+CXY0GA==",
- "dependencies": {
- "pg-int8": "1.0.1",
- "postgres-array": "~2.0.0",
- "postgres-bytea": "~1.0.0",
- "postgres-date": "~1.0.4",
- "postgres-interval": "^1.1.0"
- },
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/pg/node_modules/postgres-array": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/postgres-array/-/postgres-array-2.0.0.tgz",
- "integrity": "sha512-VpZrUqU5A69eQyW2c5CA1jtLecCsN2U/bD6VilrFDWq5+5UIEVO7nazS3TEcHf1zuPYO/sqGvUvW62g86RXZuA==",
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/pg/node_modules/postgres-bytea": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/postgres-bytea/-/postgres-bytea-1.0.0.tgz",
- "integrity": "sha512-xy3pmLuQqRBZBXDULy7KbaitYqLcmxigw14Q5sj8QBVLqEwXfeybIKVWiqAXTlcvdvb0+xkOtDbfQMOf4lST1w==",
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/pg/node_modules/postgres-date": {
- "version": "1.0.7",
- "resolved": "https://registry.npmjs.org/postgres-date/-/postgres-date-1.0.7.tgz",
- "integrity": "sha512-suDmjLVQg78nMK2UZ454hAG+OAW+HQPZ6n++TNDUX+L0+uUlLywnoxJKDou51Zm+zTCjrCl0Nq6J9C5hP9vK/Q==",
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/pg/node_modules/postgres-interval": {
- "version": "1.2.0",
- "resolved": "https://registry.npmjs.org/postgres-interval/-/postgres-interval-1.2.0.tgz",
- "integrity": "sha512-9ZhXKM/rw350N1ovuWHbGxnGh/SNJ4cnxHiM0rxE4VN41wsg8P8zWn9hv/buK00RP4WvlOyr/RBDiptyxVbkZQ==",
- "dependencies": {
- "xtend": "^4.0.0"
- },
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/pgpass": {
- "version": "1.0.5",
- "resolved": "https://registry.npmjs.org/pgpass/-/pgpass-1.0.5.tgz",
- "integrity": "sha512-FdW9r/jQZhSeohs1Z3sI1yxFQNFvMcnmfuj4WBMUTxOrAyLMaTcE1aAMBiTlbMNaXvBCQuVi0R7hd8udDSP7ug==",
- "dependencies": {
- "split2": "^4.1.0"
- }
- },
- "node_modules/picocolors": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz",
- "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==",
- "dev": true
- },
- "node_modules/picomatch": {
- "version": "2.3.1",
- "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz",
- "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==",
- "dev": true,
- "engines": {
- "node": ">=8.6"
- },
- "funding": {
- "url": "https://github.com/sponsors/jonschlinkert"
- }
- },
- "node_modules/pino": {
- "version": "8.18.0",
- "resolved": "https://registry.npmjs.org/pino/-/pino-8.18.0.tgz",
- "integrity": "sha512-Mz/gKiRyuXu4HnpHgi1YWdHQCoWMufapzooisvFn78zl4dZciAxS+YeRkUxXl1ee/SzU80YCz1zpECCh4oC6Aw==",
- "dependencies": {
- "atomic-sleep": "^1.0.0",
- "fast-redact": "^3.1.1",
- "on-exit-leak-free": "^2.1.0",
- "pino-abstract-transport": "v1.1.0",
- "pino-std-serializers": "^6.0.0",
- "process-warning": "^3.0.0",
- "quick-format-unescaped": "^4.0.3",
- "real-require": "^0.2.0",
- "safe-stable-stringify": "^2.3.1",
- "sonic-boom": "^3.7.0",
- "thread-stream": "^2.0.0"
- },
- "bin": {
- "pino": "bin.js"
- }
- },
- "node_modules/pino-abstract-transport": {
- "version": "1.1.0",
- "resolved": "https://registry.npmjs.org/pino-abstract-transport/-/pino-abstract-transport-1.1.0.tgz",
- "integrity": "sha512-lsleG3/2a/JIWUtf9Q5gUNErBqwIu1tUKTT3dUzaf5DySw9ra1wcqKjJjLX1VTY64Wk1eEOYsVGSaGfCK85ekA==",
- "dependencies": {
- "readable-stream": "^4.0.0",
- "split2": "^4.0.0"
- }
- },
- "node_modules/pino-abstract-transport/node_modules/buffer": {
- "version": "6.0.3",
- "resolved": "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz",
- "integrity": "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==",
- "funding": [
- {
- "type": "github",
- "url": "https://github.com/sponsors/feross"
- },
- {
- "type": "patreon",
- "url": "https://www.patreon.com/feross"
- },
- {
- "type": "consulting",
- "url": "https://feross.org/support"
- }
- ],
- "dependencies": {
- "base64-js": "^1.3.1",
- "ieee754": "^1.2.1"
- }
- },
- "node_modules/pino-abstract-transport/node_modules/readable-stream": {
- "version": "4.5.2",
- "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-4.5.2.tgz",
- "integrity": "sha512-yjavECdqeZ3GLXNgRXgeQEdz9fvDDkNKyHnbHRFtOr7/LcfgBcmct7t/ET+HaCTqfh06OzoAxrkN/IfjJBVe+g==",
- "dependencies": {
- "abort-controller": "^3.0.0",
- "buffer": "^6.0.3",
- "events": "^3.3.0",
- "process": "^0.11.10",
- "string_decoder": "^1.3.0"
- },
- "engines": {
- "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
- }
- },
- "node_modules/pino-abstract-transport/node_modules/safe-buffer": {
- "version": "5.2.1",
- "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz",
- "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==",
- "funding": [
- {
- "type": "github",
- "url": "https://github.com/sponsors/feross"
- },
- {
- "type": "patreon",
- "url": "https://www.patreon.com/feross"
- },
- {
- "type": "consulting",
- "url": "https://feross.org/support"
- }
- ]
- },
- "node_modules/pino-abstract-transport/node_modules/string_decoder": {
- "version": "1.3.0",
- "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz",
- "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==",
- "dependencies": {
- "safe-buffer": "~5.2.0"
- }
- },
- "node_modules/pino-pretty": {
- "version": "10.3.1",
- "resolved": "https://registry.npmjs.org/pino-pretty/-/pino-pretty-10.3.1.tgz",
- "integrity": "sha512-az8JbIYeN/1iLj2t0jR9DV48/LQ3RC6hZPpapKPkb84Q+yTidMCpgWxIT3N0flnBDilyBQ1luWNpOeJptjdp/g==",
- "dev": true,
- "dependencies": {
- "colorette": "^2.0.7",
- "dateformat": "^4.6.3",
- "fast-copy": "^3.0.0",
- "fast-safe-stringify": "^2.1.1",
- "help-me": "^5.0.0",
- "joycon": "^3.1.1",
- "minimist": "^1.2.6",
- "on-exit-leak-free": "^2.1.0",
- "pino-abstract-transport": "^1.0.0",
- "pump": "^3.0.0",
- "readable-stream": "^4.0.0",
- "secure-json-parse": "^2.4.0",
- "sonic-boom": "^3.0.0",
- "strip-json-comments": "^3.1.1"
- },
- "bin": {
- "pino-pretty": "bin.js"
- }
- },
- "node_modules/pino-pretty/node_modules/buffer": {
- "version": "6.0.3",
- "resolved": "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz",
- "integrity": "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==",
- "dev": true,
- "funding": [
- {
- "type": "github",
- "url": "https://github.com/sponsors/feross"
- },
- {
- "type": "patreon",
- "url": "https://www.patreon.com/feross"
- },
- {
- "type": "consulting",
- "url": "https://feross.org/support"
- }
- ],
- "dependencies": {
- "base64-js": "^1.3.1",
- "ieee754": "^1.2.1"
- }
- },
- "node_modules/pino-pretty/node_modules/readable-stream": {
- "version": "4.5.2",
- "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-4.5.2.tgz",
- "integrity": "sha512-yjavECdqeZ3GLXNgRXgeQEdz9fvDDkNKyHnbHRFtOr7/LcfgBcmct7t/ET+HaCTqfh06OzoAxrkN/IfjJBVe+g==",
- "dev": true,
- "dependencies": {
- "abort-controller": "^3.0.0",
- "buffer": "^6.0.3",
- "events": "^3.3.0",
- "process": "^0.11.10",
- "string_decoder": "^1.3.0"
- },
- "engines": {
- "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
- }
- },
- "node_modules/pino-pretty/node_modules/safe-buffer": {
- "version": "5.2.1",
- "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz",
- "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==",
- "dev": true,
- "funding": [
- {
- "type": "github",
- "url": "https://github.com/sponsors/feross"
- },
- {
- "type": "patreon",
- "url": "https://www.patreon.com/feross"
- },
- {
- "type": "consulting",
- "url": "https://feross.org/support"
- }
- ]
- },
- "node_modules/pino-pretty/node_modules/string_decoder": {
- "version": "1.3.0",
- "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz",
- "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==",
- "dev": true,
- "dependencies": {
- "safe-buffer": "~5.2.0"
- }
- },
- "node_modules/pino-std-serializers": {
- "version": "6.2.2",
- "resolved": "https://registry.npmjs.org/pino-std-serializers/-/pino-std-serializers-6.2.2.tgz",
- "integrity": "sha512-cHjPPsE+vhj/tnhCy/wiMh3M3z3h/j15zHQX+S9GkTBgqJuTuJzYJ4gUyACLhDaJ7kk9ba9iRDmbH2tJU03OiA=="
- },
- "node_modules/pirates": {
- "version": "4.0.6",
- "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.6.tgz",
- "integrity": "sha512-saLsH7WeYYPiD25LDuLRRY/i+6HaPYr6G1OUlN39otzkSTxKnubR9RTxS3/Kk50s1g2JTgFwWQDQyplC5/SHZg==",
- "dev": true,
- "engines": {
- "node": ">= 6"
- }
- },
- "node_modules/pkg-dir": {
- "version": "4.2.0",
- "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz",
- "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==",
- "dev": true,
- "dependencies": {
- "find-up": "^4.0.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/pkg-dir/node_modules/find-up": {
- "version": "4.1.0",
- "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz",
- "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==",
- "dev": true,
- "dependencies": {
- "locate-path": "^5.0.0",
- "path-exists": "^4.0.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/pkg-dir/node_modules/locate-path": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz",
- "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==",
- "dev": true,
- "dependencies": {
- "p-locate": "^4.1.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/pkg-dir/node_modules/p-limit": {
- "version": "2.3.0",
- "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz",
- "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==",
- "dev": true,
- "dependencies": {
- "p-try": "^2.0.0"
- },
- "engines": {
- "node": ">=6"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/pkg-dir/node_modules/p-locate": {
- "version": "4.1.0",
- "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz",
- "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==",
- "dev": true,
- "dependencies": {
- "p-limit": "^2.2.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/postgres-array": {
- "version": "3.0.2",
- "resolved": "https://registry.npmjs.org/postgres-array/-/postgres-array-3.0.2.tgz",
- "integrity": "sha512-6faShkdFugNQCLwucjPcY5ARoW1SlbnrZjmGl0IrrqewpvxvhSLHimCVzqeuULCbG0fQv7Dtk1yDbG3xv7Veog==",
- "dev": true,
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/postgres-bytea": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/postgres-bytea/-/postgres-bytea-3.0.0.tgz",
- "integrity": "sha512-CNd4jim9RFPkObHSjVHlVrxoVQXz7quwNFpz7RY1okNNme49+sVyiTvTRobiLV548Hx/hb1BG+iE7h9493WzFw==",
- "dev": true,
- "dependencies": {
- "obuf": "~1.1.2"
- },
- "engines": {
- "node": ">= 6"
- }
- },
- "node_modules/postgres-date": {
- "version": "2.1.0",
- "resolved": "https://registry.npmjs.org/postgres-date/-/postgres-date-2.1.0.tgz",
- "integrity": "sha512-K7Juri8gtgXVcDfZttFKVmhglp7epKb1K4pgrkLxehjqkrgPhfG6OO8LHLkfaqkbpjNRnra018XwAr1yQFWGcA==",
- "dev": true,
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/postgres-interval": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/postgres-interval/-/postgres-interval-3.0.0.tgz",
- "integrity": "sha512-BSNDnbyZCXSxgA+1f5UU2GmwhoI0aU5yMxRGO8CdFEcY2BQF9xm/7MqKnYoM1nJDk8nONNWDk9WeSmePFhQdlw==",
- "dev": true,
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/postgres-range": {
- "version": "1.1.4",
- "resolved": "https://registry.npmjs.org/postgres-range/-/postgres-range-1.1.4.tgz",
- "integrity": "sha512-i/hbxIE9803Alj/6ytL7UHQxRvZkI9O4Sy+J3HGc4F4oo/2eQAjTSNJ0bfxyse3bH0nuVesCk+3IRLaMtG3H6w==",
- "dev": true
- },
- "node_modules/prelude-ls": {
- "version": "1.2.1",
- "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz",
- "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==",
- "dev": true,
- "engines": {
- "node": ">= 0.8.0"
- }
- },
- "node_modules/pretty-format": {
- "version": "29.7.0",
- "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz",
- "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==",
- "dev": true,
- "dependencies": {
- "@jest/schemas": "^29.6.3",
- "ansi-styles": "^5.0.0",
- "react-is": "^18.0.0"
- },
- "engines": {
- "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
- }
- },
- "node_modules/pretty-format/node_modules/ansi-styles": {
- "version": "5.2.0",
- "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz",
- "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==",
- "dev": true,
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/chalk/ansi-styles?sponsor=1"
- }
- },
- "node_modules/process": {
- "version": "0.11.10",
- "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz",
- "integrity": "sha512-cdGef/drWFoydD1JsMzuFf8100nZl+GT+yacc2bEced5f9Rjk4z+WtFUTBu9PhOi9j/jfmBPu0mMEY4wIdAF8A==",
- "engines": {
- "node": ">= 0.6.0"
- }
- },
- "node_modules/process-nextick-args": {
- "version": "2.0.1",
- "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz",
- "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag=="
- },
- "node_modules/process-warning": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/process-warning/-/process-warning-3.0.0.tgz",
- "integrity": "sha512-mqn0kFRl0EoqhnL0GQ0veqFHyIN1yig9RHh/InzORTUiZHFRAur+aMtRkELNwGs9aNwKS6tg/An4NYBPGwvtzQ=="
- },
- "node_modules/promise-coalesce": {
- "version": "1.1.2",
- "resolved": "https://registry.npmjs.org/promise-coalesce/-/promise-coalesce-1.1.2.tgz",
- "integrity": "sha512-zLaJ9b8hnC564fnJH6NFSOGZYYdzrAJn2JUUIwzoQb32fG2QAakpDNM+CZo1km6keXkRXRM+hml1BFAPVnPkxg==",
- "engines": {
- "node": ">=16"
- }
- },
- "node_modules/prompts": {
- "version": "2.4.2",
- "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz",
- "integrity": "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==",
- "dev": true,
- "dependencies": {
- "kleur": "^3.0.3",
- "sisteransi": "^1.0.5"
- },
- "engines": {
- "node": ">= 6"
- }
- },
- "node_modules/proxy-from-env": {
- "version": "1.1.0",
- "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz",
- "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg=="
- },
- "node_modules/pump": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz",
- "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==",
- "dev": true,
- "dependencies": {
- "end-of-stream": "^1.1.0",
- "once": "^1.3.1"
- }
- },
- "node_modules/punycode": {
- "version": "2.3.1",
- "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz",
- "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==",
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/pure-rand": {
- "version": "6.0.4",
- "resolved": "https://registry.npmjs.org/pure-rand/-/pure-rand-6.0.4.tgz",
- "integrity": "sha512-LA0Y9kxMYv47GIPJy6MI84fqTd2HmYZI83W/kM/SkKfDlajnZYfmXFTxkbY+xSBPkLJxltMa9hIkmdc29eguMA==",
- "dev": true,
- "funding": [
- {
- "type": "individual",
- "url": "https://github.com/sponsors/dubzzz"
- },
- {
- "type": "opencollective",
- "url": "https://opencollective.com/fast-check"
- }
- ]
- },
- "node_modules/querystringify": {
- "version": "2.2.0",
- "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.2.0.tgz",
- "integrity": "sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ=="
- },
- "node_modules/queue-microtask": {
- "version": "1.2.3",
- "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz",
- "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==",
- "funding": [
- {
- "type": "github",
- "url": "https://github.com/sponsors/feross"
- },
- {
- "type": "patreon",
- "url": "https://www.patreon.com/feross"
- },
- {
- "type": "consulting",
- "url": "https://feross.org/support"
- }
- ]
- },
- "node_modules/queue-tick": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/queue-tick/-/queue-tick-1.0.1.tgz",
- "integrity": "sha512-kJt5qhMxoszgU/62PLP1CJytzd2NKetjSRnyuj31fDd3Rlcz3fzlFdFLD1SItunPwyqEOkca6GbV612BWfaBag=="
- },
- "node_modules/quick-format-unescaped": {
- "version": "4.0.4",
- "resolved": "https://registry.npmjs.org/quick-format-unescaped/-/quick-format-unescaped-4.0.4.tgz",
- "integrity": "sha512-tYC1Q1hgyRuHgloV/YXs2w15unPVh8qfu/qCTfhTYamaw7fyhumKa2yGpdSo87vY32rIclj+4fWYQXUMs9EHvg=="
- },
- "node_modules/random-access-file": {
- "version": "2.2.1",
- "resolved": "https://registry.npmjs.org/random-access-file/-/random-access-file-2.2.1.tgz",
- "integrity": "sha512-RGU0xmDqdOyEiynob1KYSeh8+9c9Td1MJ74GT1viMEYAn8SJ9oBtWCXLsYZukCF46yududHOdM449uRYbzBrZQ==",
- "dependencies": {
- "mkdirp-classic": "^0.5.2",
- "random-access-storage": "^1.1.1"
- }
- },
- "node_modules/random-access-storage": {
- "version": "1.4.3",
- "resolved": "https://registry.npmjs.org/random-access-storage/-/random-access-storage-1.4.3.tgz",
- "integrity": "sha512-D5e2iIC5dNENWyBxsjhEnNOMCwZZ64TARK6dyMN+3g4OTC4MJxyjh9hKLjTGoNhDOPrgjI+YlFEHFnrp/cSnzQ==",
- "dependencies": {
- "events": "^3.3.0",
- "inherits": "^2.0.3",
- "queue-tick": "^1.0.0"
- }
- },
- "node_modules/random-iterate": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/random-iterate/-/random-iterate-1.0.1.tgz",
- "integrity": "sha512-Jdsdnezu913Ot8qgKgSgs63XkAjEsnMcS1z+cC6D6TNXsUXsMxy0RpclF2pzGZTEiTXL9BiArdGTEexcv4nqcA=="
- },
- "node_modules/randombytes": {
- "version": "2.1.0",
- "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz",
- "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==",
- "dependencies": {
- "safe-buffer": "^5.1.0"
- }
- },
- "node_modules/re-emitter": {
- "version": "1.1.4",
- "resolved": "https://registry.npmjs.org/re-emitter/-/re-emitter-1.1.4.tgz",
- "integrity": "sha512-C0SIXdXDSus2yqqvV7qifnb4NoWP7mEBXJq3axci301mXHCZb8Djwm4hrEZo4UeXRaEnfjH98uQ8EBppk2oNWA=="
- },
- "node_modules/react-is": {
- "version": "18.2.0",
- "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz",
- "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==",
- "dev": true
- },
- "node_modules/readable-stream": {
- "version": "1.1.14",
- "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz",
- "integrity": "sha512-+MeVjFf4L44XUkhM1eYbD8fyEsxcV81pqMSR5gblfcLCHfZvbrqy4/qYHE+/R5HoBUT11WV5O08Cr1n3YXkWVQ==",
- "dependencies": {
- "core-util-is": "~1.0.0",
- "inherits": "~2.0.1",
- "isarray": "0.0.1",
- "string_decoder": "~0.10.x"
- }
- },
- "node_modules/readdirp": {
- "version": "3.6.0",
- "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
- "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==",
- "dev": true,
- "dependencies": {
- "picomatch": "^2.2.1"
- },
- "engines": {
- "node": ">=8.10.0"
- }
- },
- "node_modules/real-require": {
- "version": "0.2.0",
- "resolved": "https://registry.npmjs.org/real-require/-/real-require-0.2.0.tgz",
- "integrity": "sha512-57frrGM/OCTLqLOAh0mhVA9VBMHd+9U7Zb2THMGdBUoZVOtGbJzjxsYGDJ3A9AYYCP4hn6y1TVbaOfzWtm5GFg==",
- "engines": {
- "node": ">= 12.13.0"
- }
- },
- "node_modules/reflect-metadata": {
- "version": "0.2.1",
- "resolved": "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.2.1.tgz",
- "integrity": "sha512-i5lLI6iw9AU3Uu4szRNPPEkomnkjRTaVt9hy/bn5g/oSzekBSMeLZblcjP74AW0vBabqERLLIrz+gR8QYR54Tw=="
- },
- "node_modules/regexp.prototype.flags": {
- "version": "1.5.1",
- "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.1.tgz",
- "integrity": "sha512-sy6TXMN+hnP/wMy+ISxg3krXx7BAtWVO4UouuCN/ziM9UEne0euamVNafDfvC83bRNr95y0V5iijeDQFUNpvrg==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2",
- "define-properties": "^1.2.0",
- "set-function-name": "^2.0.0"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/require-directory": {
- "version": "2.1.1",
- "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz",
- "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==",
- "dev": true,
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/requires-port": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz",
- "integrity": "sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ=="
- },
- "node_modules/resolve": {
- "version": "1.22.8",
- "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz",
- "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==",
- "dev": true,
- "dependencies": {
- "is-core-module": "^2.13.0",
- "path-parse": "^1.0.7",
- "supports-preserve-symlinks-flag": "^1.0.0"
- },
- "bin": {
- "resolve": "bin/resolve"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/resolve-cwd": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz",
- "integrity": "sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==",
- "dev": true,
- "dependencies": {
- "resolve-from": "^5.0.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/resolve-cwd/node_modules/resolve-from": {
- "version": "5.0.0",
- "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz",
- "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/resolve-from": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz",
- "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==",
- "dev": true,
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/resolve-pkg-maps": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/resolve-pkg-maps/-/resolve-pkg-maps-1.0.0.tgz",
- "integrity": "sha512-seS2Tj26TBVOC2NIc2rOe2y2ZO7efxITtLZcGSOnHHNOQ7CkiUBfw0Iw2ck6xkIhPwLhKNLS8BO+hEpngQlqzw==",
- "dev": true,
- "funding": {
- "url": "https://github.com/privatenumber/resolve-pkg-maps?sponsor=1"
- }
- },
- "node_modules/resolve.exports": {
- "version": "2.0.2",
- "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-2.0.2.tgz",
- "integrity": "sha512-X2UW6Nw3n/aMgDVy+0rSqgHlv39WZAlZrXCdnbyEiKm17DSqHX4MmQMaST3FbeWR5FTuRcUwYAziZajji0Y7mg==",
- "dev": true,
- "engines": {
- "node": ">=10"
- }
- },
- "node_modules/restore-cursor": {
- "version": "3.1.0",
- "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz",
- "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==",
- "dev": true,
- "dependencies": {
- "onetime": "^5.1.0",
- "signal-exit": "^3.0.2"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/retry-as-promised": {
- "version": "7.0.4",
- "resolved": "https://registry.npmjs.org/retry-as-promised/-/retry-as-promised-7.0.4.tgz",
- "integrity": "sha512-XgmCoxKWkDofwH8WddD0w85ZfqYz+ZHlr5yo+3YUCfycWawU56T5ckWXsScsj5B8tqUcIG67DxXByo3VUgiAdA=="
- },
- "node_modules/reusify": {
- "version": "1.0.4",
- "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz",
- "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==",
- "dev": true,
- "engines": {
- "iojs": ">=1.0.0",
- "node": ">=0.10.0"
- }
- },
- "node_modules/rimraf": {
- "version": "3.0.2",
- "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz",
- "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==",
- "dev": true,
- "dependencies": {
- "glob": "^7.1.3"
- },
- "bin": {
- "rimraf": "bin.js"
- },
- "funding": {
- "url": "https://github.com/sponsors/isaacs"
- }
- },
- "node_modules/run-async": {
- "version": "2.4.1",
- "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.4.1.tgz",
- "integrity": "sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ==",
- "dev": true,
- "engines": {
- "node": ">=0.12.0"
- }
- },
- "node_modules/run-parallel": {
- "version": "1.2.0",
- "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz",
- "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==",
- "funding": [
- {
- "type": "github",
- "url": "https://github.com/sponsors/feross"
- },
- {
- "type": "patreon",
- "url": "https://www.patreon.com/feross"
- },
- {
- "type": "consulting",
- "url": "https://feross.org/support"
- }
- ],
- "dependencies": {
- "queue-microtask": "^1.2.2"
- }
- },
- "node_modules/run-series": {
- "version": "1.1.9",
- "resolved": "https://registry.npmjs.org/run-series/-/run-series-1.1.9.tgz",
- "integrity": "sha512-Arc4hUN896vjkqCYrUXquBFtRZdv1PfLbTYP71efP6butxyQ0kWpiNJyAgsxscmQg1cqvHY32/UCBzXedTpU2g==",
- "funding": [
- {
- "type": "github",
- "url": "https://github.com/sponsors/feross"
- },
- {
- "type": "patreon",
- "url": "https://www.patreon.com/feross"
- },
- {
- "type": "consulting",
- "url": "https://feross.org/support"
- }
- ]
- },
- "node_modules/rusha": {
- "version": "0.8.14",
- "resolved": "https://registry.npmjs.org/rusha/-/rusha-0.8.14.tgz",
- "integrity": "sha512-cLgakCUf6PedEu15t8kbsjnwIFFR2D4RfL+W3iWFJ4iac7z4B0ZI8fxy4R3J956kAI68HclCFGL8MPoUVC3qVA=="
- },
- "node_modules/rxjs": {
- "version": "7.8.1",
- "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.8.1.tgz",
- "integrity": "sha512-AA3TVj+0A2iuIoQkWEK/tqFjBq2j+6PO6Y0zJcvzLAFhEFIO3HL0vls9hWLncZbAAbK0mar7oZ4V079I/qPMxg==",
- "dev": true,
- "dependencies": {
- "tslib": "^2.1.0"
- }
- },
- "node_modules/safe-array-concat": {
- "version": "1.1.0",
- "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.1.0.tgz",
- "integrity": "sha512-ZdQ0Jeb9Ofti4hbt5lX3T2JcAamT9hfzYU1MNB+z/jaEbB6wfFfPIR/zEORmZqobkCCJhSjodobH6WHNmJ97dg==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.5",
- "get-intrinsic": "^1.2.2",
- "has-symbols": "^1.0.3",
- "isarray": "^2.0.5"
- },
- "engines": {
- "node": ">=0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/safe-array-concat/node_modules/isarray": {
- "version": "2.0.5",
- "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz",
- "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==",
- "dev": true
- },
- "node_modules/safe-buffer": {
- "version": "5.1.2",
- "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
- "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
- },
- "node_modules/safe-regex-test": {
- "version": "1.0.3",
- "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.3.tgz",
- "integrity": "sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.6",
- "es-errors": "^1.3.0",
- "is-regex": "^1.1.4"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/safe-stable-stringify": {
- "version": "2.4.3",
- "resolved": "https://registry.npmjs.org/safe-stable-stringify/-/safe-stable-stringify-2.4.3.tgz",
- "integrity": "sha512-e2bDA2WJT0wxseVd4lsDP4+3ONX6HpMXQa1ZhFQ7SU+GjvORCmShbCMltrtIDfkYhVHrOcPtj+KhmDBdPdZD1g==",
- "engines": {
- "node": ">=10"
- }
- },
- "node_modules/safer-buffer": {
- "version": "2.1.2",
- "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
- "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg=="
- },
- "node_modules/secure-json-parse": {
- "version": "2.7.0",
- "resolved": "https://registry.npmjs.org/secure-json-parse/-/secure-json-parse-2.7.0.tgz",
- "integrity": "sha512-6aU+Rwsezw7VR8/nyvKTx8QpWH9FrcYiXXlqC4z5d5XQBDRqtbfsRjnwGyqbi3gddNtWHuEk9OANUotL26qKUw==",
- "dev": true
- },
- "node_modules/semver": {
- "version": "7.6.0",
- "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz",
- "integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==",
- "dependencies": {
- "lru-cache": "^6.0.0"
- },
- "bin": {
- "semver": "bin/semver.js"
- },
- "engines": {
- "node": ">=10"
- }
- },
- "node_modules/semver/node_modules/lru-cache": {
- "version": "6.0.0",
- "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
- "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
- "dependencies": {
- "yallist": "^4.0.0"
- },
- "engines": {
- "node": ">=10"
- }
- },
- "node_modules/sequelize": {
- "version": "6.36.0",
- "resolved": "https://registry.npmjs.org/sequelize/-/sequelize-6.36.0.tgz",
- "integrity": "sha512-PqOa11EHwA/zLmGDU4aynbsavbHJUlgRvFuC/2cA4LhOuV6NHKcQ0IXB+hNdFrGT3rULmvc4kdIwnfCNsrECMQ==",
- "funding": [
- {
- "type": "opencollective",
- "url": "https://opencollective.com/sequelize"
- }
- ],
- "dependencies": {
- "@types/debug": "^4.1.8",
- "@types/validator": "^13.7.17",
- "debug": "^4.3.4",
- "dottie": "^2.0.6",
- "inflection": "^1.13.4",
- "lodash": "^4.17.21",
- "moment": "^2.29.4",
- "moment-timezone": "^0.5.43",
- "pg-connection-string": "^2.6.1",
- "retry-as-promised": "^7.0.4",
- "semver": "^7.5.4",
- "sequelize-pool": "^7.1.0",
- "toposort-class": "^1.0.1",
- "uuid": "^8.3.2",
- "validator": "^13.9.0",
- "wkx": "^0.5.0"
- },
- "engines": {
- "node": ">=10.0.0"
- },
- "peerDependenciesMeta": {
- "ibm_db": {
- "optional": true
- },
- "mariadb": {
- "optional": true
- },
- "mysql2": {
- "optional": true
- },
- "oracledb": {
- "optional": true
- },
- "pg": {
- "optional": true
- },
- "pg-hstore": {
- "optional": true
- },
- "snowflake-sdk": {
- "optional": true
- },
- "sqlite3": {
- "optional": true
- },
- "tedious": {
- "optional": true
- }
- }
- },
- "node_modules/sequelize-pool": {
- "version": "7.1.0",
- "resolved": "https://registry.npmjs.org/sequelize-pool/-/sequelize-pool-7.1.0.tgz",
- "integrity": "sha512-G9c0qlIWQSK29pR/5U2JF5dDQeqqHRragoyahj/Nx4KOOQ3CPPfzxnfqFPCSB7x5UgjOgnZ61nSxz+fjDpRlJg==",
- "engines": {
- "node": ">= 10.0.0"
- }
- },
- "node_modules/sequelize-typescript": {
- "version": "2.1.6",
- "resolved": "https://registry.npmjs.org/sequelize-typescript/-/sequelize-typescript-2.1.6.tgz",
- "integrity": "sha512-Vc2N++3en346RsbGjL3h7tgAl2Y7V+2liYTAOZ8XL0KTw3ahFHsyAUzOwct51n+g70I1TOUDgs06Oh6+XGcFkQ==",
- "dependencies": {
- "glob": "7.2.0"
- },
- "engines": {
- "node": ">=10.0.0"
- },
- "peerDependencies": {
- "@types/node": "*",
- "@types/validator": "*",
- "reflect-metadata": "*",
- "sequelize": ">=6.20.1"
- }
- },
- "node_modules/sequelize-typescript/node_modules/brace-expansion": {
- "version": "1.1.11",
- "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
- "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
- "dependencies": {
- "balanced-match": "^1.0.0",
- "concat-map": "0.0.1"
- }
- },
- "node_modules/sequelize-typescript/node_modules/glob": {
- "version": "7.2.0",
- "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz",
- "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==",
- "dependencies": {
- "fs.realpath": "^1.0.0",
- "inflight": "^1.0.4",
- "inherits": "2",
- "minimatch": "^3.0.4",
- "once": "^1.3.0",
- "path-is-absolute": "^1.0.0"
- },
- "engines": {
- "node": "*"
- },
- "funding": {
- "url": "https://github.com/sponsors/isaacs"
- }
- },
- "node_modules/sequelize-typescript/node_modules/minimatch": {
- "version": "3.1.2",
- "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
- "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
- "dependencies": {
- "brace-expansion": "^1.1.7"
- },
- "engines": {
- "node": "*"
- }
- },
- "node_modules/set-function-length": {
- "version": "1.2.1",
- "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.1.tgz",
- "integrity": "sha512-j4t6ccc+VsKwYHso+kElc5neZpjtq9EnRICFZtWyBsLojhmeF/ZBd/elqm22WJh/BziDe/SBiOeAt0m2mfLD0g==",
- "dev": true,
- "dependencies": {
- "define-data-property": "^1.1.2",
- "es-errors": "^1.3.0",
- "function-bind": "^1.1.2",
- "get-intrinsic": "^1.2.3",
- "gopd": "^1.0.1",
- "has-property-descriptors": "^1.0.1"
- },
- "engines": {
- "node": ">= 0.4"
- }
- },
- "node_modules/set-function-name": {
- "version": "2.0.1",
- "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.1.tgz",
- "integrity": "sha512-tMNCiqYVkXIZgc2Hnoy2IvC/f8ezc5koaRFkCjrpWzGpCd3qbZXPzVy9MAZzK1ch/X0jvSkojys3oqJN0qCmdA==",
- "dev": true,
- "dependencies": {
- "define-data-property": "^1.0.1",
- "functions-have-names": "^1.2.3",
- "has-property-descriptors": "^1.0.0"
- },
- "engines": {
- "node": ">= 0.4"
- }
- },
- "node_modules/shebang-command": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz",
- "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==",
- "dev": true,
- "dependencies": {
- "shebang-regex": "^3.0.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/shebang-regex": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz",
- "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/side-channel": {
- "version": "1.0.5",
- "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.5.tgz",
- "integrity": "sha512-QcgiIWV4WV7qWExbN5llt6frQB/lBven9pqliLXfGPB+K9ZYXxDozp0wLkHS24kWCm+6YXH/f0HhnObZnZOBnQ==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.6",
- "es-errors": "^1.3.0",
- "get-intrinsic": "^1.2.4",
- "object-inspect": "^1.13.1"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/sift": {
- "version": "16.0.1",
- "resolved": "https://registry.npmjs.org/sift/-/sift-16.0.1.tgz",
- "integrity": "sha512-Wv6BjQ5zbhW7VFefWusVP33T/EM0vYikCaQ2qR8yULbsilAT8/wQaXvuQ3ptGLpoKx+lihJE3y2UTgKDyyNHZQ=="
- },
- "node_modules/signal-exit": {
- "version": "3.0.7",
- "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz",
- "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==",
- "dev": true
- },
- "node_modules/simple-concat": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/simple-concat/-/simple-concat-1.0.1.tgz",
- "integrity": "sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q==",
- "funding": [
- {
- "type": "github",
- "url": "https://github.com/sponsors/feross"
- },
- {
- "type": "patreon",
- "url": "https://www.patreon.com/feross"
- },
- {
- "type": "consulting",
- "url": "https://feross.org/support"
- }
- ]
- },
- "node_modules/simple-get": {
- "version": "2.8.2",
- "resolved": "https://registry.npmjs.org/simple-get/-/simple-get-2.8.2.tgz",
- "integrity": "sha512-Ijd/rV5o+mSBBs4F/x9oDPtTx9Zb6X9brmnXvMW4J7IR15ngi9q5xxqWBKU744jTZiaXtxaPL7uHG6vtN8kUkw==",
- "dependencies": {
- "decompress-response": "^3.3.0",
- "once": "^1.3.1",
- "simple-concat": "^1.0.0"
- }
- },
- "node_modules/simple-peer": {
- "version": "6.4.4",
- "resolved": "https://registry.npmjs.org/simple-peer/-/simple-peer-6.4.4.tgz",
- "integrity": "sha512-sY35UHankz0ba02Dd8YzdyXhEeTAnW6ZUyDfKOSwUht1GLp9VuMT4jQUXF/wG7C9vpwvitV7Ig7a6IkY/qizwg==",
- "dependencies": {
- "debug": "^2.1.0",
- "get-browser-rtc": "^1.0.0",
- "inherits": "^2.0.1",
- "randombytes": "^2.0.3",
- "readable-stream": "^2.0.5"
- }
- },
- "node_modules/simple-peer/node_modules/debug": {
- "version": "2.6.9",
- "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
- "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
- "dependencies": {
- "ms": "2.0.0"
- }
- },
- "node_modules/simple-peer/node_modules/isarray": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
- "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ=="
- },
- "node_modules/simple-peer/node_modules/ms": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
- "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="
- },
- "node_modules/simple-peer/node_modules/readable-stream": {
- "version": "2.3.8",
- "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz",
- "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==",
- "dependencies": {
- "core-util-is": "~1.0.0",
- "inherits": "~2.0.3",
- "isarray": "~1.0.0",
- "process-nextick-args": "~2.0.0",
- "safe-buffer": "~5.1.1",
- "string_decoder": "~1.1.1",
- "util-deprecate": "~1.0.1"
- }
- },
- "node_modules/simple-peer/node_modules/string_decoder": {
- "version": "1.1.1",
- "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz",
- "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==",
- "dependencies": {
- "safe-buffer": "~5.1.0"
- }
- },
- "node_modules/simple-sha1": {
- "version": "2.1.2",
- "resolved": "https://registry.npmjs.org/simple-sha1/-/simple-sha1-2.1.2.tgz",
- "integrity": "sha512-TQl9rm4rdKAVmhO++sXAb8TNN0D6JAD5iyI1mqEPNpxUzTRrtm4aOG1pDf/5W/qCFihiaoK6uuL9rvQz1x1VKw==",
- "dependencies": {
- "rusha": "^0.8.1"
- }
- },
- "node_modules/simple-websocket": {
- "version": "4.3.1",
- "resolved": "https://registry.npmjs.org/simple-websocket/-/simple-websocket-4.3.1.tgz",
- "integrity": "sha512-knEO6ub2Pw00c7ueOV6snKE1hr7jIdY068+239v0I8DVKofyd7IQmYHXrM9pZL1zuI0H7sd+Y5kedndBi5GXIA==",
- "dependencies": {
- "debug": "^2.1.3",
- "inherits": "^2.0.1",
- "randombytes": "^2.0.3",
- "readable-stream": "^2.0.5",
- "ws": "^2.0.0",
- "xtend": "^4.0.1"
- }
- },
- "node_modules/simple-websocket/node_modules/debug": {
- "version": "2.6.9",
- "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
- "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
- "dependencies": {
- "ms": "2.0.0"
- }
- },
- "node_modules/simple-websocket/node_modules/isarray": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
- "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ=="
- },
- "node_modules/simple-websocket/node_modules/ms": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
- "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="
- },
- "node_modules/simple-websocket/node_modules/readable-stream": {
- "version": "2.3.8",
- "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz",
- "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==",
- "dependencies": {
- "core-util-is": "~1.0.0",
- "inherits": "~2.0.3",
- "isarray": "~1.0.0",
- "process-nextick-args": "~2.0.0",
- "safe-buffer": "~5.1.1",
- "string_decoder": "~1.1.1",
- "util-deprecate": "~1.0.1"
- }
- },
- "node_modules/simple-websocket/node_modules/string_decoder": {
- "version": "1.1.1",
- "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz",
- "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==",
- "dependencies": {
- "safe-buffer": "~5.1.0"
- }
- },
- "node_modules/simple-websocket/node_modules/ultron": {
- "version": "1.1.1",
- "resolved": "https://registry.npmjs.org/ultron/-/ultron-1.1.1.tgz",
- "integrity": "sha512-UIEXBNeYmKptWH6z8ZnqTeS8fV74zG0/eRU9VGkpzz+LIJNs8W/zM/L+7ctCkRrgbNnnR0xxw4bKOr0cW0N0Og=="
- },
- "node_modules/simple-websocket/node_modules/ws": {
- "version": "2.3.1",
- "resolved": "https://registry.npmjs.org/ws/-/ws-2.3.1.tgz",
- "integrity": "sha512-61a+9LgtYZxTq1hAonhX8Xwpo2riK4IOR/BIVxioFbCfc3QFKmpE4x9dLExfLHKtUfVZigYa36tThVhO57erEw==",
- "dependencies": {
- "safe-buffer": "~5.0.1",
- "ultron": "~1.1.0"
- }
- },
- "node_modules/simple-websocket/node_modules/ws/node_modules/safe-buffer": {
- "version": "5.0.1",
- "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.0.1.tgz",
- "integrity": "sha512-cr7dZWLwOeaFBLTIuZeYdkfO7UzGIKhjYENJFAxUOMKWGaWDm2nJM2rzxNRm5Owu0DH3ApwNo6kx5idXZfb/Iw=="
- },
- "node_modules/sisteransi": {
- "version": "1.0.5",
- "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz",
- "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==",
- "dev": true
- },
- "node_modules/slash": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz",
- "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/smart-buffer": {
- "version": "4.2.0",
- "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz",
- "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==",
- "optional": true,
- "peer": true,
- "engines": {
- "node": ">= 6.0.0",
- "npm": ">= 3.0.0"
- }
- },
- "node_modules/socks": {
- "version": "2.7.1",
- "resolved": "https://registry.npmjs.org/socks/-/socks-2.7.1.tgz",
- "integrity": "sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ==",
- "optional": true,
- "peer": true,
- "dependencies": {
- "ip": "^2.0.0",
- "smart-buffer": "^4.2.0"
- },
- "engines": {
- "node": ">= 10.13.0",
- "npm": ">= 3.0.0"
- }
- },
- "node_modules/sonic-boom": {
- "version": "3.8.0",
- "resolved": "https://registry.npmjs.org/sonic-boom/-/sonic-boom-3.8.0.tgz",
- "integrity": "sha512-ybz6OYOUjoQQCQ/i4LU8kaToD8ACtYP+Cj5qd2AO36bwbdewxWJ3ArmJ2cr6AvxlL2o0PqnCcPGUgkILbfkaCA==",
- "dependencies": {
- "atomic-sleep": "^1.0.0"
- }
- },
- "node_modules/source-map": {
- "version": "0.6.1",
- "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
- "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
- "dev": true,
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/source-map-support": {
- "version": "0.5.13",
- "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.13.tgz",
- "integrity": "sha512-SHSKFHadjVA5oR4PPqhtAVdcBWwRYVd6g6cAXnIbRiIwc2EhPrTuKUBdSLvlEKyIP3GCf89fltvcZiP9MMFA1w==",
- "dev": true,
- "dependencies": {
- "buffer-from": "^1.0.0",
- "source-map": "^0.6.0"
- }
- },
- "node_modules/sparse-bitfield": {
- "version": "3.0.3",
- "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz",
- "integrity": "sha512-kvzhi7vqKTfkh0PZU+2D2PIllw2ymqJKujUcyPMd9Y75Nv4nPbGJZXNhxsgdQab2BmlDct1YnfQCguEvHr7VsQ==",
- "dependencies": {
- "memory-pager": "^1.0.2"
- }
- },
- "node_modules/speedometer": {
- "version": "0.1.4",
- "resolved": "https://registry.npmjs.org/speedometer/-/speedometer-0.1.4.tgz",
- "integrity": "sha512-phdEoDlA6EUIVtzwq1UiNMXDUogczp204aYF/yfOhjNePWFfIpBJ1k5wLMuXQhEOOMjuTJEcc4vdZa+vuP+n/Q=="
- },
- "node_modules/split2": {
- "version": "4.2.0",
- "resolved": "https://registry.npmjs.org/split2/-/split2-4.2.0.tgz",
- "integrity": "sha512-UcjcJOWknrNkF6PLX83qcHM6KHgVKNkV62Y8a5uYDVv9ydGQVwAHMKqHdJje1VTWpljG0WYpCDhrCdAOYH4TWg==",
- "engines": {
- "node": ">= 10.x"
- }
- },
- "node_modules/sprintf-js": {
- "version": "1.0.3",
- "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz",
- "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==",
- "dev": true
- },
- "node_modules/stack-utils": {
- "version": "2.0.6",
- "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.6.tgz",
- "integrity": "sha512-XlkWvfIm6RmsWtNJx+uqtKLS8eqFbxUg0ZzLXqY0caEy9l7hruX8IpiDnjsLavoBgqCCR71TqWO8MaXYheJ3RQ==",
- "dev": true,
- "dependencies": {
- "escape-string-regexp": "^2.0.0"
- },
- "engines": {
- "node": ">=10"
- }
- },
- "node_modules/stack-utils/node_modules/escape-string-regexp": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz",
- "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/statuses": {
- "version": "2.0.1",
- "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz",
- "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==",
- "dev": true,
- "engines": {
- "node": ">= 0.8"
- }
- },
- "node_modules/strict-event-emitter": {
- "version": "0.5.1",
- "resolved": "https://registry.npmjs.org/strict-event-emitter/-/strict-event-emitter-0.5.1.tgz",
- "integrity": "sha512-vMgjE/GGEPEFnhFub6pa4FmJBRBVOLpIII2hvCZ8Kzb7K0hlHo7mQv6xYrBvCL2LtAIBwFUK8wvuJgTVSQ5MFQ==",
- "dev": true
- },
- "node_modules/string_decoder": {
- "version": "0.10.31",
- "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz",
- "integrity": "sha512-ev2QzSzWPYmy9GuqfIVildA4OdcGLeFZQrq5ys6RtiuF+RQQiZWr8TZNyAcuVXyQRYfEO+MsoB/1BuQVhOJuoQ=="
- },
- "node_modules/string-length": {
- "version": "4.0.2",
- "resolved": "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz",
- "integrity": "sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ==",
- "dev": true,
- "dependencies": {
- "char-regex": "^1.0.2",
- "strip-ansi": "^6.0.0"
- },
- "engines": {
- "node": ">=10"
- }
- },
- "node_modules/string-width": {
- "version": "4.2.3",
- "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz",
- "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==",
- "dev": true,
- "dependencies": {
- "emoji-regex": "^8.0.0",
- "is-fullwidth-code-point": "^3.0.0",
- "strip-ansi": "^6.0.1"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/string.prototype.trim": {
- "version": "1.2.8",
- "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.8.tgz",
- "integrity": "sha512-lfjY4HcixfQXOfaqCvcBuOIapyaroTXhbkfJN3gcB1OtyupngWK4sEET9Knd0cXd28kTUqu/kHoV4HKSJdnjiQ==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2",
- "define-properties": "^1.2.0",
- "es-abstract": "^1.22.1"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/string.prototype.trimend": {
- "version": "1.0.7",
- "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.7.tgz",
- "integrity": "sha512-Ni79DqeB72ZFq1uH/L6zJ+DKZTkOtPIHovb3YZHQViE+HDouuU4mBrLOLDn5Dde3RF8qw5qVETEjhu9locMLvA==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2",
- "define-properties": "^1.2.0",
- "es-abstract": "^1.22.1"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/string.prototype.trimstart": {
- "version": "1.0.7",
- "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.7.tgz",
- "integrity": "sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2",
- "define-properties": "^1.2.0",
- "es-abstract": "^1.22.1"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/string2compact": {
- "version": "1.3.2",
- "resolved": "https://registry.npmjs.org/string2compact/-/string2compact-1.3.2.tgz",
- "integrity": "sha512-3XUxUgwhj7Eqh2djae35QHZZT4mN3fsO7kagZhSGmhhlrQagVvWSFuuFIWnpxFS0CdTB2PlQcaL16RDi14I8uw==",
- "dependencies": {
- "addr-to-ip-port": "^1.0.1",
- "ipaddr.js": "^2.0.0"
- }
- },
- "node_modules/strip-ansi": {
- "version": "6.0.1",
- "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
- "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
- "dev": true,
- "dependencies": {
- "ansi-regex": "^5.0.1"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/strip-bom": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz",
- "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==",
- "dev": true,
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/strip-final-newline": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz",
- "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==",
- "dev": true,
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/strip-json-comments": {
- "version": "3.1.1",
- "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz",
- "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==",
- "dev": true,
- "engines": {
- "node": ">=8"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/supports-color": {
- "version": "7.2.0",
- "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
- "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
- "dev": true,
- "dependencies": {
- "has-flag": "^4.0.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/supports-preserve-symlinks-flag": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz",
- "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==",
- "dev": true,
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/test-exclude": {
- "version": "6.0.0",
- "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz",
- "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==",
- "dev": true,
- "dependencies": {
- "@istanbuljs/schema": "^0.1.2",
- "glob": "^7.1.4",
- "minimatch": "^3.0.4"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/test-exclude/node_modules/brace-expansion": {
- "version": "1.1.11",
- "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
- "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
- "dev": true,
- "dependencies": {
- "balanced-match": "^1.0.0",
- "concat-map": "0.0.1"
- }
- },
- "node_modules/test-exclude/node_modules/minimatch": {
- "version": "3.1.2",
- "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
- "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
- "dev": true,
- "dependencies": {
- "brace-expansion": "^1.1.7"
- },
- "engines": {
- "node": "*"
- }
- },
- "node_modules/text-table": {
- "version": "0.2.0",
- "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz",
- "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==",
- "dev": true
- },
- "node_modules/thirty-two": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/thirty-two/-/thirty-two-1.0.2.tgz",
- "integrity": "sha512-OEI0IWCe+Dw46019YLl6V10Us5bi574EvlJEOcAkB29IzQ/mYD1A6RyNHLjZPiHCmuodxvgF6U+vZO1L15lxVA==",
- "engines": {
- "node": ">=0.2.6"
- }
- },
- "node_modules/thread-stream": {
- "version": "2.4.1",
- "resolved": "https://registry.npmjs.org/thread-stream/-/thread-stream-2.4.1.tgz",
- "integrity": "sha512-d/Ex2iWd1whipbT681JmTINKw0ZwOUBZm7+Gjs64DHuX34mmw8vJL2bFAaNacaW72zYiTJxSHi5abUuOi5nsfg==",
- "dependencies": {
- "real-require": "^0.2.0"
- }
- },
- "node_modules/through": {
- "version": "2.3.8",
- "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz",
- "integrity": "sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg==",
- "dev": true
- },
- "node_modules/thunky": {
- "version": "1.1.0",
- "resolved": "https://registry.npmjs.org/thunky/-/thunky-1.1.0.tgz",
- "integrity": "sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA=="
- },
- "node_modules/tmp": {
- "version": "0.0.33",
- "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz",
- "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==",
- "dev": true,
- "dependencies": {
- "os-tmpdir": "~1.0.2"
- },
- "engines": {
- "node": ">=0.6.0"
- }
- },
- "node_modules/tmpl": {
- "version": "1.0.5",
- "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz",
- "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==",
- "dev": true
- },
- "node_modules/to-fast-properties": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz",
- "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==",
- "dev": true,
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/to-regex-range": {
- "version": "5.0.1",
- "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
- "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
- "dev": true,
- "dependencies": {
- "is-number": "^7.0.0"
- },
- "engines": {
- "node": ">=8.0"
- }
- },
- "node_modules/toposort-class": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/toposort-class/-/toposort-class-1.0.1.tgz",
- "integrity": "sha512-OsLcGGbYF3rMjPUf8oKktyvCiUxSbqMMS39m33MAjLTC1DVIH6x3WSt63/M77ihI09+Sdfk1AXvfhCEeUmC7mg=="
- },
- "node_modules/torrent-discovery": {
- "version": "5.4.0",
- "resolved": "https://registry.npmjs.org/torrent-discovery/-/torrent-discovery-5.4.0.tgz",
- "integrity": "sha512-bPTDIA7XEjRlw6vQyt7kM/h1mg1INBsibjbujISITonx4POENZgxfyCSEXZpDhbAkluSPH4HKRKs4/YTmNLC6w==",
- "dependencies": {
- "bittorrent-dht": "^6.0.0",
- "bittorrent-tracker": "^7.0.0",
- "debug": "^2.0.0",
- "inherits": "^2.0.1",
- "re-emitter": "^1.0.0",
- "run-parallel": "^1.1.2",
- "xtend": "^4.0.0"
- }
- },
- "node_modules/torrent-discovery/node_modules/debug": {
- "version": "2.6.9",
- "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
- "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
- "dependencies": {
- "ms": "2.0.0"
- }
- },
- "node_modules/torrent-discovery/node_modules/ms": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
- "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="
- },
- "node_modules/torrent-piece": {
- "version": "1.1.2",
- "resolved": "https://registry.npmjs.org/torrent-piece/-/torrent-piece-1.1.2.tgz",
- "integrity": "sha512-ElXPyXKKG73o+uziHJ8qlYE9EuyDVxnK2zWL+pW/2bma7RsLpSwFFIJAb8Qui7/tel2hsHQW1z3zBnfQNREpWA=="
- },
- "node_modules/torrent-stream": {
- "version": "1.2.1",
- "resolved": "https://registry.npmjs.org/torrent-stream/-/torrent-stream-1.2.1.tgz",
- "integrity": "sha512-F+3tYmXnpO2gyhZQ7o8yakELJH3FtKISI/FU0iWvchOWFUXiFnjbEBoumSzfcK1P71Qxzx2az4lVK4Dkq4KSew==",
- "dependencies": {
- "bitfield": "^0.1.0",
- "bncode": "^0.5.2",
- "buffer-from": "^1.0.0",
- "end-of-stream": "^0.1.4",
- "fs-chunk-store": "^1.3.0",
- "hat": "0.0.3",
- "immediate-chunk-store": "^1.0.5",
- "ip-set": "^1.0.0",
- "mkdirp": "^0.3.5",
- "parse-torrent": "^4.0.0",
- "peer-wire-swarm": "^0.12.0",
- "rimraf": "^2.2.5",
- "torrent-discovery": "^5.2.0",
- "torrent-piece": "^1.0.0"
- }
- },
- "node_modules/torrent-stream/node_modules/end-of-stream": {
- "version": "0.1.5",
- "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-0.1.5.tgz",
- "integrity": "sha512-go5TQkd0YRXYhX+Lc3UrXkoKU5j+m72jEP5lHWr2Nh82L8wfZtH8toKgcg4T10o23ELIMGXQdwCbl+qAXIPDrw==",
- "dependencies": {
- "once": "~1.3.0"
- }
- },
- "node_modules/torrent-stream/node_modules/mkdirp": {
- "version": "0.3.5",
- "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.3.5.tgz",
- "integrity": "sha512-8OCq0De/h9ZxseqzCH8Kw/Filf5pF/vMI6+BH7Lu0jXz2pqYCjTAQRolSxRIi+Ax+oCCjlxoJMP0YQ4XlrQNHg==",
- "deprecated": "Legacy versions of mkdirp are no longer supported. Please update to mkdirp 1.x. (Note that the API surface has changed to use Promises in 1.x.)"
- },
- "node_modules/torrent-stream/node_modules/once": {
- "version": "1.3.3",
- "resolved": "https://registry.npmjs.org/once/-/once-1.3.3.tgz",
- "integrity": "sha512-6vaNInhu+CHxtONf3zw3vq4SP2DOQhjBvIa3rNcG0+P7eKWlYH6Peu7rHizSloRU2EwMz6GraLieis9Ac9+p1w==",
- "dependencies": {
- "wrappy": "1"
- }
- },
- "node_modules/torrent-stream/node_modules/rimraf": {
- "version": "2.7.1",
- "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz",
- "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==",
- "dependencies": {
- "glob": "^7.1.3"
- },
- "bin": {
- "rimraf": "bin.js"
- }
- },
- "node_modules/tr46": {
- "version": "4.1.1",
- "resolved": "https://registry.npmjs.org/tr46/-/tr46-4.1.1.tgz",
- "integrity": "sha512-2lv/66T7e5yNyhAAC4NaKe5nVavzuGJQVVtRYLyQ2OI8tsJ61PMLlelehb0wi2Hx6+hT/OJUWZcw8MjlSRnxvw==",
- "dependencies": {
- "punycode": "^2.3.0"
- },
- "engines": {
- "node": ">=14"
- }
- },
- "node_modules/ts-api-utils": {
- "version": "1.2.1",
- "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.2.1.tgz",
- "integrity": "sha512-RIYA36cJn2WiH9Hy77hdF9r7oEwxAtB/TS9/S4Qd90Ap4z5FSiin5zEiTL44OII1Y3IIlEvxwxFUVgrHSZ/UpA==",
- "dev": true,
- "engines": {
- "node": ">=16"
- },
- "peerDependencies": {
- "typescript": ">=4.2.0"
- }
- },
- "node_modules/ts-jest": {
- "version": "29.1.2",
- "resolved": "https://registry.npmjs.org/ts-jest/-/ts-jest-29.1.2.tgz",
- "integrity": "sha512-br6GJoH/WUX4pu7FbZXuWGKGNDuU7b8Uj77g/Sp7puZV6EXzuByl6JrECvm0MzVzSTkSHWTihsXt+5XYER5b+g==",
- "dev": true,
- "dependencies": {
- "bs-logger": "0.x",
- "fast-json-stable-stringify": "2.x",
- "jest-util": "^29.0.0",
- "json5": "^2.2.3",
- "lodash.memoize": "4.x",
- "make-error": "1.x",
- "semver": "^7.5.3",
- "yargs-parser": "^21.0.1"
- },
- "bin": {
- "ts-jest": "cli.js"
- },
- "engines": {
- "node": "^16.10.0 || ^18.0.0 || >=20.0.0"
- },
- "peerDependencies": {
- "@babel/core": ">=7.0.0-beta.0 <8",
- "@jest/types": "^29.0.0",
- "babel-jest": "^29.0.0",
- "jest": "^29.0.0",
- "typescript": ">=4.3 <6"
- },
- "peerDependenciesMeta": {
- "@babel/core": {
- "optional": true
- },
- "@jest/types": {
- "optional": true
- },
- "babel-jest": {
- "optional": true
- },
- "esbuild": {
- "optional": true
- }
- }
- },
- "node_modules/ts-node": {
- "version": "10.9.2",
- "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.9.2.tgz",
- "integrity": "sha512-f0FFpIdcHgn8zcPSbf1dRevwt047YMnaiJM3u2w2RewrB+fob/zePZcrOyQoLMMO7aBIddLcQIEK5dYjkLnGrQ==",
- "dev": true,
- "dependencies": {
- "@cspotcode/source-map-support": "^0.8.0",
- "@tsconfig/node10": "^1.0.7",
- "@tsconfig/node12": "^1.0.7",
- "@tsconfig/node14": "^1.0.0",
- "@tsconfig/node16": "^1.0.2",
- "acorn": "^8.4.1",
- "acorn-walk": "^8.1.1",
- "arg": "^4.1.0",
- "create-require": "^1.1.0",
- "diff": "^4.0.1",
- "make-error": "^1.1.1",
- "v8-compile-cache-lib": "^3.0.1",
- "yn": "3.1.1"
- },
- "bin": {
- "ts-node": "dist/bin.js",
- "ts-node-cwd": "dist/bin-cwd.js",
- "ts-node-esm": "dist/bin-esm.js",
- "ts-node-script": "dist/bin-script.js",
- "ts-node-transpile-only": "dist/bin-transpile.js",
- "ts-script": "dist/bin-script-deprecated.js"
- },
- "peerDependencies": {
- "@swc/core": ">=1.2.50",
- "@swc/wasm": ">=1.2.50",
- "@types/node": "*",
- "typescript": ">=2.7"
- },
- "peerDependenciesMeta": {
- "@swc/core": {
- "optional": true
- },
- "@swc/wasm": {
- "optional": true
- }
- }
- },
- "node_modules/tsconfig-paths": {
- "version": "4.2.0",
- "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-4.2.0.tgz",
- "integrity": "sha512-NoZ4roiN7LnbKn9QqE1amc9DJfzvZXxF4xDavcOWt1BPkdx+m+0gJuPM+S0vCe7zTJMYUP0R8pO2XMr+Y8oLIg==",
- "dev": true,
- "dependencies": {
- "json5": "^2.2.2",
- "minimist": "^1.2.6",
- "strip-bom": "^3.0.0"
- },
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/tsconfig-paths/node_modules/strip-bom": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz",
- "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==",
- "dev": true,
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/tslib": {
- "version": "2.6.2",
- "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz",
- "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==",
- "dev": true
- },
- "node_modules/tsx": {
- "version": "4.7.0",
- "resolved": "https://registry.npmjs.org/tsx/-/tsx-4.7.0.tgz",
- "integrity": "sha512-I+t79RYPlEYlHn9a+KzwrvEwhJg35h/1zHsLC2JXvhC2mdynMv6Zxzvhv5EMV6VF5qJlLlkSnMVvdZV3PSIGcg==",
- "dev": true,
- "dependencies": {
- "esbuild": "~0.19.10",
- "get-tsconfig": "^4.7.2"
- },
- "bin": {
- "tsx": "dist/cli.mjs"
- },
- "engines": {
- "node": ">=18.0.0"
- },
- "optionalDependencies": {
- "fsevents": "~2.3.3"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/aix-ppc64": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.19.12.tgz",
- "integrity": "sha512-bmoCYyWdEL3wDQIVbcyzRyeKLgk2WtWLTWz1ZIAZF/EGbNOwSA6ew3PftJ1PqMiOOGu0OyFMzG53L0zqIpPeNA==",
- "cpu": [
- "ppc64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "aix"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/android-arm": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.19.12.tgz",
- "integrity": "sha512-qg/Lj1mu3CdQlDEEiWrlC4eaPZ1KztwGJ9B6J+/6G+/4ewxJg7gqj8eVYWvao1bXrqGiW2rsBZFSX3q2lcW05w==",
- "cpu": [
- "arm"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "android"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/android-arm64": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.19.12.tgz",
- "integrity": "sha512-P0UVNGIienjZv3f5zq0DP3Nt2IE/3plFzuaS96vihvD0Hd6H/q4WXUGpCxD/E8YrSXfNyRPbpTq+T8ZQioSuPA==",
- "cpu": [
- "arm64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "android"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/android-x64": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.19.12.tgz",
- "integrity": "sha512-3k7ZoUW6Q6YqhdhIaq/WZ7HwBpnFBlW905Fa4s4qWJyiNOgT1dOqDiVAQFwBH7gBRZr17gLrlFCRzF6jFh7Kew==",
- "cpu": [
- "x64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "android"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/darwin-arm64": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.19.12.tgz",
- "integrity": "sha512-B6IeSgZgtEzGC42jsI+YYu9Z3HKRxp8ZT3cqhvliEHovq8HSX2YX8lNocDn79gCKJXOSaEot9MVYky7AKjCs8g==",
- "cpu": [
- "arm64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "darwin"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/darwin-x64": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.19.12.tgz",
- "integrity": "sha512-hKoVkKzFiToTgn+41qGhsUJXFlIjxI/jSYeZf3ugemDYZldIXIxhvwN6erJGlX4t5h417iFuheZ7l+YVn05N3A==",
- "cpu": [
- "x64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "darwin"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/freebsd-arm64": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.19.12.tgz",
- "integrity": "sha512-4aRvFIXmwAcDBw9AueDQ2YnGmz5L6obe5kmPT8Vd+/+x/JMVKCgdcRwH6APrbpNXsPz+K653Qg8HB/oXvXVukA==",
- "cpu": [
- "arm64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "freebsd"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/freebsd-x64": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.19.12.tgz",
- "integrity": "sha512-EYoXZ4d8xtBoVN7CEwWY2IN4ho76xjYXqSXMNccFSx2lgqOG/1TBPW0yPx1bJZk94qu3tX0fycJeeQsKovA8gg==",
- "cpu": [
- "x64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "freebsd"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/linux-arm": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.19.12.tgz",
- "integrity": "sha512-J5jPms//KhSNv+LO1S1TX1UWp1ucM6N6XuL6ITdKWElCu8wXP72l9MM0zDTzzeikVyqFE6U8YAV9/tFyj0ti+w==",
- "cpu": [
- "arm"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/linux-arm64": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.19.12.tgz",
- "integrity": "sha512-EoTjyYyLuVPfdPLsGVVVC8a0p1BFFvtpQDB/YLEhaXyf/5bczaGeN15QkR+O4S5LeJ92Tqotve7i1jn35qwvdA==",
- "cpu": [
- "arm64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/linux-ia32": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.19.12.tgz",
- "integrity": "sha512-Thsa42rrP1+UIGaWz47uydHSBOgTUnwBwNq59khgIwktK6x60Hivfbux9iNR0eHCHzOLjLMLfUMLCypBkZXMHA==",
- "cpu": [
- "ia32"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/linux-loong64": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.19.12.tgz",
- "integrity": "sha512-LiXdXA0s3IqRRjm6rV6XaWATScKAXjI4R4LoDlvO7+yQqFdlr1Bax62sRwkVvRIrwXxvtYEHHI4dm50jAXkuAA==",
- "cpu": [
- "loong64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/linux-mips64el": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.19.12.tgz",
- "integrity": "sha512-fEnAuj5VGTanfJ07ff0gOA6IPsvrVHLVb6Lyd1g2/ed67oU1eFzL0r9WL7ZzscD+/N6i3dWumGE1Un4f7Amf+w==",
- "cpu": [
- "mips64el"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/linux-ppc64": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.19.12.tgz",
- "integrity": "sha512-nYJA2/QPimDQOh1rKWedNOe3Gfc8PabU7HT3iXWtNUbRzXS9+vgB0Fjaqr//XNbd82mCxHzik2qotuI89cfixg==",
- "cpu": [
- "ppc64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/linux-riscv64": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.19.12.tgz",
- "integrity": "sha512-2MueBrlPQCw5dVJJpQdUYgeqIzDQgw3QtiAHUC4RBz9FXPrskyyU3VI1hw7C0BSKB9OduwSJ79FTCqtGMWqJHg==",
- "cpu": [
- "riscv64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/linux-s390x": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.19.12.tgz",
- "integrity": "sha512-+Pil1Nv3Umes4m3AZKqA2anfhJiVmNCYkPchwFJNEJN5QxmTs1uzyy4TvmDrCRNT2ApwSari7ZIgrPeUx4UZDg==",
- "cpu": [
- "s390x"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/linux-x64": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.19.12.tgz",
- "integrity": "sha512-B71g1QpxfwBvNrfyJdVDexenDIt1CiDN1TIXLbhOw0KhJzE78KIFGX6OJ9MrtC0oOqMWf+0xop4qEU8JrJTwCg==",
- "cpu": [
- "x64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "linux"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/netbsd-x64": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.19.12.tgz",
- "integrity": "sha512-3ltjQ7n1owJgFbuC61Oj++XhtzmymoCihNFgT84UAmJnxJfm4sYCiSLTXZtE00VWYpPMYc+ZQmB6xbSdVh0JWA==",
- "cpu": [
- "x64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "netbsd"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/openbsd-x64": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.19.12.tgz",
- "integrity": "sha512-RbrfTB9SWsr0kWmb9srfF+L933uMDdu9BIzdA7os2t0TXhCRjrQyCeOt6wVxr79CKD4c+p+YhCj31HBkYcXebw==",
- "cpu": [
- "x64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "openbsd"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/sunos-x64": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.19.12.tgz",
- "integrity": "sha512-HKjJwRrW8uWtCQnQOz9qcU3mUZhTUQvi56Q8DPTLLB+DawoiQdjsYq+j+D3s9I8VFtDr+F9CjgXKKC4ss89IeA==",
- "cpu": [
- "x64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "sunos"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/win32-arm64": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.19.12.tgz",
- "integrity": "sha512-URgtR1dJnmGvX864pn1B2YUYNzjmXkuJOIqG2HdU62MVS4EHpU2946OZoTMnRUHklGtJdJZ33QfzdjGACXhn1A==",
- "cpu": [
- "arm64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "win32"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/win32-ia32": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.19.12.tgz",
- "integrity": "sha512-+ZOE6pUkMOJfmxmBZElNOx72NKpIa/HFOMGzu8fqzQJ5kgf6aTGrcJaFsNiVMH4JKpMipyK+7k0n2UXN7a8YKQ==",
- "cpu": [
- "ia32"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "win32"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/@esbuild/win32-x64": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.19.12.tgz",
- "integrity": "sha512-T1QyPSDCyMXaO3pzBkF96E8xMkiRYbUEZADd29SyPGabqxMViNoii+NcK7eWJAEoU6RZyEm5lVSIjTmcdoB9HA==",
- "cpu": [
- "x64"
- ],
- "dev": true,
- "optional": true,
- "os": [
- "win32"
- ],
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/tsx/node_modules/esbuild": {
- "version": "0.19.12",
- "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.19.12.tgz",
- "integrity": "sha512-aARqgq8roFBj054KvQr5f1sFu0D65G+miZRCuJyJ0G13Zwx7vRar5Zhn2tkQNzIXcBrNVsv/8stehpj+GAjgbg==",
- "dev": true,
- "hasInstallScript": true,
- "bin": {
- "esbuild": "bin/esbuild"
- },
- "engines": {
- "node": ">=12"
- },
- "optionalDependencies": {
- "@esbuild/aix-ppc64": "0.19.12",
- "@esbuild/android-arm": "0.19.12",
- "@esbuild/android-arm64": "0.19.12",
- "@esbuild/android-x64": "0.19.12",
- "@esbuild/darwin-arm64": "0.19.12",
- "@esbuild/darwin-x64": "0.19.12",
- "@esbuild/freebsd-arm64": "0.19.12",
- "@esbuild/freebsd-x64": "0.19.12",
- "@esbuild/linux-arm": "0.19.12",
- "@esbuild/linux-arm64": "0.19.12",
- "@esbuild/linux-ia32": "0.19.12",
- "@esbuild/linux-loong64": "0.19.12",
- "@esbuild/linux-mips64el": "0.19.12",
- "@esbuild/linux-ppc64": "0.19.12",
- "@esbuild/linux-riscv64": "0.19.12",
- "@esbuild/linux-s390x": "0.19.12",
- "@esbuild/linux-x64": "0.19.12",
- "@esbuild/netbsd-x64": "0.19.12",
- "@esbuild/openbsd-x64": "0.19.12",
- "@esbuild/sunos-x64": "0.19.12",
- "@esbuild/win32-arm64": "0.19.12",
- "@esbuild/win32-ia32": "0.19.12",
- "@esbuild/win32-x64": "0.19.12"
- }
- },
- "node_modules/type-check": {
- "version": "0.4.0",
- "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz",
- "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==",
- "dev": true,
- "dependencies": {
- "prelude-ls": "^1.2.1"
- },
- "engines": {
- "node": ">= 0.8.0"
- }
- },
- "node_modules/type-detect": {
- "version": "4.0.8",
- "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz",
- "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==",
- "dev": true,
- "engines": {
- "node": ">=4"
- }
- },
- "node_modules/type-fest": {
- "version": "0.20.2",
- "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz",
- "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==",
- "dev": true,
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- },
- "node_modules/typed-array-buffer": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.1.tgz",
- "integrity": "sha512-RSqu1UEuSlrBhHTWC8O9FnPjOduNs4M7rJ4pRKoEjtx1zUNOPN2sSXHLDX+Y2WPbHIxbvg4JFo2DNAEfPIKWoQ==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.6",
- "es-errors": "^1.3.0",
- "is-typed-array": "^1.1.13"
- },
- "engines": {
- "node": ">= 0.4"
- }
- },
- "node_modules/typed-array-byte-length": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.0.tgz",
- "integrity": "sha512-Or/+kvLxNpeQ9DtSydonMxCx+9ZXOswtwJn17SNLvhptaXYDJvkFFP5zbfU/uLmvnBJlI4yrnXRxpdWH/M5tNA==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2",
- "for-each": "^0.3.3",
- "has-proto": "^1.0.1",
- "is-typed-array": "^1.1.10"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/typed-array-byte-offset": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.0.tgz",
- "integrity": "sha512-RD97prjEt9EL8YgAgpOkf3O4IF9lhJFr9g0htQkm0rchFp/Vx7LW5Q8fSXXub7BXAODyUQohRMyOc3faCPd0hg==",
- "dev": true,
- "dependencies": {
- "available-typed-arrays": "^1.0.5",
- "call-bind": "^1.0.2",
- "for-each": "^0.3.3",
- "has-proto": "^1.0.1",
- "is-typed-array": "^1.1.10"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/typed-array-length": {
- "version": "1.0.4",
- "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.4.tgz",
- "integrity": "sha512-KjZypGq+I/H7HI5HlOoGHkWUUGq+Q0TPhQurLbyrVrvnKTBgzLhIJ7j6J/XTQOi0d1RjyZ0wdas8bKs2p0x3Ng==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2",
- "for-each": "^0.3.3",
- "is-typed-array": "^1.1.9"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/typescript": {
- "version": "5.3.3",
- "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.3.tgz",
- "integrity": "sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw==",
- "dev": true,
- "bin": {
- "tsc": "bin/tsc",
- "tsserver": "bin/tsserver"
- },
- "engines": {
- "node": ">=14.17"
- }
- },
- "node_modules/ultron": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/ultron/-/ultron-1.0.2.tgz",
- "integrity": "sha512-QMpnpVtYaWEeY+MwKDN/UdKlE/LsFZXM5lO1u7GaZzNgmIbGixHEmVMIKT+vqYOALu3m5GYQy9kz4Xu4IVn7Ow=="
- },
- "node_modules/unbox-primitive": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz",
- "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==",
- "dev": true,
- "dependencies": {
- "call-bind": "^1.0.2",
- "has-bigints": "^1.0.2",
- "has-symbols": "^1.0.3",
- "which-boxed-primitive": "^1.0.2"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/underscore": {
- "version": "1.13.6",
- "resolved": "https://registry.npmjs.org/underscore/-/underscore-1.13.6.tgz",
- "integrity": "sha512-+A5Sja4HP1M08MaXya7p5LvjuM7K6q/2EaC0+iovj/wOcMsTzMvDFbasi/oSapiwOlt252IqsKqPjCl7huKS0A=="
- },
- "node_modules/undici-types": {
- "version": "5.26.5",
- "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz",
- "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA=="
- },
- "node_modules/uniq": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/uniq/-/uniq-1.0.1.tgz",
- "integrity": "sha512-Gw+zz50YNKPDKXs+9d+aKAjVwpjNwqzvNpLigIruT4HA9lMZNdMqs9x07kKHB/L9WRzqp4+DlTU5s4wG2esdoA=="
- },
- "node_modules/update-browserslist-db": {
- "version": "1.0.13",
- "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.13.tgz",
- "integrity": "sha512-xebP81SNcPuNpPP3uzeW1NYXxI3rxyJzF3pD6sH4jE7o/IX+WtSpwnVU+qIsDPyk0d3hmFQ7mjqc6AtV604hbg==",
- "dev": true,
- "funding": [
- {
- "type": "opencollective",
- "url": "https://opencollective.com/browserslist"
- },
- {
- "type": "tidelift",
- "url": "https://tidelift.com/funding/github/npm/browserslist"
- },
- {
- "type": "github",
- "url": "https://github.com/sponsors/ai"
- }
- ],
- "dependencies": {
- "escalade": "^3.1.1",
- "picocolors": "^1.0.0"
- },
- "bin": {
- "update-browserslist-db": "cli.js"
- },
- "peerDependencies": {
- "browserslist": ">= 4.21.0"
- }
- },
- "node_modules/uri-js": {
- "version": "4.4.1",
- "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz",
- "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==",
- "dev": true,
- "dependencies": {
- "punycode": "^2.1.0"
- }
- },
- "node_modules/url-parse": {
- "version": "1.5.10",
- "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.5.10.tgz",
- "integrity": "sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ==",
- "dependencies": {
- "querystringify": "^2.1.1",
- "requires-port": "^1.0.0"
- }
- },
- "node_modules/util-deprecate": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
- "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw=="
- },
- "node_modules/utp": {
- "version": "0.0.7",
- "resolved": "https://registry.npmjs.org/utp/-/utp-0.0.7.tgz",
- "integrity": "sha512-2ZLjisH0HQkpqZTg2m7TK0Yn7TETTg7DxM0EpCKIIIV2ky9w9nSxW5a7gzdk4nH2h+pomrrGw0uywrUJfsm2eA==",
- "dependencies": {
- "cyclist": "~0.1.0"
- }
- },
- "node_modules/uuid": {
- "version": "8.3.2",
- "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz",
- "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==",
- "bin": {
- "uuid": "dist/bin/uuid"
- }
- },
- "node_modules/v8-compile-cache-lib": {
- "version": "3.0.1",
- "resolved": "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz",
- "integrity": "sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg==",
- "dev": true
- },
- "node_modules/v8-to-istanbul": {
- "version": "9.2.0",
- "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.2.0.tgz",
- "integrity": "sha512-/EH/sDgxU2eGxajKdwLCDmQ4FWq+kpi3uCmBGpw1xJtnAxEjlD8j8PEiGWpCIMIs3ciNAgH0d3TTJiUkYzyZjA==",
- "dev": true,
- "dependencies": {
- "@jridgewell/trace-mapping": "^0.3.12",
- "@types/istanbul-lib-coverage": "^2.0.1",
- "convert-source-map": "^2.0.0"
- },
- "engines": {
- "node": ">=10.12.0"
- }
- },
- "node_modules/validator": {
- "version": "13.11.0",
- "resolved": "https://registry.npmjs.org/validator/-/validator-13.11.0.tgz",
- "integrity": "sha512-Ii+sehpSfZy+At5nPdnyMhx78fEoPDkR2XW/zimHEL3MyGJQOCQ7WeP20jPYRz7ZCpcKLB21NxuXHF3bxjStBQ==",
- "engines": {
- "node": ">= 0.10"
- }
- },
- "node_modules/walker": {
- "version": "1.0.8",
- "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz",
- "integrity": "sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==",
- "dev": true,
- "dependencies": {
- "makeerror": "1.0.12"
- }
- },
- "node_modules/wcwidth": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/wcwidth/-/wcwidth-1.0.1.tgz",
- "integrity": "sha512-XHPEwS0q6TaxcvG85+8EYkbiCux2XtWG2mkc47Ng2A77BQu9+DqIOJldST4HgPkuea7dvKSj5VgX3P1d4rW8Tg==",
- "dev": true,
- "dependencies": {
- "defaults": "^1.0.3"
- }
- },
- "node_modules/webidl-conversions": {
- "version": "7.0.0",
- "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz",
- "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==",
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/whatwg-url": {
- "version": "13.0.0",
- "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-13.0.0.tgz",
- "integrity": "sha512-9WWbymnqj57+XEuqADHrCJ2eSXzn8WXIW/YSGaZtb2WKAInQ6CHfaUUcTyyver0p8BDg5StLQq8h1vtZuwmOig==",
- "dependencies": {
- "tr46": "^4.1.1",
- "webidl-conversions": "^7.0.0"
- },
- "engines": {
- "node": ">=16"
- }
- },
- "node_modules/which": {
- "version": "2.0.2",
- "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
- "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
- "dev": true,
- "dependencies": {
- "isexe": "^2.0.0"
- },
- "bin": {
- "node-which": "bin/node-which"
- },
- "engines": {
- "node": ">= 8"
- }
- },
- "node_modules/which-boxed-primitive": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz",
- "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==",
- "dev": true,
- "dependencies": {
- "is-bigint": "^1.0.1",
- "is-boolean-object": "^1.1.0",
- "is-number-object": "^1.0.4",
- "is-string": "^1.0.5",
- "is-symbol": "^1.0.3"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/which-typed-array": {
- "version": "1.1.14",
- "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.14.tgz",
- "integrity": "sha512-VnXFiIW8yNn9kIHN88xvZ4yOWchftKDsRJ8fEPacX/wl1lOvBrhsJ/OeJCXq7B0AaijRuqgzSKalJoPk+D8MPg==",
- "dev": true,
- "dependencies": {
- "available-typed-arrays": "^1.0.6",
- "call-bind": "^1.0.5",
- "for-each": "^0.3.3",
- "gopd": "^1.0.1",
- "has-tostringtag": "^1.0.1"
- },
- "engines": {
- "node": ">= 0.4"
- },
- "funding": {
- "url": "https://github.com/sponsors/ljharb"
- }
- },
- "node_modules/wkx": {
- "version": "0.5.0",
- "resolved": "https://registry.npmjs.org/wkx/-/wkx-0.5.0.tgz",
- "integrity": "sha512-Xng/d4Ichh8uN4l0FToV/258EjMGU9MGcA0HV2d9B/ZpZB3lqQm7nkOdZdm5GhKtLLhAE7PiVQwN4eN+2YJJUg==",
- "dependencies": {
- "@types/node": "*"
- }
- },
- "node_modules/wrap-ansi": {
- "version": "6.2.0",
- "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz",
- "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==",
- "dev": true,
- "dependencies": {
- "ansi-styles": "^4.0.0",
- "string-width": "^4.1.0",
- "strip-ansi": "^6.0.0"
- },
- "engines": {
- "node": ">=8"
- }
- },
- "node_modules/wrappy": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
- "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ=="
- },
- "node_modules/write-file-atomic": {
- "version": "4.0.2",
- "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-4.0.2.tgz",
- "integrity": "sha512-7KxauUdBmSdWnmpaGFg+ppNjKF8uNLry8LyzjauQDOVONfFLNKrKvQOxZ/VuTIcS/gge/YNahf5RIIQWTSarlg==",
- "dev": true,
- "dependencies": {
- "imurmurhash": "^0.1.4",
- "signal-exit": "^3.0.7"
- },
- "engines": {
- "node": "^12.13.0 || ^14.15.0 || >=16.0.0"
- }
- },
- "node_modules/ws": {
- "version": "1.1.5",
- "resolved": "https://registry.npmjs.org/ws/-/ws-1.1.5.tgz",
- "integrity": "sha512-o3KqipXNUdS7wpQzBHSe180lBGO60SoK0yVo3CYJgb2MkobuWuBX6dhkYP5ORCLd55y+SaflMOV5fqAB53ux4w==",
- "dependencies": {
- "options": ">=0.0.5",
- "ultron": "1.0.x"
- }
- },
- "node_modules/xtend": {
- "version": "4.0.2",
- "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz",
- "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==",
- "engines": {
- "node": ">=0.4"
- }
- },
- "node_modules/y18n": {
- "version": "5.0.8",
- "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz",
- "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==",
- "dev": true,
- "engines": {
- "node": ">=10"
- }
- },
- "node_modules/yallist": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
- "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A=="
- },
- "node_modules/yargs": {
- "version": "17.7.2",
- "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz",
- "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==",
- "dev": true,
- "dependencies": {
- "cliui": "^8.0.1",
- "escalade": "^3.1.1",
- "get-caller-file": "^2.0.5",
- "require-directory": "^2.1.1",
- "string-width": "^4.2.3",
- "y18n": "^5.0.5",
- "yargs-parser": "^21.1.1"
- },
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/yargs-parser": {
- "version": "21.1.1",
- "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz",
- "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==",
- "dev": true,
- "engines": {
- "node": ">=12"
- }
- },
- "node_modules/yn": {
- "version": "3.1.1",
- "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz",
- "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==",
- "dev": true,
- "engines": {
- "node": ">=6"
- }
- },
- "node_modules/yocto-queue": {
- "version": "0.1.0",
- "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz",
- "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==",
- "dev": true,
- "engines": {
- "node": ">=10"
- },
- "funding": {
- "url": "https://github.com/sponsors/sindresorhus"
- }
- }
- }
-}
diff --git a/src/node/consumer/package.json b/src/node/consumer/package.json
deleted file mode 100644
index e7d24a4..0000000
--- a/src/node/consumer/package.json
+++ /dev/null
@@ -1,61 +0,0 @@
-{
- "name": "consumer",
- "version": "0.0.1",
- "type": "module",
- "scripts": {
- "clean": "rm -rf dist",
- "build": "tsx esbuild.ts",
- "dev": "tsx watch --ignore node_modules src/main.ts | pino-pretty",
- "start": "node dist/main.cjs",
- "lint": "eslint ./src --ext .ts,.js",
- "lint-fix": "npm run lint -- --fix",
- "test": "jest",
- "test:watch": "jest --watch"
- },
- "license": "MIT",
- "dependencies": {
- "@ctrl/video-filename-parser": "^5.2.0",
- "@tirke/node-cache-manager-mongodb": "^1.6.0",
- "amqplib": "^0.10.3",
- "axios": "^1.6.1",
- "bottleneck": "^2.19.5",
- "cache-manager": "^5.4.0",
- "fuse.js": "^7.0.0",
- "inversify": "^6.0.2",
- "magnet-uri": "^6.2.0",
- "moment": "^2.30.1",
- "mongoose": "^8.2.0",
- "name-to-imdb": "^3.0.4",
- "parse-torrent-title": "https://github.com/TheBeastLT/parse-torrent-title.git#022408972c2a040f846331a912a6a8487746a654",
- "pg": "^8.11.3",
- "pg-hstore": "^2.3.4",
- "pino": "^8.18.0",
- "reflect-metadata": "^0.2.1",
- "sequelize": "^6.36.0",
- "sequelize-typescript": "^2.1.6",
- "torrent-stream": "^1.2.1"
- },
- "devDependencies": {
- "@types/amqplib": "^0.10.4",
- "@types/jest": "^29.5.12",
- "@types/magnet-uri": "^5.1.5",
- "@types/node": "^20.11.16",
- "@types/pg": "^8.11.0",
- "@types/torrent-stream": "^0.0.9",
- "@types/validator": "^13.11.8",
- "@typescript-eslint/eslint-plugin": "^6.21.0",
- "@typescript-eslint/parser": "^6.21.0",
- "esbuild": "^0.20.0",
- "eslint": "^8.56.0",
- "eslint-plugin-import": "^2.29.1",
- "eslint-plugin-import-helpers": "^1.3.1",
- "jest": "^29.7.0",
- "msw": "^2.1.7",
- "pino-pretty": "^10.3.1",
- "ts-jest": "^29.1.2",
- "ts-node": "^10.9.2",
- "tsconfig-paths": "^4.2.0",
- "tsx": "^4.7.0",
- "typescript": "^5.3.3"
- }
-}
diff --git a/src/node/consumer/src/lib/enums/cache_types.ts b/src/node/consumer/src/lib/enums/cache_types.ts
deleted file mode 100644
index 6eb1f0e..0000000
--- a/src/node/consumer/src/lib/enums/cache_types.ts
+++ /dev/null
@@ -1,4 +0,0 @@
-export enum CacheType {
- Memory = 'memory',
- MongoDb = 'mongodb'
-}
diff --git a/src/node/consumer/src/lib/enums/torrent_types.ts b/src/node/consumer/src/lib/enums/torrent_types.ts
deleted file mode 100644
index 0c17983..0000000
--- a/src/node/consumer/src/lib/enums/torrent_types.ts
+++ /dev/null
@@ -1,5 +0,0 @@
-export enum TorrentType {
- Series = 'Series',
- Movie = 'Movie',
- Anime = 'anime',
-}
diff --git a/src/node/consumer/src/lib/helpers/boolean_helpers.ts b/src/node/consumer/src/lib/helpers/boolean_helpers.ts
deleted file mode 100644
index 5c76f08..0000000
--- a/src/node/consumer/src/lib/helpers/boolean_helpers.ts
+++ /dev/null
@@ -1,18 +0,0 @@
-export const BooleanHelpers = {
- parseBool: (value: string | undefined, defaultValue: boolean): boolean => {
- switch (value?.trim().toLowerCase()) {
- case undefined:
- return defaultValue;
- case 'true':
- case 'yes':
- case '1':
- return true;
- case 'false':
- case 'no':
- case '0':
- return false;
- default:
- throw new Error(`Invalid boolean value: '${value}'. Allowed values are 'true', 'false', 'yes', 'no', '1', or '0'.`);
- }
- }
-}
diff --git a/src/node/consumer/src/lib/helpers/extension_helpers.ts b/src/node/consumer/src/lib/helpers/extension_helpers.ts
deleted file mode 100644
index a7ed11b..0000000
--- a/src/node/consumer/src/lib/helpers/extension_helpers.ts
+++ /dev/null
@@ -1,66 +0,0 @@
-const VIDEO_EXTENSIONS = [
- "3g2",
- "3gp",
- "avi",
- "flv",
- "mkv",
- "mk3d",
- "mov",
- "mp2",
- "mp4",
- "m4v",
- "mpe",
- "mpeg",
- "mpg",
- "mpv",
- "webm",
- "wmv",
- "ogm",
- "divx"
-];
-
-const SUBTITLE_EXTENSIONS = [
- "aqt",
- "gsub",
- "jss",
- "sub",
- "ttxt",
- "pjs",
- "psb",
- "rt",
- "smi",
- "slt",
- "ssf",
- "srt",
- "ssa",
- "ass",
- "usf",
- "idx",
- "vtt"
-];
-
-const DISK_EXTENSIONS = [
- "iso",
- "m2ts",
- "ts",
- "vob"
-];
-
-export const ExtensionHelpers = {
- isVideo(filename: string): boolean {
- return this.isExtension(filename, VIDEO_EXTENSIONS);
- },
-
- isSubtitle(filename: string): boolean {
- return this.isExtension(filename, SUBTITLE_EXTENSIONS);
- },
-
- isDisk(filename: string): boolean {
- return this.isExtension(filename, DISK_EXTENSIONS);
- },
-
- isExtension(filename: string, extensions: string[]): boolean {
- const extensionMatch = filename.match(/\.(\w{2,4})$/);
- return extensionMatch !== null && extensions.includes(extensionMatch[1].toLowerCase());
- }
-}
diff --git a/src/node/consumer/src/lib/helpers/promises_helpers.ts b/src/node/consumer/src/lib/helpers/promises_helpers.ts
deleted file mode 100644
index ebb7635..0000000
--- a/src/node/consumer/src/lib/helpers/promises_helpers.ts
+++ /dev/null
@@ -1,37 +0,0 @@
-/* eslint-disable @typescript-eslint/no-explicit-any */
-export const PromiseHelpers = {
-
- sequence: async function (promises: (() => Promise)[]): Promise {
- return promises.reduce((promise, func) =>
- promise.then(result => func().then(res => result.concat(res))), Promise.resolve([]));
- },
-
- first: async function (promises: any): Promise {
- return Promise.all(promises.map((p: any) => {
- return p.then((val: any) => Promise.reject(val), (err: any) => Promise.resolve(err));
- })).then(
- (errors) => Promise.reject(errors),
- (val) => Promise.resolve(val)
- );
- },
-
- delay: async function (duration: number): Promise {
- return new Promise(resolve => setTimeout(() => resolve(), duration));
- },
-
- timeout: async function (timeoutMs: number, promise: any, message = 'Timed out'): Promise {
- return Promise.race([
- promise,
- new Promise(function (resolve, reject) {
- setTimeout(function () {
- reject(message);
- }, timeoutMs);
- })
- ]);
- },
-
- mostCommonValue: function (array: any[]): any {
- return array.sort((a, b) => array.filter(v => v === a).length - array.filter(v => v === b).length).pop();
- }
-};
-/* eslint-enable @typescript-eslint/no-explicit-any */
diff --git a/src/node/consumer/src/lib/interfaces/cache_options.ts b/src/node/consumer/src/lib/interfaces/cache_options.ts
deleted file mode 100644
index 9bdd06a..0000000
--- a/src/node/consumer/src/lib/interfaces/cache_options.ts
+++ /dev/null
@@ -1,3 +0,0 @@
-export interface ICacheOptions {
- ttl: number;
-}
diff --git a/src/node/consumer/src/lib/interfaces/cache_service.ts b/src/node/consumer/src/lib/interfaces/cache_service.ts
deleted file mode 100644
index dab176c..0000000
--- a/src/node/consumer/src/lib/interfaces/cache_service.ts
+++ /dev/null
@@ -1,11 +0,0 @@
-import {CacheMethod} from "@services/cache_service";
-
-/* eslint-disable @typescript-eslint/no-explicit-any */
-export interface ICacheService {
- cacheWrapImdbId: (key: string, method: CacheMethod) => Promise;
- cacheWrapKitsuId: (key: string, method: CacheMethod) => Promise;
- cacheWrapMetadata: (id: string, method: CacheMethod) => Promise;
- cacheTrackers: (method: CacheMethod) => Promise;
-}
-
-/* eslint-enable @typescript-eslint/no-explicit-any */
diff --git a/src/node/consumer/src/lib/interfaces/cinemeta_metadata.ts b/src/node/consumer/src/lib/interfaces/cinemeta_metadata.ts
deleted file mode 100644
index 5b2cff3..0000000
--- a/src/node/consumer/src/lib/interfaces/cinemeta_metadata.ts
+++ /dev/null
@@ -1,84 +0,0 @@
-import {ICommonVideoMetadata} from "@interfaces/common_video_metadata";
-
-export interface ICinemetaJsonResponse {
- meta?: ICinemetaMetaData;
- trailerStreams?: ICinemetaTrailerStream[];
- links?: ICinemetaLink[];
- behaviorHints?: ICinemetaBehaviorHints;
-}
-
-export interface ICinemetaMetaData {
- awards?: string;
- cast?: string[];
- country?: string;
- description?: string;
- director?: null;
- dvdRelease?: null;
- genre?: string[];
- imdbRating?: string;
- name?: string;
- popularity?: number;
- poster?: string;
- released?: string;
- runtime?: string;
- status?: string;
- tvdb_id?: number;
- type?: string;
- writer?: string[];
- year?: string;
- background?: string;
- logo?: string;
- popularities?: ICinemetaPopularities;
- moviedb_id?: number;
- slug?: string;
- trailers?: ICinemetaTrailer[];
- id?: string;
- genres?: string[];
- releaseInfo?: string;
- videos?: ICinemetaVideo[];
-}
-
-export interface ICinemetaPopularities {
- PXS_TEST?: number;
- PXS?: number;
- SCM?: number;
- EXMD?: number;
- ALLIANCE?: number;
- EJD?: number;
- moviedb?: number;
- trakt?: number;
- stremio?: number;
- stremio_lib?: number;
-}
-
-export interface ICinemetaTrailer {
- source?: string;
- type?: string;
-}
-
-export interface ICinemetaVideo extends ICommonVideoMetadata {
- name?: string;
- number?: number;
- firstAired?: string;
- tvdb_id?: number;
- rating?: string;
- overview?: string;
- thumbnail?: string;
- description?: string;
-}
-
-export interface ICinemetaTrailerStream {
- title?: string;
- ytId?: string;
-}
-
-export interface ICinemetaLink {
- name?: string;
- category?: string;
- url?: string;
-}
-
-export interface ICinemetaBehaviorHints {
- defaultVideoId?: null;
- hasScheduledVideos?: boolean;
-}
diff --git a/src/node/consumer/src/lib/interfaces/common_video_metadata.ts b/src/node/consumer/src/lib/interfaces/common_video_metadata.ts
deleted file mode 100644
index 8108093..0000000
--- a/src/node/consumer/src/lib/interfaces/common_video_metadata.ts
+++ /dev/null
@@ -1,9 +0,0 @@
-export interface ICommonVideoMetadata {
- season?: number;
- episode?: number;
- released?: string;
- title?: string;
- name?: string;
- id?: string;
- imdb_id?: string;
-}
diff --git a/src/node/consumer/src/lib/interfaces/ingested_rabbit_message.ts b/src/node/consumer/src/lib/interfaces/ingested_rabbit_message.ts
deleted file mode 100644
index 34b8b8e..0000000
--- a/src/node/consumer/src/lib/interfaces/ingested_rabbit_message.ts
+++ /dev/null
@@ -1,15 +0,0 @@
-export interface IIngestedRabbitTorrent {
- name: string;
- source: string;
- category: string;
- infoHash: string;
- size: string;
- seeders: number;
- leechers: number;
- imdb: string;
- processed: boolean;
-}
-
-export interface IIngestedRabbitMessage {
- message: IIngestedRabbitTorrent;
-}
diff --git a/src/node/consumer/src/lib/interfaces/kitsu_catalog_metadata.ts b/src/node/consumer/src/lib/interfaces/kitsu_catalog_metadata.ts
deleted file mode 100644
index a0a5ccc..0000000
--- a/src/node/consumer/src/lib/interfaces/kitsu_catalog_metadata.ts
+++ /dev/null
@@ -1,23 +0,0 @@
-import {IKitsuLink, IKitsuTrailer} from "@interfaces/kitsu_metadata";
-
-export interface IKitsuCatalogJsonResponse {
- metas: IKitsuCatalogMetaData[];
-}
-
-export interface IKitsuCatalogMetaData {
- id: string;
- type: string;
- animeType: string;
- name: string;
- aliases: string[];
- description: string;
- releaseInfo: string;
- runtime: string;
- imdbRating: string;
- genres: string[];
- logo?: string;
- poster: string;
- background: string;
- trailers: IKitsuTrailer[];
- links: IKitsuLink[];
-}
diff --git a/src/node/consumer/src/lib/interfaces/kitsu_metadata.ts b/src/node/consumer/src/lib/interfaces/kitsu_metadata.ts
deleted file mode 100644
index 67c7547..0000000
--- a/src/node/consumer/src/lib/interfaces/kitsu_metadata.ts
+++ /dev/null
@@ -1,49 +0,0 @@
-import {ICommonVideoMetadata} from "@interfaces/common_video_metadata";
-
-export interface IKitsuJsonResponse {
- cacheMaxAge?: number;
- meta?: IKitsuMeta;
-}
-
-export interface IKitsuMeta {
- aliases?: string[];
- animeType?: string;
- background?: string;
- description?: string;
- country?: string;
- genres?: string[];
- id?: string;
- imdbRating?: string;
- imdb_id?: string;
- kitsu_id?: string;
- links?: IKitsuLink[];
- logo?: string;
- name?: string;
- poster?: string;
- releaseInfo?: string;
- runtime?: string;
- slug?: string;
- status?: string;
- trailers?: IKitsuTrailer[];
- type?: string;
- userCount?: number;
- videos?: IKitsuVideo[];
- year?: string;
-}
-
-export interface IKitsuVideo extends ICommonVideoMetadata {
- imdbEpisode?: number;
- imdbSeason?: number;
- thumbnail?: string;
-}
-
-export interface IKitsuTrailer {
- source?: string;
- type?: string;
-}
-
-export interface IKitsuLink {
- name?: string;
- category?: string;
- url?: string;
-}
diff --git a/src/node/consumer/src/lib/interfaces/logging_service.ts b/src/node/consumer/src/lib/interfaces/logging_service.ts
deleted file mode 100644
index d4de39f..0000000
--- a/src/node/consumer/src/lib/interfaces/logging_service.ts
+++ /dev/null
@@ -1,12 +0,0 @@
-/* eslint-disable @typescript-eslint/no-explicit-any */
-export interface ILoggingService {
- info(message: string, ...args: any[]): void;
-
- error(message: string, ...args: any[]): void;
-
- debug(message: string, ...args: any[]): void;
-
- warn(message: string, ...args: any[]): void;
-}
-
-/* eslint-enable @typescript-eslint/no-explicit-any */
diff --git a/src/node/consumer/src/lib/interfaces/metadata_query.ts b/src/node/consumer/src/lib/interfaces/metadata_query.ts
deleted file mode 100644
index 1e09f41..0000000
--- a/src/node/consumer/src/lib/interfaces/metadata_query.ts
+++ /dev/null
@@ -1,9 +0,0 @@
-export interface IMetaDataQuery {
- title?: string
- type?: string
- year?: number | string
- date?: string
- season?: number
- episode?: number
- id?: string | number
-}
diff --git a/src/node/consumer/src/lib/interfaces/metadata_response.ts b/src/node/consumer/src/lib/interfaces/metadata_response.ts
deleted file mode 100644
index c1e987e..0000000
--- a/src/node/consumer/src/lib/interfaces/metadata_response.ts
+++ /dev/null
@@ -1,15 +0,0 @@
-import {ICommonVideoMetadata} from "@interfaces/common_video_metadata";
-
-export interface IMetadataResponse {
- kitsuId?: number;
- imdbId?: number;
- type?: string;
- title?: string;
- year?: number;
- country?: string;
- genres?: string[];
- status?: string;
- videos?: ICommonVideoMetadata[];
- episodeCount?: number[];
- totalCount?: number;
-}
diff --git a/src/node/consumer/src/lib/interfaces/metadata_service.ts b/src/node/consumer/src/lib/interfaces/metadata_service.ts
deleted file mode 100644
index 5ef3fe2..0000000
--- a/src/node/consumer/src/lib/interfaces/metadata_service.ts
+++ /dev/null
@@ -1,14 +0,0 @@
-import {IMetaDataQuery} from "@interfaces/metadata_query";
-import {IMetadataResponse} from "@interfaces/metadata_response";
-
-export interface IMetadataService {
- getKitsuId(info: IMetaDataQuery): Promise;
-
- getImdbId(info: IMetaDataQuery): Promise;
-
- getMetadata(query: IMetaDataQuery): Promise;
-
- isEpisodeImdbId(imdbId: string | undefined): Promise;
-
- escapeTitle(title: string): string;
-}
diff --git a/src/node/consumer/src/lib/interfaces/parse_torrent_title_result.ts b/src/node/consumer/src/lib/interfaces/parse_torrent_title_result.ts
deleted file mode 100644
index 1e613f8..0000000
--- a/src/node/consumer/src/lib/interfaces/parse_torrent_title_result.ts
+++ /dev/null
@@ -1,36 +0,0 @@
-import {IFileAttributes} from "@repository/interfaces/file_attributes";
-
-export interface IParseTorrentTitleResult {
- title?: string;
- date?: string;
- year?: number | string;
- resolution?: string;
- extended?: boolean;
- unrated?: boolean;
- proper?: boolean;
- repack?: boolean;
- convert?: boolean;
- hardcoded?: boolean;
- retail?: boolean;
- remastered?: boolean;
- complete?: boolean;
- region?: string;
- container?: string;
- extension?: string;
- source?: string;
- codec?: string;
- bitDepth?: string;
- hdr?: Array;
- audio?: string;
- group?: string;
- volumes?: Array;
- seasons?: Array;
- season?: number;
- episodes?: Array;
- episode?: number;
- languages?: string;
- dubbed?: boolean;
- videoFile?: IFileAttributes;
- folderName?: string;
- fileName?: string;
-}
diff --git a/src/node/consumer/src/lib/interfaces/parsed_torrent.ts b/src/node/consumer/src/lib/interfaces/parsed_torrent.ts
deleted file mode 100644
index c1699df..0000000
--- a/src/node/consumer/src/lib/interfaces/parsed_torrent.ts
+++ /dev/null
@@ -1,18 +0,0 @@
-import {TorrentType} from "@enums/torrent_types";
-import {IParseTorrentTitleResult} from "@interfaces/parse_torrent_title_result";
-import {ITorrentFileCollection} from "@interfaces/torrent_file_collection";
-
-export interface IParsedTorrent extends IParseTorrentTitleResult {
- size?: number;
- isPack?: boolean;
- imdbId?: string | number;
- kitsuId?: number;
- trackers?: string;
- provider?: string | null;
- infoHash: string;
- type: string | TorrentType;
- uploadDate?: Date;
- seeders?: number;
- torrentId?: string;
- fileCollection?: ITorrentFileCollection;
-}
diff --git a/src/node/consumer/src/lib/interfaces/process_torrents_job.ts b/src/node/consumer/src/lib/interfaces/process_torrents_job.ts
deleted file mode 100644
index bd93800..0000000
--- a/src/node/consumer/src/lib/interfaces/process_torrents_job.ts
+++ /dev/null
@@ -1,3 +0,0 @@
-export interface IProcessTorrentsJob {
- listenToQueue: () => Promise;
-}
diff --git a/src/node/consumer/src/lib/interfaces/torrent_download_service.ts b/src/node/consumer/src/lib/interfaces/torrent_download_service.ts
deleted file mode 100644
index e02058a..0000000
--- a/src/node/consumer/src/lib/interfaces/torrent_download_service.ts
+++ /dev/null
@@ -1,6 +0,0 @@
-import {IParsedTorrent} from "@interfaces/parsed_torrent";
-import {ITorrentFileCollection} from "@interfaces/torrent_file_collection";
-
-export interface ITorrentDownloadService {
- getTorrentFiles(torrent: IParsedTorrent, timeout: number): Promise;
-}
diff --git a/src/node/consumer/src/lib/interfaces/torrent_entries_service.ts b/src/node/consumer/src/lib/interfaces/torrent_entries_service.ts
deleted file mode 100644
index 64be4b6..0000000
--- a/src/node/consumer/src/lib/interfaces/torrent_entries_service.ts
+++ /dev/null
@@ -1,18 +0,0 @@
-import {IParsedTorrent} from "@interfaces/parsed_torrent";
-import {ITorrentAttributes, ITorrentCreationAttributes} from "@repository/interfaces/torrent_attributes";
-import {SkipTorrent} from "@repository/models/skipTorrent";
-import {Torrent} from "@repository/models/torrent";
-
-export interface ITorrentEntriesService {
- createTorrentEntry(torrent: IParsedTorrent, overwrite: boolean): Promise;
-
- createSkipTorrentEntry(torrent: ITorrentCreationAttributes): Promise<[SkipTorrent, boolean | null]>;
-
- getStoredTorrentEntry(torrent: Torrent): Promise;
-
- checkAndUpdateTorrent(torrent: IParsedTorrent): Promise;
-
- createTorrentContents(torrent: Torrent): Promise;
-
- updateTorrentSeeders(torrent: ITorrentAttributes): Promise<[number] | undefined>;
-}
diff --git a/src/node/consumer/src/lib/interfaces/torrent_file_collection.ts b/src/node/consumer/src/lib/interfaces/torrent_file_collection.ts
deleted file mode 100644
index 664af7d..0000000
--- a/src/node/consumer/src/lib/interfaces/torrent_file_collection.ts
+++ /dev/null
@@ -1,9 +0,0 @@
-import {IContentAttributes} from "@repository/interfaces/content_attributes";
-import {IFileAttributes} from "@repository/interfaces/file_attributes";
-import {ISubtitleAttributes} from "@repository/interfaces/subtitle_attributes";
-
-export interface ITorrentFileCollection {
- contents?: IContentAttributes[];
- videos?: IFileAttributes[];
- subtitles?: ISubtitleAttributes[];
-}
diff --git a/src/node/consumer/src/lib/interfaces/torrent_file_service.ts b/src/node/consumer/src/lib/interfaces/torrent_file_service.ts
deleted file mode 100644
index cab4f48..0000000
--- a/src/node/consumer/src/lib/interfaces/torrent_file_service.ts
+++ /dev/null
@@ -1,8 +0,0 @@
-import {IParsedTorrent} from "@interfaces/parsed_torrent";
-import {ITorrentFileCollection} from "@interfaces/torrent_file_collection";
-
-export interface ITorrentFileService {
- parseTorrentFiles(torrent: IParsedTorrent): Promise;
-
- isPackTorrent(torrent: IParsedTorrent): boolean;
-}
diff --git a/src/node/consumer/src/lib/interfaces/torrent_processing_service.ts b/src/node/consumer/src/lib/interfaces/torrent_processing_service.ts
deleted file mode 100644
index 48e1a6c..0000000
--- a/src/node/consumer/src/lib/interfaces/torrent_processing_service.ts
+++ /dev/null
@@ -1,5 +0,0 @@
-import {IIngestedTorrentAttributes} from "@repository/interfaces/ingested_torrent_attributes";
-
-export interface ITorrentProcessingService {
- processTorrentRecord(torrent: IIngestedTorrentAttributes): Promise;
-}
diff --git a/src/node/consumer/src/lib/interfaces/torrent_subtitle_service.ts b/src/node/consumer/src/lib/interfaces/torrent_subtitle_service.ts
deleted file mode 100644
index 96ea2f5..0000000
--- a/src/node/consumer/src/lib/interfaces/torrent_subtitle_service.ts
+++ /dev/null
@@ -1,5 +0,0 @@
-import {ITorrentFileCollection} from "@interfaces/torrent_file_collection";
-
-export interface ITorrentSubtitleService {
- assignSubtitles(fileCollection: ITorrentFileCollection): ITorrentFileCollection;
-}
diff --git a/src/node/consumer/src/lib/interfaces/tracker_service.ts b/src/node/consumer/src/lib/interfaces/tracker_service.ts
deleted file mode 100644
index 28b82e5..0000000
--- a/src/node/consumer/src/lib/interfaces/tracker_service.ts
+++ /dev/null
@@ -1,3 +0,0 @@
-export interface ITrackerService {
- getTrackers(): Promise;
-}
diff --git a/src/node/consumer/src/lib/jobs/process_torrents_job.ts b/src/node/consumer/src/lib/jobs/process_torrents_job.ts
deleted file mode 100644
index 7a4da57..0000000
--- a/src/node/consumer/src/lib/jobs/process_torrents_job.ts
+++ /dev/null
@@ -1,63 +0,0 @@
-import {IIngestedRabbitMessage, IIngestedRabbitTorrent} from "@interfaces/ingested_rabbit_message";
-import {ILoggingService} from "@interfaces/logging_service";
-import {IProcessTorrentsJob} from "@interfaces/process_torrents_job";
-import {ITorrentProcessingService} from "@interfaces/torrent_processing_service";
-import {IIngestedTorrentAttributes} from "@repository/interfaces/ingested_torrent_attributes";
-import {configurationService} from '@services/configuration_service';
-import {IocTypes} from "@setup/ioc_types";
-import client, {Channel, Connection, ConsumeMessage, Options} from 'amqplib'
-import {inject, injectable} from "inversify";
-
-@injectable()
-export class ProcessTorrentsJob implements IProcessTorrentsJob {
- @inject(IocTypes.ITorrentProcessingService) torrentProcessingService: ITorrentProcessingService;
- @inject(IocTypes.ILoggingService) logger: ILoggingService;
-
- private readonly assertQueueOptions: Options.AssertQueue = {durable: true};
- private readonly consumeQueueOptions: Options.Consume = {noAck: false};
-
- async listenToQueue(): Promise {
- if (!configurationService.jobConfig.JOBS_ENABLED) {
- return;
- }
-
- try {
- const connection: Connection = await client.connect(configurationService.rabbitConfig.RABBIT_URI);
- const channel: Channel = await connection.createChannel();
- await this.assertAndConsumeQueue(channel);
- } catch (error) {
- this.logger.error('Failed to connect and setup channel', error);
- }
- }
-
- private processMessage = (msg: ConsumeMessage | null): Promise => {
- const ingestedTorrent: IIngestedTorrentAttributes = this.getMessageAsJson(msg);
- return this.torrentProcessingService.processTorrentRecord(ingestedTorrent);
- };
-
- private getMessageAsJson = (msg: ConsumeMessage | null): IIngestedTorrentAttributes => {
- const content = msg?.content.toString('utf8') ?? "{}";
- const receivedObject: IIngestedRabbitMessage = JSON.parse(content);
- const receivedTorrent: IIngestedRabbitTorrent = receivedObject.message;
- return {...receivedTorrent, info_hash: receivedTorrent.infoHash};
- };
-
- private assertAndConsumeQueue = async (channel: Channel): Promise => {
- this.logger.info('Worker is running! Waiting for new torrents...');
-
- const ackMsg = async (msg: ConsumeMessage | null): Promise => {
- await this.processMessage(msg)
- .then(() => this.logger.info('Processed torrent'))
- .then(() => msg && channel.ack(msg))
- .catch((error) => this.logger.error('Failed to process torrent', error));
- }
-
- try {
- await channel.assertQueue(configurationService.rabbitConfig.QUEUE_NAME, this.assertQueueOptions);
- await channel.prefetch(configurationService.jobConfig.JOB_CONCURRENCY);
- await channel.consume(configurationService.rabbitConfig.QUEUE_NAME, ackMsg, this.consumeQueueOptions);
- } catch (error) {
- this.logger.error('Failed to setup channel', error);
- }
- };
-}
diff --git a/src/node/consumer/src/lib/models/configuration/cache_config.ts b/src/node/consumer/src/lib/models/configuration/cache_config.ts
deleted file mode 100644
index 6461492..0000000
--- a/src/node/consumer/src/lib/models/configuration/cache_config.ts
+++ /dev/null
@@ -1,15 +0,0 @@
-import {BooleanHelpers} from "@helpers/boolean_helpers";
-
-export const cacheConfig = {
- MONGODB_HOST: process.env.MONGODB_HOST || 'mongodb',
- MONGODB_PORT: process.env.MONGODB_PORT || '27017',
- MONGODB_DB: process.env.MONGODB_DB || 'knightcrawler',
- MONGODB_USER: process.env.MONGODB_USER || 'mongo',
- MONGODB_PASSWORD: process.env.MONGODB_PASSWORD || 'mongo',
- NO_CACHE: BooleanHelpers.parseBool(process.env.NO_CACHE, false),
- COLLECTION_NAME: process.env.MONGODB_COLLECTION || 'knightcrawler_consumer_collection',
-
- get MONGO_URI(): string {
- return `mongodb://${this.MONGODB_USER}:${this.MONGODB_PASSWORD}@${this.MONGODB_HOST}:${this.MONGODB_PORT}/${this.MONGODB_DB}?authSource=admin`;
- }
-};
diff --git a/src/node/consumer/src/lib/models/configuration/database_config.ts b/src/node/consumer/src/lib/models/configuration/database_config.ts
deleted file mode 100644
index be199be..0000000
--- a/src/node/consumer/src/lib/models/configuration/database_config.ts
+++ /dev/null
@@ -1,14 +0,0 @@
-import {BooleanHelpers} from "@helpers/boolean_helpers";
-
-export const databaseConfig = {
- POSTGRES_HOST: process.env.POSTGRES_HOST || 'postgres',
- POSTGRES_PORT: parseInt(process.env.POSTGRES_PORT || '5432'),
- POSTGRES_DB: process.env.POSTGRES_DB || 'knightcrawler',
- POSTGRES_USER: process.env.POSTGRES_USER || 'postgres',
- POSTGRES_PASSWORD: process.env.POSTGRES_PASSWORD || 'postgres',
- AUTO_CREATE_AND_APPLY_MIGRATIONS: BooleanHelpers.parseBool(process.env.AUTO_CREATE_AND_APPLY_MIGRATIONS, false),
-
- get POSTGRES_URI(): string {
- return `postgres://${this.POSTGRES_USER}:${this.POSTGRES_PASSWORD}@${this.POSTGRES_HOST}:${this.POSTGRES_PORT}/${this.POSTGRES_DB}`;
- }
-};
diff --git a/src/node/consumer/src/lib/models/configuration/job_config.ts b/src/node/consumer/src/lib/models/configuration/job_config.ts
deleted file mode 100644
index 54fe5fa..0000000
--- a/src/node/consumer/src/lib/models/configuration/job_config.ts
+++ /dev/null
@@ -1,6 +0,0 @@
-import {BooleanHelpers} from "@helpers/boolean_helpers";
-
-export const jobConfig = {
- JOB_CONCURRENCY: parseInt(process.env.JOB_CONCURRENCY || "1", 10),
- JOBS_ENABLED: BooleanHelpers.parseBool(process.env.JOBS_ENABLED, true)
-};
diff --git a/src/node/consumer/src/lib/models/configuration/metadata_config.ts b/src/node/consumer/src/lib/models/configuration/metadata_config.ts
deleted file mode 100644
index 5b578d9..0000000
--- a/src/node/consumer/src/lib/models/configuration/metadata_config.ts
+++ /dev/null
@@ -1,5 +0,0 @@
-export const metadataConfig = {
- IMDB_CONCURRENT: parseInt(process.env.IMDB_CONCURRENT || "1", 10),
- IMDB_INTERVAL_MS: parseInt(process.env.IMDB_INTERVAL_MS || "1000", 10),
- TITLE_MATCH_THRESHOLD: Number(process.env.TITLE_MATCH_THRESHOLD || 0.25),
-};
diff --git a/src/node/consumer/src/lib/models/configuration/rabbit_config.ts b/src/node/consumer/src/lib/models/configuration/rabbit_config.ts
deleted file mode 100644
index 236c59b..0000000
--- a/src/node/consumer/src/lib/models/configuration/rabbit_config.ts
+++ /dev/null
@@ -1,13 +0,0 @@
-import {BooleanHelpers} from "@helpers/boolean_helpers";
-
-export const rabbitConfig = {
- HOST: process.env.RABBITMQ_HOST || 'rabbitmq',
- USER: process.env.RABBITMQ_USER || 'guest',
- PASSWORD: process.env.RABBITMQ_PASSWORD || 'guest',
- QUEUE_NAME: process.env.RABBITMQ_QUEUE_NAME || 'ingested',
- DURABLE: BooleanHelpers.parseBool(process.env.RABBITMQ_DURABLE, true),
-
- get RABBIT_URI(): string {
- return `amqp://${this.USER}:${this.PASSWORD}@${this.HOST}?heartbeat=30`;
- }
-};
diff --git a/src/node/consumer/src/lib/models/configuration/torrent_config.ts b/src/node/consumer/src/lib/models/configuration/torrent_config.ts
deleted file mode 100644
index 8cbb79f..0000000
--- a/src/node/consumer/src/lib/models/configuration/torrent_config.ts
+++ /dev/null
@@ -1,4 +0,0 @@
-export const torrentConfig = {
- MAX_CONNECTIONS_PER_TORRENT: parseInt(process.env.MAX_CONNECTIONS_PER_TORRENT || "20", 10),
- TIMEOUT: parseInt(process.env.TORRENT_TIMEOUT || "30000", 10)
-};
diff --git a/src/node/consumer/src/lib/models/configuration/tracker_config.ts b/src/node/consumer/src/lib/models/configuration/tracker_config.ts
deleted file mode 100644
index 79daa33..0000000
--- a/src/node/consumer/src/lib/models/configuration/tracker_config.ts
+++ /dev/null
@@ -1,7 +0,0 @@
-import {BooleanHelpers} from "@helpers/boolean_helpers";
-
-export const trackerConfig = {
- TRACKERS_URL: process.env.TRACKERS_URL || 'https://ngosang.github.io/trackerslist/trackers_all.txt',
- GITHUB_PAT: process.env.GITHUB_PAT,
- UDP_ENABLED: BooleanHelpers.parseBool(process.env.UDP_TRACKERS_ENABLED, false)
-};
diff --git a/src/node/consumer/src/lib/mongo/interfaces/imdb_entry_attributes.ts b/src/node/consumer/src/lib/mongo/interfaces/imdb_entry_attributes.ts
deleted file mode 100644
index 807a1ed..0000000
--- a/src/node/consumer/src/lib/mongo/interfaces/imdb_entry_attributes.ts
+++ /dev/null
@@ -1,13 +0,0 @@
-import {Document} from "mongoose";
-
-export interface IImdbEntry extends Document {
- _id: string;
- EndYear: string;
- Genres: string;
- IsAdult: string;
- OriginalTitle: string;
- PrimaryTitle: string;
- RuntimeMinutes: string;
- StartYear: string;
- TitleType: string;
-}
diff --git a/src/node/consumer/src/lib/mongo/interfaces/mongo_metadata_query.ts b/src/node/consumer/src/lib/mongo/interfaces/mongo_metadata_query.ts
deleted file mode 100644
index 23bff4f..0000000
--- a/src/node/consumer/src/lib/mongo/interfaces/mongo_metadata_query.ts
+++ /dev/null
@@ -1,5 +0,0 @@
-export interface IMongoMetadataQuery {
- $text: { $search: string },
- TitleType: string,
- StartYear?: string;
-}
diff --git a/src/node/consumer/src/lib/mongo/interfaces/mongo_repository.ts b/src/node/consumer/src/lib/mongo/interfaces/mongo_repository.ts
deleted file mode 100644
index 7431a85..0000000
--- a/src/node/consumer/src/lib/mongo/interfaces/mongo_repository.ts
+++ /dev/null
@@ -1,4 +0,0 @@
-export interface IMongoRepository {
- connect(): Promise;
- getImdbId(title: string, category: string, year?: string | number): Promise;
-}
diff --git a/src/node/consumer/src/lib/mongo/models/imdb_entries_model.ts b/src/node/consumer/src/lib/mongo/models/imdb_entries_model.ts
deleted file mode 100644
index 49b9a3a..0000000
--- a/src/node/consumer/src/lib/mongo/models/imdb_entries_model.ts
+++ /dev/null
@@ -1,18 +0,0 @@
-import {IImdbEntry} from "@mongo/interfaces/imdb_entry_attributes";
-import mongoose, {Schema} from "mongoose";
-
-const ImdbEntriesSchema: Schema = new Schema({
- _id: { type: String, required: true },
- EndYear: { type: String, default: "" },
- Genres: { type: String, default: "" },
- IsAdult: { type: String, default: "0" },
- OriginalTitle: { type: String, default: "" },
- PrimaryTitle: { type: String, required: true },
- RuntimeMinutes: { type: String, default: "" },
- StartYear: { type: String, required: true },
- TitleType: { type: String, default: "" },
-});
-
-ImdbEntriesSchema.index({ PrimaryTitle: 'text', TitleType: 1, StartYear: 1 }, { background: true });
-
-export const ImdbEntryModel = mongoose.model('ImdbEntry', ImdbEntriesSchema, 'imdb-entries');
diff --git a/src/node/consumer/src/lib/mongo/mongo_repository.ts b/src/node/consumer/src/lib/mongo/mongo_repository.ts
deleted file mode 100644
index 7149ce0..0000000
--- a/src/node/consumer/src/lib/mongo/mongo_repository.ts
+++ /dev/null
@@ -1,63 +0,0 @@
-import {TorrentType} from "@enums/torrent_types";
-import {ILoggingService} from "@interfaces/logging_service";
-import {IImdbEntry} from "@mongo/interfaces/imdb_entry_attributes";
-import {IMongoMetadataQuery} from "@mongo/interfaces/mongo_metadata_query";
-import {IMongoRepository} from "@mongo/interfaces/mongo_repository";
-import {ImdbEntryModel} from "@mongo/models/imdb_entries_model";
-import {configurationService} from '@services/configuration_service';
-import {IocTypes} from "@setup/ioc_types";
-import Fuse, {FuseResult, IFuseOptions} from 'fuse.js';
-import {inject, injectable} from "inversify";
-import mongoose from 'mongoose';
-
-const fuseOptions : IFuseOptions = {
- includeScore: true,
- keys: ['PrimaryTitle', 'OriginalTitle'],
- threshold: configurationService.metadataConfig.TITLE_MATCH_THRESHOLD,
-};
-
-@injectable()
-export class MongoRepository implements IMongoRepository {
- @inject(IocTypes.ILoggingService) private logger: ILoggingService;
- private db: typeof mongoose = mongoose;
-
- async connect() : Promise {
- try {
- await this.db.connect(configurationService.cacheConfig.MONGO_URI, {directConnection: true});
- this.logger.info('Successfully connected to mongo db');
- }
- catch (error) {
- const FAILED_TO_CONNECT = 'Failed to connect to mongo db';
- this.logger.debug(FAILED_TO_CONNECT, error);
- this.logger.error(FAILED_TO_CONNECT);
- process.exit(1);
- }
- }
-
- async getImdbId(title: string, category: string, year?: string | number) : Promise {
- const titleType: string = category === TorrentType.Series ? 'tvSeries' : 'movie';
- const query: IMongoMetadataQuery = {
- $text: { $search: title },
- TitleType: titleType
- };
- if (year) {
- query.StartYear = year.toString();
- }
- try {
- const results = await ImdbEntryModel.find(query).limit(100).maxTimeMS(30000);
- if (!results.length) {
- return null;
- }
- const fuse: Fuse = new Fuse(results, fuseOptions);
- const searchResults: FuseResult[] = fuse.search(title);
- if (!searchResults.length) {
- return null;
- }
- const [bestMatch] = searchResults;
- return bestMatch.item._id;
- } catch (error) {
- this.logger.error('Query exceeded the 30 seconds time limit', error);
- return null;
- }
- }
-}
diff --git a/src/node/consumer/src/lib/repository/database_repository.ts b/src/node/consumer/src/lib/repository/database_repository.ts
deleted file mode 100644
index 381f73f..0000000
--- a/src/node/consumer/src/lib/repository/database_repository.ts
+++ /dev/null
@@ -1,260 +0,0 @@
-import {PromiseHelpers} from '@helpers/promises_helpers';
-import {ILoggingService} from "@interfaces/logging_service";
-import {IContentCreationAttributes} from "@repository/interfaces/content_attributes";
-import {IDatabaseRepository} from "@repository/interfaces/database_repository";
-import {IFileAttributes, IFileCreationAttributes} from "@repository/interfaces/file_attributes";
-import {ISubtitleAttributes, ISubtitleCreationAttributes} from "@repository/interfaces/subtitle_attributes";
-import {ITorrentAttributes, ITorrentCreationAttributes} from "@repository/interfaces/torrent_attributes";
-import {Content} from "@repository/models/content";
-import {File} from "@repository/models/file";
-import {IngestedPage} from "@repository/models/ingestedPage";
-import {IngestedTorrent} from "@repository/models/ingestedTorrent";
-import {Provider} from "@repository/models/provider";
-import {SkipTorrent} from "@repository/models/skipTorrent";
-import {Subtitle} from "@repository/models/subtitle";
-import {Torrent} from "@repository/models/torrent";
-import {configurationService} from '@services/configuration_service';
-import {IocTypes} from "@setup/ioc_types";
-import {inject, injectable} from "inversify";
-import moment from 'moment';
-import {literal, Op, WhereOptions} from "sequelize";
-import {Model, Sequelize} from 'sequelize-typescript';
-
-@injectable()
-export class DatabaseRepository implements IDatabaseRepository {
- @inject(IocTypes.ILoggingService) logger: ILoggingService;
-
- private readonly database: Sequelize;
-
- private models = [
- Torrent,
- Provider,
- File,
- Subtitle,
- Content,
- SkipTorrent,
- IngestedTorrent,
- IngestedPage];
-
- constructor() {
- this.database = this.createDatabase();
- }
-
- async connect(): Promise {
- try {
- await this.database.sync({alter: configurationService.databaseConfig.AUTO_CREATE_AND_APPLY_MIGRATIONS});
- } catch (error) {
- this.logger.debug('Failed to sync database', error);
- this.logger.error('Failed syncing database');
- process.exit(1);
- }
- }
-
- async getProvider(provider: Provider): Promise {
- try {
- const [result] = await Provider.findOrCreate({where: {name: {[Op.eq]: provider.name}}, defaults: provider});
- return result;
- } catch {
- return provider as Provider;
- }
- }
-
- async getTorrent(torrent: ITorrentAttributes): Promise {
- const where = torrent.infoHash
- ? {infoHash: torrent.infoHash}
- : {provider: torrent.provider, torrentId: torrent.torrentId};
- return await Torrent.findOne({where});
- }
-
- async getTorrentsBasedOnTitle(titleQuery: string, type: string): Promise {
- return this.getTorrentsBasedOnQuery({
- title: {[Op.regexp]: `${titleQuery}`},
- type
- });
- }
-
- async getTorrentsBasedOnQuery(where: WhereOptions): Promise {
- return await Torrent.findAll({where});
- }
-
- async getFilesBasedOnQuery(where: WhereOptions): Promise {
- return await File.findAll({where});
- }
-
- async getTorrentsWithoutSize(): Promise {
- return await Torrent.findAll({
- where: literal(
- 'exists (select 1 from files where files."infoHash" = torrent."infoHash" and files.size = 300000000)'),
- order: [
- ['seeders', 'DESC']
- ]
- });
- }
-
- async getUpdateSeedersTorrents(limit = 50): Promise {
- const until = moment().subtract(7, 'days').format('YYYY-MM-DD');
- return await Torrent.findAll({
- where: literal(`torrent."updatedAt" < '${until}'`),
- limit: limit,
- order: [
- ['seeders', 'DESC'],
- ['updatedAt', 'ASC']
- ]
- });
- }
-
- async getUpdateSeedersNewTorrents(limit = 50): Promise {
- const lastUpdate = moment().subtract(12, 'hours').format('YYYY-MM-DD');
- const createdAfter = moment().subtract(4, 'days').format('YYYY-MM-DD');
- return await Torrent.findAll({
- where: literal(`torrent."updatedAt" < '${lastUpdate}' AND torrent."createdAt" > '${createdAfter}'`),
- limit: limit,
- order: [
- ['seeders', 'ASC'],
- ['updatedAt', 'ASC']
- ]
- });
- }
-
- async getNoContentsTorrents(): Promise {
- return await Torrent.findAll({
- where: {opened: false, seeders: {[Op.gte]: 1}},
- limit: 500,
- order: literal('random()')
- });
- }
-
- async createTorrent(torrent: ITorrentCreationAttributes): Promise {
- try {
- await Torrent.upsert(torrent);
- await this.createContents(torrent.infoHash, torrent.contents);
- await this.createSubtitles(torrent.infoHash, torrent.subtitles);
- } catch (error) {
- this.logger.error(`Failed to create torrent: ${torrent.infoHash}`);
- this.logger.debug("Error: ", error);
- }
- }
-
- async setTorrentSeeders(torrent: ITorrentAttributes, seeders: number): Promise<[number]> {
- const where = torrent.infoHash
- ? {infoHash: torrent.infoHash}
- : {provider: torrent.provider, torrentId: torrent.torrentId};
-
- return await Torrent.update(
- {seeders: seeders},
- {where: where}
- );
- }
-
- async deleteTorrent(infoHash: string): Promise {
- return await Torrent.destroy({where: {infoHash: infoHash}});
- }
-
- async createFile(file: IFileCreationAttributes): Promise {
- try {
- const operatingFile = File.build(file);
- if (operatingFile.id) {
- if (operatingFile.dataValues) {
- await operatingFile.save();
- } else {
- await File.upsert(file);
- }
- await this.upsertSubtitles(operatingFile, file.subtitles);
- } else {
- if (operatingFile.subtitles && operatingFile.subtitles.length) {
- operatingFile.subtitles = operatingFile.subtitles.map(subtitle => {
- subtitle.title = subtitle.path || '';
- return subtitle;
- });
- }
- await File.create(file, {include: [Subtitle], ignoreDuplicates: true});
- }
- } catch (error) {
- this.logger.error(`Failed to create file: ${file.infoHash}`);
- this.logger.debug("Error: ", error);
- }
- }
-
- async getFiles(infoHash: string): Promise {
- return File.findAll({where: {infoHash: infoHash}});
- }
-
- async getFilesBasedOnTitle(titleQuery: string): Promise {
- return File.findAll({where: {title: {[Op.regexp]: `${titleQuery}`}}});
- }
-
- async deleteFile(id: number): Promise {
- return File.destroy({where: {id: id}});
- }
-
- async createSubtitles(infoHash: string, subtitles: ISubtitleCreationAttributes[] | undefined): Promise[]> {
- if (subtitles && subtitles.length) {
- return Subtitle.bulkCreate(subtitles.map(subtitle => ({...subtitle, infoHash: infoHash, title: subtitle.path})));
- }
- return Promise.resolve();
- }
-
- async upsertSubtitles(file: File, subtitles: ISubtitleCreationAttributes[] | undefined): Promise {
- if (file.id && subtitles && subtitles.length) {
- await PromiseHelpers.sequence(subtitles
- .map(subtitle => {
- subtitle.fileId = file.id;
- subtitle.infoHash = subtitle.infoHash || file.infoHash;
- subtitle.title = subtitle.title || subtitle.path || '';
- return subtitle;
- })
- .map(subtitle => async () => {
- const operatingInstance = Subtitle.build(subtitle);
- if (operatingInstance.dataValues) {
- await operatingInstance.save();
- } else {
- await Subtitle.create(subtitle);
- }
- }));
- }
- }
-
- async getSubtitles(infoHash: string): Promise {
- return Subtitle.findAll({where: {infoHash: infoHash}});
- }
-
- async getUnassignedSubtitles(): Promise {
- return Subtitle.findAll({where: {fileId: null}});
- }
-
- async createContents(infoHash: string, contents: IContentCreationAttributes[] | undefined): Promise {
- if (contents && contents.length) {
- await Content.bulkCreate(contents.map(content => ({...content, infoHash})), {ignoreDuplicates: true});
- await Torrent.update({opened: true}, {where: {infoHash: infoHash}, silent: true});
- }
- }
-
- async getContents(infoHash: string): Promise {
- return Content.findAll({where: {infoHash: infoHash}});
- }
-
- async getSkipTorrent(infoHash: string): Promise {
- const result = await SkipTorrent.findByPk(infoHash);
- if (!result) {
- throw new Error(`torrent not found: ${infoHash}`);
- }
- return result.dataValues as SkipTorrent;
- }
-
- async createSkipTorrent(torrent: ITorrentCreationAttributes): Promise<[SkipTorrent, boolean | null]> {
- return SkipTorrent.upsert({infoHash: torrent.infoHash});
- }
-
- private createDatabase = (): Sequelize => {
- const newDatabase = new Sequelize(
- configurationService.databaseConfig.POSTGRES_URI,
- {
- logging: false
- }
- );
-
- newDatabase.addModels(this.models);
-
- return newDatabase;
- };
-}
diff --git a/src/node/consumer/src/lib/repository/interfaces/content_attributes.ts b/src/node/consumer/src/lib/repository/interfaces/content_attributes.ts
deleted file mode 100644
index 9d7eff9..0000000
--- a/src/node/consumer/src/lib/repository/interfaces/content_attributes.ts
+++ /dev/null
@@ -1,11 +0,0 @@
-import {Optional} from "sequelize";
-
-export interface IContentAttributes {
- infoHash: string;
- fileIndex: number;
- path: string;
- size: number;
-}
-
-export interface IContentCreationAttributes extends Optional {
-}
diff --git a/src/node/consumer/src/lib/repository/interfaces/database_repository.ts b/src/node/consumer/src/lib/repository/interfaces/database_repository.ts
deleted file mode 100644
index 2875c69..0000000
--- a/src/node/consumer/src/lib/repository/interfaces/database_repository.ts
+++ /dev/null
@@ -1,64 +0,0 @@
-import {IContentCreationAttributes} from "@repository/interfaces/content_attributes";
-import {IFileAttributes, IFileCreationAttributes} from "@repository/interfaces/file_attributes";
-import {ISubtitleAttributes, ISubtitleCreationAttributes} from "@repository/interfaces/subtitle_attributes";
-import {ITorrentAttributes, ITorrentCreationAttributes} from "@repository/interfaces/torrent_attributes";
-import {Content} from "@repository/models/content";
-import {File} from "@repository/models/file";
-import {Provider} from "@repository/models/provider";
-import {SkipTorrent} from "@repository/models/skipTorrent";
-import {Subtitle} from "@repository/models/subtitle";
-import {Torrent} from "@repository/models/torrent";
-import {WhereOptions} from "sequelize";
-import {Model} from "sequelize-typescript";
-
-export interface IDatabaseRepository {
- connect(): Promise;
-
- getProvider(provider: Provider): Promise;
-
- getTorrent(torrent: ITorrentAttributes): Promise;
-
- getTorrentsBasedOnTitle(titleQuery: string, type: string): Promise;
-
- getTorrentsBasedOnQuery(where: WhereOptions): Promise;
-
- getFilesBasedOnQuery(where: WhereOptions): Promise;
-
- getTorrentsWithoutSize(): Promise;
-
- getUpdateSeedersTorrents(limit: number): Promise;
-
- getUpdateSeedersNewTorrents(limit: number): Promise;
-
- getNoContentsTorrents(): Promise;
-
- createTorrent(torrent: ITorrentCreationAttributes): Promise;
-
- setTorrentSeeders(torrent: ITorrentAttributes, seeders: number): Promise<[number]>;
-
- deleteTorrent(infoHash: string): Promise;
-
- createFile(file: IFileCreationAttributes): Promise;
-
- getFiles(infoHash: string): Promise;
-
- getFilesBasedOnTitle(titleQuery: string): Promise;
-
- deleteFile(id: number): Promise;
-
- createSubtitles(infoHash: string, subtitles: ISubtitleCreationAttributes[]): Promise[]>;
-
- upsertSubtitles(file: File, subtitles: ISubtitleCreationAttributes[] | undefined): Promise;
-
- getSubtitles(infoHash: string): Promise;
-
- getUnassignedSubtitles(): Promise;
-
- createContents(infoHash: string, contents: IContentCreationAttributes[]): Promise;
-
- getContents(infoHash: string): Promise;
-
- getSkipTorrent(infoHash: string): Promise;
-
- createSkipTorrent(torrent: ITorrentCreationAttributes): Promise<[SkipTorrent, boolean | null]>;
-}
diff --git a/src/node/consumer/src/lib/repository/interfaces/file_attributes.ts b/src/node/consumer/src/lib/repository/interfaces/file_attributes.ts
deleted file mode 100644
index 7cbd7eb..0000000
--- a/src/node/consumer/src/lib/repository/interfaces/file_attributes.ts
+++ /dev/null
@@ -1,22 +0,0 @@
-import {IParseTorrentTitleResult} from "@interfaces/parse_torrent_title_result";
-import {ISubtitleAttributes} from "@repository/interfaces/subtitle_attributes";
-import {Optional} from "sequelize";
-
-export interface IFileAttributes extends IParseTorrentTitleResult {
- id?: number;
- infoHash?: string;
- fileIndex?: number;
- title: string;
- size?: number;
- imdbId?: string;
- imdbSeason?: number;
- imdbEpisode?: number;
- kitsuId?: number;
- kitsuEpisode?: number;
- subtitles?: ISubtitleAttributes[];
- path?: string;
- isMovie?: boolean;
-}
-
-export interface IFileCreationAttributes extends Optional {
-}
diff --git a/src/node/consumer/src/lib/repository/interfaces/ingested_page_attributes.ts b/src/node/consumer/src/lib/repository/interfaces/ingested_page_attributes.ts
deleted file mode 100644
index fe985f8..0000000
--- a/src/node/consumer/src/lib/repository/interfaces/ingested_page_attributes.ts
+++ /dev/null
@@ -1,6 +0,0 @@
-export interface IIngestedPageAttributes {
- url: string;
-}
-
-export interface IIngestedPageCreationAttributes extends IIngestedPageAttributes {
-}
diff --git a/src/node/consumer/src/lib/repository/interfaces/ingested_torrent_attributes.ts b/src/node/consumer/src/lib/repository/interfaces/ingested_torrent_attributes.ts
deleted file mode 100644
index e58c88b..0000000
--- a/src/node/consumer/src/lib/repository/interfaces/ingested_torrent_attributes.ts
+++ /dev/null
@@ -1,17 +0,0 @@
-import {Optional} from "sequelize";
-
-export interface IIngestedTorrentAttributes {
- name: string;
- source: string;
- category: string;
- info_hash: string;
- size: string;
- seeders: number;
- leechers: number;
- imdb: string;
- processed: boolean;
- createdAt?: Date;
-}
-
-export interface IIngestedTorrentCreationAttributes extends Optional {
-}
diff --git a/src/node/consumer/src/lib/repository/interfaces/provider_attributes.ts b/src/node/consumer/src/lib/repository/interfaces/provider_attributes.ts
deleted file mode 100644
index 60e1bda..0000000
--- a/src/node/consumer/src/lib/repository/interfaces/provider_attributes.ts
+++ /dev/null
@@ -1,10 +0,0 @@
-import {Optional} from "sequelize";
-
-export interface IProviderAttributes {
- name: string;
- lastScraped: Date;
- lastScrapedId: string;
-}
-
-export interface IProviderCreationAttributes extends Optional {
-}
diff --git a/src/node/consumer/src/lib/repository/interfaces/skip_torrent_attributes.ts b/src/node/consumer/src/lib/repository/interfaces/skip_torrent_attributes.ts
deleted file mode 100644
index a0add46..0000000
--- a/src/node/consumer/src/lib/repository/interfaces/skip_torrent_attributes.ts
+++ /dev/null
@@ -1,8 +0,0 @@
-import {Optional} from "sequelize";
-
-export interface ISkipTorrentAttributes {
- infoHash: string;
-}
-
-export interface ISkipTorrentCreationAttributes extends Optional {
-}
diff --git a/src/node/consumer/src/lib/repository/interfaces/subtitle_attributes.ts b/src/node/consumer/src/lib/repository/interfaces/subtitle_attributes.ts
deleted file mode 100644
index 7d31367..0000000
--- a/src/node/consumer/src/lib/repository/interfaces/subtitle_attributes.ts
+++ /dev/null
@@ -1,12 +0,0 @@
-import {Optional} from "sequelize";
-
-export interface ISubtitleAttributes {
- infoHash: string;
- fileIndex: number;
- fileId?: number | null;
- title: string;
- path: string;
-}
-
-export interface ISubtitleCreationAttributes extends Optional {
-}
diff --git a/src/node/consumer/src/lib/repository/interfaces/torrent_attributes.ts b/src/node/consumer/src/lib/repository/interfaces/torrent_attributes.ts
deleted file mode 100644
index b7b2bdf..0000000
--- a/src/node/consumer/src/lib/repository/interfaces/torrent_attributes.ts
+++ /dev/null
@@ -1,26 +0,0 @@
-import {IContentAttributes} from "@repository/interfaces/content_attributes";
-import {IFileAttributes} from "@repository/interfaces/file_attributes";
-import {ISubtitleAttributes} from "@repository/interfaces/subtitle_attributes";
-import {Optional} from "sequelize";
-
-export interface ITorrentAttributes {
- infoHash: string;
- provider?: string | null;
- torrentId?: string;
- title?: string;
- size?: number;
- type?: string;
- uploadDate?: Date;
- seeders?: number;
- trackers?: string;
- languages?: string;
- resolution?: string;
- reviewed?: boolean;
- opened?: boolean;
- contents?: IContentAttributes[];
- files?: IFileAttributes[];
- subtitles?: ISubtitleAttributes[];
-}
-
-export interface ITorrentCreationAttributes extends Optional {
-}
diff --git a/src/node/consumer/src/lib/repository/models/content.ts b/src/node/consumer/src/lib/repository/models/content.ts
deleted file mode 100644
index 2dffb6b..0000000
--- a/src/node/consumer/src/lib/repository/models/content.ts
+++ /dev/null
@@ -1,22 +0,0 @@
-import {IContentAttributes, IContentCreationAttributes} from "@repository/interfaces/content_attributes";
-import {Torrent} from "@repository/models/torrent";
-import {BelongsTo, Column, DataType, ForeignKey, Model, Table} from 'sequelize-typescript';
-
-@Table({modelName: 'content', timestamps: false})
-export class Content extends Model {
- @Column({type: DataType.STRING(64), primaryKey: true, allowNull: false, onDelete: 'CASCADE'})
- @ForeignKey(() => Torrent)
- declare infoHash: string;
-
- @Column({type: DataType.INTEGER, primaryKey: true, allowNull: false})
- declare fileIndex: number;
-
- @Column({type: DataType.STRING(512), allowNull: false})
- declare path: string;
-
- @Column({type: DataType.BIGINT})
- declare size: number;
-
- @BelongsTo(() => Torrent, {constraints: false, foreignKey: 'infoHash'})
- torrent?: Torrent;
-}
diff --git a/src/node/consumer/src/lib/repository/models/file.ts b/src/node/consumer/src/lib/repository/models/file.ts
deleted file mode 100644
index a8359ef..0000000
--- a/src/node/consumer/src/lib/repository/models/file.ts
+++ /dev/null
@@ -1,59 +0,0 @@
-import {IFileAttributes, IFileCreationAttributes} from "@repository/interfaces/file_attributes";
-import {Subtitle} from "@repository/models/subtitle";
-import {Torrent} from "@repository/models/torrent";
-import {BelongsTo, Column, DataType, ForeignKey, HasMany, Model, Table} from 'sequelize-typescript';
-
-const indexes = [
- {
- unique: true,
- name: 'files_unique_file_constraint',
- fields: [
- 'infoHash',
- 'fileIndex',
- 'imdbId',
- 'imdbSeason',
- 'imdbEpisode',
- 'kitsuId',
- 'kitsuEpisode'
- ]
- },
- {unique: false, fields: ['imdbId', 'imdbSeason', 'imdbEpisode']},
- {unique: false, fields: ['kitsuId', 'kitsuEpisode']}
-];
-
-@Table({modelName: 'file', timestamps: true, indexes: indexes})
-export class File extends Model {
- @Column({type: DataType.STRING(64), allowNull: false, onDelete: 'CASCADE'})
- @ForeignKey(() => Torrent)
- declare infoHash: string;
-
- @Column({type: DataType.INTEGER})
- declare fileIndex: number;
-
- @Column({type: DataType.STRING(512), allowNull: false})
- declare title: string;
-
- @Column({type: DataType.BIGINT})
- declare size: number;
-
- @Column({type: DataType.STRING(32)})
- declare imdbId: string;
-
- @Column({type: DataType.INTEGER})
- declare imdbSeason: number;
-
- @Column({type: DataType.INTEGER})
- declare imdbEpisode: number;
-
- @Column({type: DataType.INTEGER})
- declare kitsuId: number;
-
- @Column({type: DataType.INTEGER})
- declare kitsuEpisode: number;
-
- @HasMany(() => Subtitle, {constraints: false, foreignKey: 'fileId'})
- declare subtitles?: Subtitle[];
-
- @BelongsTo(() => Torrent, {constraints: false, foreignKey: 'infoHash'})
- torrent?: Torrent;
-}
diff --git a/src/node/consumer/src/lib/repository/models/ingestedPage.ts b/src/node/consumer/src/lib/repository/models/ingestedPage.ts
deleted file mode 100644
index 4ae96e9..0000000
--- a/src/node/consumer/src/lib/repository/models/ingestedPage.ts
+++ /dev/null
@@ -1,16 +0,0 @@
-import {IIngestedPageAttributes, IIngestedPageCreationAttributes} from "@repository/interfaces/ingested_page_attributes";
-import {Column, DataType, Model, Table} from 'sequelize-typescript';
-
-const indexes = [
- {
- unique: true,
- name: 'ingested_page_unique_url_constraint',
- fields: ['url']
- }
-];
-
-@Table({modelName: 'ingested_page', timestamps: true, indexes: indexes})
-export class IngestedPage extends Model {
- @Column({type: DataType.STRING(512), allowNull: false})
- declare url: string;
-}
diff --git a/src/node/consumer/src/lib/repository/models/ingestedTorrent.ts b/src/node/consumer/src/lib/repository/models/ingestedTorrent.ts
deleted file mode 100644
index 8c7f0bb..0000000
--- a/src/node/consumer/src/lib/repository/models/ingestedTorrent.ts
+++ /dev/null
@@ -1,40 +0,0 @@
-import {IIngestedTorrentAttributes, IIngestedTorrentCreationAttributes} from "@repository/interfaces/ingested_torrent_attributes";
-import {Column, DataType, Model, Table} from 'sequelize-typescript';
-
-const indexes = [
- {
- unique: true,
- name: 'ingested_torrent_unique_source_info_hash_constraint',
- fields: ['source', 'info_hash']
- }
-];
-
-@Table({modelName: 'ingested_torrent', timestamps: true, indexes: indexes})
-export class IngestedTorrent extends Model {
- @Column({type: DataType.STRING(512)})
- declare name: string;
-
- @Column({type: DataType.STRING(512)})
- declare source: string;
-
- @Column({type: DataType.STRING(32)})
- declare category: string;
-
- @Column({type: DataType.STRING(64)})
- declare info_hash: string;
-
- @Column({type: DataType.STRING(32)})
- declare size: string;
-
- @Column({type: DataType.INTEGER})
- declare seeders: number;
-
- @Column({type: DataType.INTEGER})
- declare leechers: number;
-
- @Column({type: DataType.STRING(32)})
- declare imdb: string;
-
- @Column({type: DataType.BOOLEAN, defaultValue: false})
- declare processed: boolean;
-}
diff --git a/src/node/consumer/src/lib/repository/models/provider.ts b/src/node/consumer/src/lib/repository/models/provider.ts
deleted file mode 100644
index 2083e96..0000000
--- a/src/node/consumer/src/lib/repository/models/provider.ts
+++ /dev/null
@@ -1,15 +0,0 @@
-import {IProviderAttributes, IProviderCreationAttributes} from "@repository/interfaces/provider_attributes";
-import {Column, DataType, Model, Table} from 'sequelize-typescript';
-
-@Table({modelName: 'provider', timestamps: false})
-export class Provider extends Model {
-
- @Column({type: DataType.STRING(32), primaryKey: true})
- declare name: string;
-
- @Column({type: DataType.DATE})
- declare lastScraped: Date;
-
- @Column({type: DataType.STRING(128)})
- declare lastScrapedId: string;
-}
diff --git a/src/node/consumer/src/lib/repository/models/skipTorrent.ts b/src/node/consumer/src/lib/repository/models/skipTorrent.ts
deleted file mode 100644
index 9cf1878..0000000
--- a/src/node/consumer/src/lib/repository/models/skipTorrent.ts
+++ /dev/null
@@ -1,9 +0,0 @@
-import {ISkipTorrentAttributes, ISkipTorrentCreationAttributes} from "@repository/interfaces/skip_torrent_attributes";
-import {Column, DataType, Model, Table} from 'sequelize-typescript';
-
-@Table({modelName: 'skip_torrent', timestamps: false})
-export class SkipTorrent extends Model {
-
- @Column({type: DataType.STRING(64), primaryKey: true})
- declare infoHash: string;
-}
diff --git a/src/node/consumer/src/lib/repository/models/subtitle.ts b/src/node/consumer/src/lib/repository/models/subtitle.ts
deleted file mode 100644
index 9cf62b8..0000000
--- a/src/node/consumer/src/lib/repository/models/subtitle.ts
+++ /dev/null
@@ -1,38 +0,0 @@
-import {ISubtitleAttributes, ISubtitleCreationAttributes} from "@repository/interfaces/subtitle_attributes";
-import {File} from "@repository/models/file";
-import {BelongsTo, Column, DataType, ForeignKey, Model, Table} from 'sequelize-typescript';
-
-const indexes = [
- {
- unique: true,
- name: 'subtitles_unique_subtitle_constraint',
- fields: [
- 'infoHash',
- 'fileIndex',
- 'fileId'
- ]
- },
- {unique: false, fields: ['fileId']}
-];
-
-@Table({modelName: 'subtitle', timestamps: false, indexes: indexes})
-export class Subtitle extends Model