Skip to content

Latest commit

 

History

History
133 lines (97 loc) · 3.92 KB

README.md

File metadata and controls

133 lines (97 loc) · 3.92 KB

Wildberries Tariffs Service

Сервис для автоматического сбора данных о тарифах коробов Wildberries и экспорта их в Google Таблицы.

Функциональность

  • Ежечасный сбор данных о тарифах через API Wildberries
  • Сохранение данных в PostgreSQL с автоматическим обновлением существующих записей
  • Экспорт данных в несколько Google таблиц каждые 2 часа
  • Сортировка данных по коэффициенту доставки и хранения
  • Поддержка нескольких таблиц Google Sheets

Технологии

  • Node.js 20+
  • TypeScript
  • PostgreSQL
  • Knex.js для работы с БД
  • Docker и Docker Compose
  • Google Sheets API
  • Cron для планирования задач

Предварительные требования

  1. Установленные инструменты:

    • Node.js 20+
    • PostgreSQL
    • Docker и Docker Compose
  2. Доступы:

    • Токен API Wildberries
    • Проект в Google Cloud с включенным Google Sheets API
    • Service Account с доступом к Google Sheets

Установка и настройка

  1. Клонирование репозитория:
git clone https://github.com/spam5041/wb-tariffs-service
cd wb-tariffs-service   
  1. Настройте переменные окружения в .env файле (по завершении удалите .example из имени файла):
  • WB_API_KEY - токен API Wildberries
  • GOOGLE_SHEET_IDS - список ID Google таблиц через запятую
  • Другие необходимые переменные
  1. Поместите файл credentials.json от Google Cloud в корень проекта

  2. Запуск через Docker:

docker compose up --build
  1. Или локальный запуск:
npm install
npm run migrate
npm start

Структура проекта

  • /src
    • /config - конфигурация приложения
    • /db - миграции и настройки базы данных
    • /services - основная бизнес-логика
    • /types - TypeScript типы
    • /utils - вспомогательные функции

API и интеграции

Wildberries API

  • Endpoint: https://common-api.wildberries.ru/api/v1/tariffs/box
  • Метод: GET
  • Частота запросов: каждый час

Google Sheets

  • Данные экспортируются на лист stocks_coefs
  • Частота обновления: каждые 2 часа
  • Сортировка по возрастанию коэффициента
  • Поддержка множества таблиц

База данных

Таблица warehouse_tariffs:

  • date (date) - дата получения тарифа
  • warehouse_name (string) - название склада
  • delivery_storage_cost (decimal) - коэффициент доставки и хранения
  • delivery_base (decimal) - базовая стоимость доставки
  • delivery_liter (decimal) - стоимость доставки за литр
  • storage_base (decimal) - базовая стоимость хранения
  • storage_liter (decimal) - стоимость хранения за литр

Мониторинг

Логи сохраняются в файлы:

  • combined.log - все логи
  • error.log - только ошибки

Разработка

Запуск в режиме разработки

npm run dev

Запуск тестов

npm test

Создание новой миграции

npm run migrate:make <migration-name>

Применение миграций

npm run migrate

Откат миграций

npm run migrate:rollback