Nvidia Stock Bot

JV Hardware License: CC BY-NC 4.0
Nvidia Stock Bot
**đŸ€– Nvidia Stock Bot** - Un robot qui permet d'ĂȘtre alertĂ© en temps rĂ©el des stocks de cartes graphiques **Nvidia RTX FE** grĂące Ă  des notifications Discord. > [!NOTE] > *Le code a Ă©tĂ© partiellement Ă©crit et structurĂ© Ă  l'aide d'une intelligence artificielle gĂ©nĂ©rative.* > > *Le dĂ©pĂŽt GitHub est un miroir de https://git.djeex.fr/Djeex/nvidia-stock-bot. Vous y trouverez le paquet complet, l'historique et les notes de version.* > > **Nvidia Stock Bot** – Un bot qui vous alerte en temps rĂ©el sur la disponibilitĂ© en stock des GPU Nvidia RTX FE via des notifications Discord. ## 📌 Sommaire - [✹ FonctionnalitĂ©s](#fonctionnalit%C3%A9s) - [🐳 Installation docker sans le dĂ©pot (rapide)](#installation-sans-le-d%C3%A9pot-avec-docker-compose) - [🐙 Installation docker avec le dĂ©pot (dĂ©veloppeur)](#installation-avec-le-d%C3%A9pot) - [🐍 Installation avec Python (dĂ©veloppeur)](#installation-avec-python) - [đŸ–Œïž Captures d'Ă©cran](#captures-d%C3%A9cran) - [đŸ§‘â€đŸ’» Contributeurs](#contributeurs) ## ✹ FonctionnalitĂ©s - Notification Discord `@everyone` en cas de changement du SKU (potentiel drop imminent) - Notification Discord `@everyone` en cas de stock dĂ©tectĂ© avec modĂšle, prix, et lien - Notification Discord silencieuse en cas d'absence de stock dĂ©tĂ©ctĂ© - Choix de la frĂ©quence de la vĂ©rification - Choix du modĂšle Ă  surveiller ## 🐳 Installation sans le dĂ©pot avec docker compose Vous trouverez-ci dessous les instructions pour configurer le conteneur avec notre image prĂ©-compilĂ©e. Avec cette solution, votre bot tournera tout seul tant que le conteneur est actif. **PrĂ©-requis** - [Docker](https://docs.docker.com/engine/install/) **Configuration** - CrĂ©ez un dossier `nvidia-stock-bot` - CrĂ©ez le fichier `compose.yaml` dans ce dossier avec la configuration ci-dessous : ```yaml services: nvidia-stock-bot: image: git.djeex.fr/djeex/nvidia-stock-bot:latest-french container_name: nvidia-stock-bot restart: unless-stopped environment: - DISCORD_WEBHOOK_URL= # URL de votre webhook Discord - PRODUCT_NAME= # Le nom exact du GPU que vous recherchez comme "RTX 5080" - PYTHONUNBUFFERED=1 # Permet d'afficher les logs en temps rĂ©el command: python nvidia-stock-bot.py ``` **Variables d'environnements :** | Variables | Explications | Valeurs possibles | Valeur par dĂ©faut | |---------------------|-------------------------------------------------|--------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------| | DISCORD_WEBHOOK_URL | URL de votre webhook Discord | Une URL | | | REFRESH_TIME | DurĂ©e de rafraichissement du script en secondes | `60`, `30`, etc... | `30` | | API_URL_SKU | API listant le produit | Une URL | `https://api.nvidia.partners/edge/product/search?page=1&limit=100&locale=fr-fr&Manufacturer=Nvidia` | | API_URL_STOCK | API donnant le stock | Une URL | `https://api.store.nvidia.com/partner/v1/feinventory?locale=fr-fr&skus=` | | PRODUCT_URL | URL d'achat du GPU | Une URL | `https://marketplace.nvidia.com/fr-fr/consumer/graphics-cards/?locale=fr-fr&page=1&limit=12&manufacturer=NVIDIA` | | PRODUCT_NAME | Le nom exact du GPU que vous recherchez | `RTX 5090`, `RTX 5080` ou `RTX 5070`. | | | TEST_MODE | Pour tester sans envoyer de notifs | `True`, `False` | `False` | | PYTHONUNBUFFERED | #Permet d'afficher les logs en temps rĂ©el | `1`, `0` | `1` | **Lancer l'image** Rendez-vous dans le dossier `nvidia-stock-bot` et lancez le conteneur : ```sh docker compose up -d ``` **Voir les logs pour vĂ©rifier le bon fonctionnement** ```sh docker logs -f nvidia-stock-bot ``` ## 📩 Installation avec le dĂ©pot Vous trouverez-ci dessous les instructions pour installer le dĂ©pot, compiler l'image docker, et lancer le conteneur. Avec cette solution, votre bot tournera tout seul tant que le conteneur est actif. **PrĂ©-requis** - [Git](https://git-scm.com/docs) - [Docker](https://docs.docker.com/engine/install/) **Cloner et paramĂ©trer** - Clonez le repo : ```sh git clone https://git.djeex.fr/Djeex/nvidia-stock-bot.git ``` - Rendez vous dans le dossier `nvidia-stock-bot` et compilez l'image docker : ```sh docker build -t nvidia-stock-bot . ``` - Puis rendez-vous dans le dossier `nvidia-stock-bot/docker` et Ă©ditez le fichier `.env` avec : - l'url de votre webhook discord - les diffĂ©rents liens API et produits - la frĂ©quence de consultation des stock (par dĂ©faut 60s, attention Ă  ne pas trop descendre sous peine de blocage de votre adresse IP par nVidia) **Lancer l'image** Rendez-vous dans le dossier `nvidia-stock-bot/docker` et lancez le conteneur : ```sh docker compose up -d ``` **Voir les logs pour vĂ©rifier le bon fonctionnement** ```sh docker logs -f nvidia-stock-bot ``` ## 🐍 Installation avec Python Vous trouverez ci-dessous comment exĂ©cuter directement le script Python. Avec cette solution, le bot s'arretera si vous fermez votre terminal. **PrĂ©-requis** - Python 3.11 ou plus - requests : `pip install requests` **Configuration** - CrĂ©ez un environnement virtuel (exemple : `python3 -m venv nom_de_l_environnement` ) - CrĂ©ez un dossier et aller dedans - TĂ©lĂ©chargez le script python : ```sh curl -o nvidia-stock-bot.py -# https://git.djeex.fr/Djeex/nvidia-stock-bot/raw/branch/main/nvidia-stock-bot.py ``` - Exportez les variables d'environnement avec votre webhook discord et le temps de rafraichissement en secondes, par exemple : ```sh export DISCORD_WEBHOOK_URL="https://votre_url_discord" export REFRESH_TIME="60" export API_URL_SKU="https://api.nvidia.partners/edge/product/search?page=1&limit=100&locale=fr-fr&Manufacturer=Nvidia&gpu=RTX%205080" export API_URL_STOCK="https://api.store.nvidia.com/partner/v1/feinventory?locale=fr-fr&skus=" export PRODUCT_URL= "https://marketplace.nvidia.com/fr-fr/consumer/graphics-cards/?locale=fr-fr&page=1&limit=12&gpu=RTX%205080&manufacturer=NVIDIA" export PRODUCT_NAME="RTX 5080" export TEST_MODE=false ``` - Lancez le script ```sh python nvidia-stock-bot.py ``` ## đŸ–Œïž Captures d'Ă©cran
Nvidia Stock Bot - captures
## đŸ§‘â€đŸ’» Contributeurs On remercie pour leurs contributions : - Djeex - KevOut - Extreme2pac