Update README.md

This commit is contained in:
themaster1970sf 2025-05-19 20:04:23 +03:00 committed by GitHub
parent e4d9adf7c9
commit d3e2bf4b45
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

154
README.md
View file

@ -1,101 +1,173 @@
# Auto Build GitHub Release Automation # ![AutoBuildRepo](https://img.shields.io/badge/Auto%20Build-GitHub%20Release-blue?style=for-the-badge&logo=github)
## 📦 Описание проекта ![Python](https://img.shields.io/badge/-Python-3776AB?logo=python&logoColor=white)
![GitHub](https://img.shields.io/badge/-GitHub-181717?logo=github)
![Windows](https://img.shields.io/badge/-Windows-0078D6?logo=windows&logoColor=white)
![Linux](https://img.shields.io/badge/-Linux-FCC624?logo=linux&logoColor=black)
![Usage](https://img.shields.io/badge/Usage-Automated%20Releases-yellow)
![License](https://img.shields.io/badge/License-MIT-green)
Скрипт автоматизирует создание релизов в GitHub с ежедневной архивацией содержимого репозитория. ## Содержание
## 🚀 Функциональность * [Описание](#описание)
* [Функции](#функции)
* [Требования](#требования)
* [Установка](#установка)
* [Конфигурация](#конфигурация)
* [Настройки расписания](#настройки-расписания)
* [Запуск](#запуск)
* [Важные примечания](#важные-примечания)
* [Лицензия](#лицензия)
- Автоматическое создание архива репозитория ## Описание
- Генерация релиза в GitHub
- Загрузка архива как asset релиза
- Поддержка Windows и Linux
- Настраиваемое расписание
## 🛠 Требования Мощный Python-скрипт, автоматизирующий создание релизов на GitHub путем генерации ежедневных архивов содержимого вашего репозитория. Идеально подходит для проектов, требующих регулярных сборок или резервных копий.
- Python 3.8+ ## Функции
- Git
- Личный токен GitHub
## 📋 Установка * 🔄 **Автоматическое архивирование репозитория** - Создает сжатые архивы вашего репозитория
* 🚀 **Генерация релизов на GitHub** - Автоматически создает релизы на GitHub
* 📦 **Загрузка ресурсов** - Прикрепляет архивные файлы к каждому релизу
* 💻 **Кроссплатформенность** - Работает как на Windows, так и на Linux
* ⏱️ **Настраиваемое расписание** - Настройте собственное время выпуска релизов
* 🔒 **Безопасная аутентификация** - Использует персональные токены доступа GitHub для безопасного доступа к API
## Требования
* Python 3.8 или выше
* Установленный и настроенный Git
* Персональный токен доступа GitHub с соответствующими разрешениями
* Интернет-соединение для доступа к API GitHub
## Установка
<details>
<summary>
### Windows ### Windows
</summary>
1. **Клонировать репозиторий**
1. Клонировать репозиторий:
```bash ```bash
git clone https://github.com/themaster1970sf/AutoBuildRepo.git git clone https://github.com/themaster1970sf/AutoBuildRepo.git
cd auto-build-script cd AutoBuildRepo
``` ```
2. Установить зависимости: 2. **Установить зависимости**
```powershell ```powershell
pip install -r requirements.txt pip install -r requirements.txt
``` ```
3. Запуск: 3. **Запустить скрипт**
```powershell ```powershell
python app.py python app.py
``` ```
</details>
<details>
<summary>
### Linux ### Linux
</summary>
1. **Клонировать репозиторий**
1. Клонировать репозиторий:
```bash ```bash
git clone https://github.com/themaster1970sf/AutoBuildRepo.git git clone https://github.com/themaster1970sf/AutoBuildRepo.git
cd auto-build-script cd AutoBuildRepo
``` ```
2. Создать виртуальное окружение: 2. **Создать и активировать виртуальное окружение**
```bash ```bash
python3 -m venv venv python3 -m venv venv
source venv/bin/activate source venv/bin/activate
``` ```
3. Установить зависимости: 3. **Установить зависимости**
```bash ```bash
pip install -r requirements.txt pip install -r requirements.txt
``` ```
4. Запуск: 4. **Запустить скрипт**
```powershell
```bash
python3 app.py python3 app.py
``` ```
</details>
## 🔧 Настройка ## Конфигурация
1. **Получить персональный токен доступа GitHub**
Создайте токен со следующими разрешениями:
- `repo` (Полный контроль над приватными репозиториями)
- `workflow` (Обновление рабочих процессов GitHub Action)
2. **Настроить скрипт**
Отредактируйте функцию `daily_release()` в файле `app.py`:
1. Получить Personal Access Token в GitHub
2. Отредактировать `daily_release()`:
```python ```python
repo = { repo = {
"path": r"/path/to/build", "path": r"/путь/к/сборке",
"git_config": { "git_config": {
"username": "your_github_username", "username": "ваше_имя_пользователя_github",
"repo": "your_repository", "repo": "ваш_репозиторий",
"token": "your_github_token" "token": "ваш_токен_github"
} }
} }
``` ```
## 🕒 Расписание ## Настройки расписания
По умолчанию скрипт запускается ежедневно в 11:23. Чтобы изменить расписание, измените функцию `main()`:
По умолчанию скрипт запускается ежедневно в 11:23. Изменить время в функции `main()`:
```python ```python
schedule.every().day.at("HOUR:MINUTE").do(daily_release) schedule.every().day.at("ЧАС:МИНУТА").do(daily_release)
``` ```
## 🐍 Запуск Доступные варианты расписания:
- `schedule.every().day.at("ЧЧ:ММ")` - Запуск ежедневно в указанное время
- `schedule.every().hour` - Запуск каждый час
- `schedule.every().monday` - Запуск каждый понедельник
- `schedule.every(10).minutes` - Запуск каждые 10 минут
## Запуск
Чтобы запустить автоматический процесс выпуска релизов:
```bash ```bash
python app.py python app.py
``` ```
## ⚠️ Важно Скрипт продолжит работать в фоновом режиме в соответствии с установленным расписанием.
- Храните токен в секрете ## Важные примечания
- Проверьте права доступа к репозиторию
- Убедитесь в корректности путей
## 📄 Лицензия ⚠️ **Соображения безопасности**
[MIT License](https://github.com/themaster1970sf/AutoBuildRepo/blob/main/LICENSE) - Никогда не фиксируйте токен GitHub непосредственно в коде
- Рассмотрите возможность использования переменных окружения для хранения конфиденциальной информации
- Убедитесь, что ваш репозиторий имеет достаточно места для хранения регулярных архивов
- Проверьте, есть ли у вас необходимые разрешения для целевого репозитория
⚠️ **Соображения производительности**
- Для больших репозиториев архивирование может занять значительное время
- Следите за ограничениями скорости API GitHub
- Учитывайте использование пропускной способности сети для больших загрузок
## Лицензия
[Лицензия MIT](https://github.com/themaster1970sf/AutoBuildRepo/blob/main/LICENSE)
---
<p align="center">
Сделано с ❤️ от <a href="https://github.com/themaster1970sf">themaster1970sf</a>
</p>