- Удален Basic Auth, заменен на современную JWT авторизацию - Добавлена страница входа с красивым интерфейсом - Обновлен фронтенд для работы с JWT токенами - Добавлены новые зависимости: PyJWT, passlib[bcrypt], jinja2 - Создан тестовый скрипт для проверки авторизации - Добавлено руководство по миграции - Обновлена документация и README - Улучшен дизайн поля ввода пароля на странице входа Автор: Сергей Антропов Сайт: https://devops.org.ru
125 lines
5.8 KiB
Makefile
125 lines
5.8 KiB
Makefile
# Makefile для LogBoard+
|
||
# Автор: Сергей Антропов
|
||
# Сайт: https://devops.org.ru
|
||
|
||
.PHONY: help setup build up down restart logs clean status ps shell generate test-auth
|
||
|
||
# Переменные
|
||
COMPOSE_FILE = docker-compose.yml
|
||
SERVICE_NAME = logboard
|
||
|
||
# Цвета для вывода
|
||
GREEN = \033[0;32m
|
||
YELLOW = \033[1;33m
|
||
RED = \033[0;31m
|
||
NC = \033[0m # No Color
|
||
|
||
help: ## Показать справку по командам
|
||
@echo "$(GREEN)LogBoard+ - Команды управления$(NC)"
|
||
@echo ""
|
||
@echo "$(YELLOW)Основные команды:$(NC)"
|
||
@grep -E '^[a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?## "}; {printf " $(GREEN)%-15s$(NC) %s\n", $$1, $$2}'
|
||
@echo ""
|
||
@echo "$(YELLOW)Примеры использования:$(NC)"
|
||
@echo " make setup # Настроить переменные окружения"
|
||
@echo " make build # Собрать образ"
|
||
@echo " make up # Запустить сервисы"
|
||
@echo " make down # Остановить сервисы"
|
||
@echo " make restart # Перезапустить сервисы"
|
||
@echo " make logs # Показать логи"
|
||
|
||
setup: ## Настроить переменные окружения (копировать env.example в .env)
|
||
@echo "$(GREEN)Настройка переменных окружения...$(NC)"
|
||
@if [ ! -f .env ]; then \
|
||
cp env.example .env; \
|
||
echo "$(GREEN)Файл .env создан из env.example$(NC)"; \
|
||
echo "$(YELLOW)Не забудьте отредактировать .env под свои нужды!$(NC)"; \
|
||
echo "$(YELLOW)После редактирования .env запустите make generate для обновления docker-compose.yml$(NC)"; \
|
||
else \
|
||
echo "$(YELLOW)Файл .env уже существует.$(NC)"; \
|
||
echo "$(YELLOW)Для пересоздания удалите .env и запустите make setup$(NC)"; \
|
||
fi
|
||
|
||
generate: ## Сгенерировать docker-compose.yml из .env файла
|
||
@echo "$(GREEN)Генерация docker-compose.yml из .env файла...$(NC)"
|
||
@if [ ! -f .env ]; then \
|
||
echo "$(RED)Файл .env не найден! Сначала запустите make setup$(NC)"; \
|
||
exit 1; \
|
||
fi
|
||
python3 scripts/generate-compose.py
|
||
@echo "$(GREEN)docker-compose.yml сгенерирован успешно!$(NC)"
|
||
|
||
build: ## Собрать Docker образ
|
||
@echo "$(GREEN)Сборка Docker образа...$(NC)"
|
||
docker compose -f $(COMPOSE_FILE) build --no-cache
|
||
@echo "$(GREEN)Образ собран успешно!$(NC)"
|
||
|
||
up: ## Запустить сервисы в фоновом режиме (с правами root)
|
||
@echo "$(GREEN)Запуск сервисов с правами root...$(NC)"
|
||
docker compose -f $(COMPOSE_FILE) up -d
|
||
@echo "$(GREEN)Сервисы запущены с правами root!$(NC)"
|
||
@echo "$(YELLOW)Приложение доступно по адресу: http://localhost:9001$(NC)"
|
||
|
||
down: ## Остановить и удалить сервисы (с правами root)
|
||
@echo "$(YELLOW)Остановка сервисов с правами root...$(NC)"
|
||
docker compose -f $(COMPOSE_FILE) down
|
||
@echo "$(GREEN)Сервисы с правами root остановлены!$(NC)"
|
||
|
||
restart: ## Перезапустить сервисы (с правами root)
|
||
@echo "$(YELLOW)Перезапуск сервисов с правами root...$(NC)"
|
||
docker compose -f $(COMPOSE_FILE) restart
|
||
@echo "$(GREEN)Сервисы с правами root перезапущены!$(NC)"
|
||
|
||
logs: ## Показать логи сервисов
|
||
@echo "$(GREEN)Логи сервисов:$(NC)"
|
||
docker compose -f $(COMPOSE_FILE) logs -f
|
||
|
||
logs-tail: ## Показать последние 100 строк логов
|
||
@echo "$(GREEN)Последние 100 строк логов:$(NC)"
|
||
docker compose -f $(COMPOSE_FILE) logs --tail=100
|
||
|
||
clean: ## Остановить сервисы и удалить образы
|
||
@echo "$(RED)Очистка проекта...$(NC)"
|
||
docker compose -f $(COMPOSE_FILE) down --rmi all --volumes --remove-orphans
|
||
@echo "$(GREEN)Очистка завершена!$(NC)"
|
||
|
||
status: ## Показать статус сервисов
|
||
@echo "$(GREEN)Статус сервисов:$(NC)"
|
||
docker compose -f $(COMPOSE_FILE) ps
|
||
|
||
ps: status ## Алиас для команды status
|
||
|
||
shell: ## Подключиться к контейнеру сервиса
|
||
@echo "$(GREEN)Подключение к контейнеру $(SERVICE_NAME)...$(NC)"
|
||
docker compose -f $(COMPOSE_FILE) exec $(SERVICE_NAME) /bin/bash
|
||
|
||
start: up ## Алиас для команды up
|
||
|
||
stop: down ## Алиас для команды down
|
||
|
||
dev: ## Запуск в режиме разработки (с выводом логов)
|
||
@echo "$(GREEN)Запуск в режиме разработки...$(NC)"
|
||
docker compose -f $(COMPOSE_FILE) up --build
|
||
|
||
rebuild: ## Пересобрать и запустить сервисы
|
||
@echo "$(YELLOW)Пересборка и запуск сервисов...$(NC)"
|
||
docker compose -f $(COMPOSE_FILE) down
|
||
docker compose -f $(COMPOSE_FILE) build --no-cache
|
||
docker compose -f $(COMPOSE_FILE) up -d
|
||
@echo "$(GREEN)Сервисы пересобраны и запущены!$(NC)"
|
||
@echo "$(YELLOW)Приложение доступно по адресу: http://localhost:9001$(NC)"
|
||
|
||
test-auth: ## Тестирование новой системы авторизации
|
||
@echo "$(GREEN)Тестирование системы авторизации...$(NC)"
|
||
@if [ ! -f test_auth.py ]; then \
|
||
echo "$(RED)Файл test_auth.py не найден!$(NC)"; \
|
||
exit 1; \
|
||
fi
|
||
@echo "$(YELLOW)Убедитесь, что сервис запущен: make up$(NC)"
|
||
@echo "$(YELLOW)Ожидание запуска сервиса...$(NC)"
|
||
@sleep 5
|
||
python3 test_auth.py
|
||
@echo "$(GREEN)Тестирование завершено!$(NC)"
|
||
|
||
|