Обновления в docker: entrypoint.sh и инструкции по развертыванию
This commit is contained in:
@@ -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()
|
|
||||||
```
|
|
||||||
|
|
||||||
## Полезные команды
|
## Полезные команды
|
||||||
|
|
||||||
|
|||||||
@@ -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="...")')
|
||||||
|
else:
|
||||||
if not User.objects.filter(email=email).exists():
|
if not PlatformAdmin.objects.filter(email=email).exists():
|
||||||
user = User.objects.create_superuser(
|
admin = PlatformAdmin.objects.create_superuser(
|
||||||
email=email,
|
email=email,
|
||||||
password=password,
|
name=name,
|
||||||
name=first_name
|
password=password
|
||||||
)
|
)
|
||||||
print(f'Superuser {email} created successfully!')
|
print(f'PlatformAdmin {email} created successfully!')
|
||||||
else:
|
else:
|
||||||
print(f'Superuser {email} already exists.')
|
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
|
||||||
|
|||||||
Reference in New Issue
Block a user