Обновления в docker: entrypoint.sh и инструкции по развертыванию
This commit is contained in:
@@ -102,10 +102,10 @@ REDIS_DB=0
|
||||
# Celery
|
||||
CELERY_BROKER_URL=redis://redis:6379/0
|
||||
|
||||
# Tenant Admin (создаётся при первом запуске)
|
||||
TENANT_ADMIN_EMAIL=admin@example.com
|
||||
TENANT_ADMIN_PASSWORD=ваш-админ-пароль
|
||||
TENANT_ADMIN_NAME=Admin
|
||||
# Platform Admin (администратор платформы - создаётся автоматически)
|
||||
PLATFORM_ADMIN_EMAIL=admin@mix.smaa.by
|
||||
PLATFORM_ADMIN_PASSWORD=ваш-надёжный-пароль-минимум-16-символов
|
||||
PLATFORM_ADMIN_NAME=Platform Admin
|
||||
|
||||
# Django-tenants
|
||||
PUBLIC_SCHEMA_DOMAIN=mix.smaa.by
|
||||
@@ -171,8 +171,9 @@ docker-compose logs -f
|
||||
При первом запуске автоматически:
|
||||
1. Создаётся база данных PostgreSQL
|
||||
2. Применяются миграции Django
|
||||
3. Создаётся суперпользователь: `slamfromm@gmail.com` / `GKh^768&T9`
|
||||
4. Собираются статические файлы
|
||||
3. Собираются статические файлы
|
||||
4. Создаётся public tenant
|
||||
5. **Создаётся PlatformAdmin** из переменных `PLATFORM_ADMIN_*` в `.env.docker`
|
||||
|
||||
### Проверка работоспособности:
|
||||
```bash
|
||||
@@ -258,34 +259,27 @@ server {
|
||||
|
||||
## Создание тенантов (магазинов)
|
||||
|
||||
После запуска системы, войдите в админку `https://mix.smaa.by/admin/` и создайте:
|
||||
**Рекомендуемый способ:** Через форму регистрации и активацию в админке.
|
||||
|
||||
1. **Client (Тенант)** - новый магазин
|
||||
2. **Domain** - привяжите домен, например `shop1.mix.smaa.by`
|
||||
1. Пользователь заполняет форму на `https://mix.smaa.by/register/`
|
||||
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
|
||||
### Архитектура пользователей
|
||||
|
||||
# Создаём тенант
|
||||
tenant = Client(
|
||||
schema_name='shop1',
|
||||
name='Магазин 1',
|
||||
)
|
||||
tenant.save()
|
||||
| Модель | Schema | Доступ |
|
||||
|--------|--------|--------|
|
||||
| `PlatformAdmin` | public | Django Admin везде |
|
||||
| `CustomUser` | tenant | Только фронтенд |
|
||||
|
||||
# Привязываем домен
|
||||
domain = Domain(
|
||||
domain='shop1.mix.smaa.by',
|
||||
tenant=tenant,
|
||||
is_primary=True
|
||||
)
|
||||
domain.save()
|
||||
```
|
||||
PlatformAdmin может войти в Django Admin любого тенанта для техподдержки.
|
||||
|
||||
## Полезные команды
|
||||
|
||||
|
||||
@@ -148,32 +148,33 @@ run_migrations() {
|
||||
python /app/docker/create_public_tenant.py
|
||||
}
|
||||
|
||||
# Создание суперпользователя если не существует
|
||||
create_superuser() {
|
||||
echo "Creating superuser if not exists..."
|
||||
# Создание PlatformAdmin если не существует
|
||||
create_platform_admin() {
|
||||
echo "Creating PlatformAdmin if not exists..."
|
||||
python manage.py shell << EOF
|
||||
from django.contrib.auth import get_user_model
|
||||
from django.db import connection
|
||||
from django_tenants.utils import schema_context
|
||||
from platform_admin.models import PlatformAdmin
|
||||
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 схеме из переменных окружения
|
||||
with schema_context('public'):
|
||||
email = os.environ.get('TENANT_ADMIN_EMAIL', 'admin@example.com')
|
||||
password = os.environ.get('TENANT_ADMIN_PASSWORD', 'changeme')
|
||||
first_name = os.environ.get('TENANT_ADMIN_NAME', 'Admin')
|
||||
|
||||
if not User.objects.filter(email=email).exists():
|
||||
user = User.objects.create_superuser(
|
||||
if not password:
|
||||
print('WARNING: PLATFORM_ADMIN_PASSWORD not set. Skipping PlatformAdmin creation.')
|
||||
print('Create PlatformAdmin manually via Django shell:')
|
||||
print(' from platform_admin.models import PlatformAdmin')
|
||||
print(' PlatformAdmin.objects.create_superuser(email="...", name="...", password="...")')
|
||||
else:
|
||||
if not PlatformAdmin.objects.filter(email=email).exists():
|
||||
admin = PlatformAdmin.objects.create_superuser(
|
||||
email=email,
|
||||
password=password,
|
||||
name=first_name
|
||||
name=name,
|
||||
password=password
|
||||
)
|
||||
print(f'Superuser {email} created successfully!')
|
||||
print(f'PlatformAdmin {email} created successfully!')
|
||||
else:
|
||||
print(f'Superuser {email} already exists.')
|
||||
print(f'PlatformAdmin {email} already exists.')
|
||||
EOF
|
||||
}
|
||||
|
||||
@@ -199,7 +200,7 @@ case "$1" in
|
||||
wait_for_redis
|
||||
setup_directories
|
||||
run_migrations
|
||||
create_superuser
|
||||
create_platform_admin
|
||||
echo "Starting Gunicorn..."
|
||||
exec gunicorn myproject.wsgi:application \
|
||||
--bind 0.0.0.0:8000 \
|
||||
@@ -228,7 +229,7 @@ case "$1" in
|
||||
migrate)
|
||||
wait_for_postgres
|
||||
run_migrations
|
||||
create_superuser
|
||||
create_platform_admin
|
||||
;;
|
||||
collectstatic)
|
||||
wait_for_postgres
|
||||
|
||||
Reference in New Issue
Block a user