Обновления в docker: entrypoint.sh и инструкции по развертыванию

This commit is contained in:
2026-01-08 22:16:39 +03:00
parent f94af70f7f
commit 4f57d594c9
2 changed files with 45 additions and 50 deletions

View File

@@ -102,10 +102,10 @@ REDIS_DB=0
# Celery # Celery
CELERY_BROKER_URL=redis://redis:6379/0 CELERY_BROKER_URL=redis://redis:6379/0
# Tenant Admin (создаётся при первом запуске) # Platform Admin (администратор платформы - создаётся автоматически)
TENANT_ADMIN_EMAIL=admin@example.com PLATFORM_ADMIN_EMAIL=admin@mix.smaa.by
TENANT_ADMIN_PASSWORD=ваш-админ-пароль PLATFORM_ADMIN_PASSWORD=ваш-надёжный-пароль-минимум-16-символов
TENANT_ADMIN_NAME=Admin PLATFORM_ADMIN_NAME=Platform Admin
# Django-tenants # Django-tenants
PUBLIC_SCHEMA_DOMAIN=mix.smaa.by PUBLIC_SCHEMA_DOMAIN=mix.smaa.by
@@ -171,8 +171,9 @@ docker-compose logs -f
При первом запуске автоматически: При первом запуске автоматически:
1. Создаётся база данных PostgreSQL 1. Создаётся база данных PostgreSQL
2. Применяются миграции Django 2. Применяются миграции Django
3. Создаётся суперпользователь: `slamfromm@gmail.com` / `GKh^768&T9` 3. Собираются статические файлы
4. Собираются статические файлы 4. Создаётся public tenant
5. **Создаётся PlatformAdmin** из переменных `PLATFORM_ADMIN_*` в `.env.docker`
### Проверка работоспособности: ### Проверка работоспособности:
```bash ```bash
@@ -258,34 +259,27 @@ server {
## Создание тенантов (магазинов) ## Создание тенантов (магазинов)
После запуска системы, войдите в админку `https://mix.smaa.by/admin/` и создайте: **Рекомендуемый способ:** Через форму регистрации и активацию в админке.
1. **Client (Тенант)** - новый магазин 1. Пользователь заполняет форму на `https://mix.smaa.by/register/`
2. **Domain** - привяжите домен, например `shop1.mix.smaa.by` 2. PlatformAdmin входит в `https://mix.smaa.by/admin/`
3. В разделе "Заявки на регистрацию" нажимает "Активировать"
### Через Django shell: При активации автоматически:
```bash - Создаётся тенант и домен
docker-compose exec web python manage.py shell - Применяются миграции
``` - Создаётся владелец (CustomUser)
- Инициализируются данные (склад, статусы и т.д.)
- Отправляется email с ссылкой для установки пароля
```python ### Архитектура пользователей
from tenants.models import Client, Domain
# Создаём тенант | Модель | Schema | Доступ |
tenant = Client( |--------|--------|--------|
schema_name='shop1', | `PlatformAdmin` | public | Django Admin везде |
name='Магазин 1', | `CustomUser` | tenant | Только фронтенд |
)
tenant.save()
# Привязываем домен PlatformAdmin может войти в Django Admin любого тенанта для техподдержки.
domain = Domain(
domain='shop1.mix.smaa.by',
tenant=tenant,
is_primary=True
)
domain.save()
```
## Полезные команды ## Полезные команды

View File

@@ -148,32 +148,33 @@ run_migrations() {
python /app/docker/create_public_tenant.py python /app/docker/create_public_tenant.py
} }
# Создание суперпользователя если не существует # Создание PlatformAdmin если не существует
create_superuser() { create_platform_admin() {
echo "Creating superuser if not exists..." echo "Creating PlatformAdmin if not exists..."
python manage.py shell << EOF python manage.py shell << EOF
from django.contrib.auth import get_user_model from platform_admin.models import PlatformAdmin
from django.db import connection
from django_tenants.utils import schema_context
import os import os
User = get_user_model() # Создаём PlatformAdmin из переменных окружения
email = os.environ.get('PLATFORM_ADMIN_EMAIL', 'admin@platform.com')
password = os.environ.get('PLATFORM_ADMIN_PASSWORD')
name = os.environ.get('PLATFORM_ADMIN_NAME', 'Platform Admin')
# Создаём суперпользователя в public схеме из переменных окружения if not password:
with schema_context('public'): print('WARNING: PLATFORM_ADMIN_PASSWORD not set. Skipping PlatformAdmin creation.')
email = os.environ.get('TENANT_ADMIN_EMAIL', 'admin@example.com') print('Create PlatformAdmin manually via Django shell:')
password = os.environ.get('TENANT_ADMIN_PASSWORD', 'changeme') print(' from platform_admin.models import PlatformAdmin')
first_name = os.environ.get('TENANT_ADMIN_NAME', 'Admin') print(' PlatformAdmin.objects.create_superuser(email="...", name="...", password="...")')
if not User.objects.filter(email=email).exists():
user = User.objects.create_superuser(
email=email,
password=password,
name=first_name
)
print(f'Superuser {email} created successfully!')
else: else:
print(f'Superuser {email} already exists.') if not PlatformAdmin.objects.filter(email=email).exists():
admin = PlatformAdmin.objects.create_superuser(
email=email,
name=name,
password=password
)
print(f'PlatformAdmin {email} created successfully!')
else:
print(f'PlatformAdmin {email} already exists.')
EOF EOF
} }
@@ -199,7 +200,7 @@ case "$1" in
wait_for_redis wait_for_redis
setup_directories setup_directories
run_migrations run_migrations
create_superuser create_platform_admin
echo "Starting Gunicorn..." echo "Starting Gunicorn..."
exec gunicorn myproject.wsgi:application \ exec gunicorn myproject.wsgi:application \
--bind 0.0.0.0:8000 \ --bind 0.0.0.0:8000 \
@@ -228,7 +229,7 @@ case "$1" in
migrate) migrate)
wait_for_postgres wait_for_postgres
run_migrations run_migrations
create_superuser create_platform_admin
;; ;;
collectstatic) collectstatic)
wait_for_postgres wait_for_postgres