217 lines
9.0 KiB
YAML
217 lines
9.0 KiB
YAML
---
|
|
apiVersion: apps/v1
|
|
kind: Deployment
|
|
metadata:
|
|
name: backend
|
|
namespace: django
|
|
labels:
|
|
app: backend
|
|
service: backend
|
|
spec:
|
|
replicas: 1
|
|
selector:
|
|
matchLabels:
|
|
app: backend
|
|
template:
|
|
metadata:
|
|
labels:
|
|
app: backend
|
|
service: backend
|
|
annotations:
|
|
traffic.sidecar.istio.io/excludeOutboundPorts: "8200"
|
|
vault.hashicorp.com/agent-init-first: "true"
|
|
vault.hashicorp.com/agent-inject: "true"
|
|
vault.hashicorp.com/agent-pre-populate-only: "true"
|
|
vault.hashicorp.com/auth-path: auth/kubernetes
|
|
vault.hashicorp.com/role: django
|
|
vault.hashicorp.com/agent-inject-secret-django-postgresql: secrets/data/postgresql/apps/django
|
|
vault.hashicorp.com/agent-inject-template-django-postgresql: |-
|
|
{{- with secret "secrets/data/postgresql/apps/django" -}}
|
|
DJANGO_POSTGRES_HOST=postgresql.django.svc.cluster.local
|
|
DJANGO_POSTGRES_PORTS=5432
|
|
DJANGO_POSTGRES_DATABASE=sarex_db
|
|
DJANGO_POSTGRES_USER={{ index .Data.data "username" }}
|
|
DJANGO_POSTGRES_PASSWORD={{ index .Data.data "password" }}
|
|
{{- end -}}
|
|
vault.hashicorp.com/agent-inject-secret-django-rabbitmq: secrets/data/rabbitmq/apps/django
|
|
vault.hashicorp.com/agent-inject-template-django-rabbitmq: |-
|
|
{{- with secret "secrets/data/rabbitmq/apps/django" -}}
|
|
CELERY_RABBITMQ_HOST=rabbitmq.rabbitmq.svc.cluster.local
|
|
CELERY_RABBITMQ_USER={{ index .Data.data "username" }}
|
|
CELERY_RABBITMQ_PASSWORD={{ index .Data.data "password" }}
|
|
CELERY_RABBITMQ_VHOST={{ index .Data.data "vhost" }}
|
|
DJANGO_RABBIT_HOSTNAME=rabbitmq.rabbitmq.svc.cluster.local
|
|
DJANGO_RABBIT_USER={{ index .Data.data "username" }}
|
|
DJANGO_RABBIT_PASS={{ index .Data.data "password" }}
|
|
DJANGO_RABBIT_VHOST={{ index .Data.data "vhost" }}
|
|
{{- end -}}
|
|
vault.hashicorp.com/agent-inject-secret-django-s3: secrets/data/minio/apps/django
|
|
vault.hashicorp.com/agent-inject-template-django-s3: |-
|
|
{{- with secret "secrets/data/minio/apps/django" -}}
|
|
AWS_S3_ENDPOINT_URL=https://minio.contour.infra.sarex.tech
|
|
S3_HOST=https://minio.contour.infra.sarex.tech
|
|
{{- $buckets := index .Data.data "buckets" }}
|
|
S3_BUCKET={{- if gt (len $buckets) 0 -}}{{ index (index $buckets 0) "name" }}{{- else -}}django{{- end -}}
|
|
S3_LOGIN={{ index .Data.data "access_key" }}
|
|
S3_PASSWORD={{ index .Data.data "secret_key" }}
|
|
{{- end -}}
|
|
vault.hashicorp.com/agent-inject-secret-django-kafka: secrets/data/kafka/apps/django
|
|
vault.hashicorp.com/agent-inject-template-django-kafka: |-
|
|
{{- with secret "secrets/data/kafka/apps/django" -}}
|
|
KAFKA_BOOTSTRAP_SERVERS="[\"{{ index .Data.data.auth "bootstrap_servers" }}\"]"
|
|
KAFKA_SECURITY_PROTOCOL={{ index .Data.data.auth "security_protocol" }}
|
|
KAFKA_SASL_MECHANISM={{ index .Data.data.auth "sasl_mechanism" }}
|
|
KAFKA_SASL_PLAIN_USERNAME={{ index .Data.data "username" }}
|
|
KAFKA_SASL_PLAIN_PASSWORD={{ index .Data.data "password" }}
|
|
{{- end -}}
|
|
vault.hashicorp.com/agent-inject-secret-django-jwt-private: secrets/data/vault/common/rsa_keys
|
|
vault.hashicorp.com/agent-inject-template-django-jwt-private: |-
|
|
{{- with secret "secrets/data/vault/common/rsa_keys" -}}
|
|
{{ index .Data.data "private_key" }}
|
|
{{- end -}}
|
|
vault.hashicorp.com/agent-inject-secret-django-jwt-public: secrets/data/vault/common/rsa_keys
|
|
vault.hashicorp.com/agent-inject-template-django-jwt-public: |-
|
|
{{- with secret "secrets/data/vault/common/rsa_keys" -}}
|
|
{{ index .Data.data "public_key" }}
|
|
{{- end -}}
|
|
vault.hashicorp.com/agent-inject-secret-django-common: secrets/data/vault/common/django_auth
|
|
vault.hashicorp.com/agent-inject-template-django-common: |-
|
|
{{- with secret "secrets/data/vault/common/django_auth" -}}
|
|
ZITADEL_ACCESS_TOKEN={{ index .Data.data "django_zitadel_access_token" }}
|
|
{{- end -}}
|
|
spec:
|
|
serviceAccountName: django-vault
|
|
volumes:
|
|
- name: django-configmap
|
|
configMap:
|
|
name: django-configmap
|
|
items:
|
|
- key: production.py
|
|
path: production.py
|
|
defaultMode: 420
|
|
- name: uwsgi-configmap
|
|
configMap:
|
|
name: uwsgi-configmap
|
|
items:
|
|
- key: uwsgi.ini
|
|
path: uwsgi.ini
|
|
defaultMode: 420
|
|
containers:
|
|
- name: backend
|
|
image: cr.yandex/crp3ccidau046kdj8g9q/backend:production_a96dead0
|
|
imagePullPolicy: IfNotPresent
|
|
command: ["/bin/sh", "-ec"]
|
|
args:
|
|
- |
|
|
set -a
|
|
[ -f /vault/secrets/django-postgresql ] && . /vault/secrets/django-postgresql
|
|
[ -f /vault/secrets/django-rabbitmq ] && . /vault/secrets/django-rabbitmq
|
|
[ -f /vault/secrets/django-s3 ] && . /vault/secrets/django-s3
|
|
[ -f /vault/secrets/django-kafka ] && . /vault/secrets/django-kafka
|
|
[ -f /vault/secrets/django-common ] && . /vault/secrets/django-common
|
|
[ -f /vault/secrets/django-jwt-private ] && export JWT_PRIVATE_KEY="$(cat /vault/secrets/django-jwt-private)"
|
|
[ -f /vault/secrets/django-jwt-public ] && export JWT_PUBLIC_KEY="$(cat /vault/secrets/django-jwt-public)"
|
|
set +a
|
|
exec /opt/sarex/entrypoint.sh
|
|
ports:
|
|
- name: http
|
|
containerPort: 8000
|
|
protocol: TCP
|
|
env:
|
|
- name: ALLOWED_HOSTS
|
|
value: '*'
|
|
- name: SERVER_USE_CHANGELOG
|
|
value: "0"
|
|
- name: SERVER_ZITADEL_ENABLED
|
|
value: "False"
|
|
- name: DJANGO_SETTINGS_MODULE
|
|
value: config.settings.production
|
|
- name: CELERY_REDIS_HOST
|
|
value: redis
|
|
- name: CELERY_REDIS_PORT
|
|
value: "6379"
|
|
- name: DJANGO_REDIS_HOST
|
|
value: redis
|
|
- name: DJANGO_REDIS_PORT
|
|
value: "6379"
|
|
- name: BIMV2_INTERNAL_HOST
|
|
value: http://bim-backend-v2-service.bim-api
|
|
- name: BIMV2_TIMEOUT
|
|
value: "60"
|
|
- name: JWT_KID
|
|
value: "1"
|
|
- name: PDM_SYNC
|
|
value: "1"
|
|
- name: KC_SYNC_ENABLE
|
|
value: "0"
|
|
- name: MEASUREMENTS_HOST
|
|
value: http://measurements-service.measurements.svc.cluster.local:8000/api
|
|
- name: MEASUREMENTS_USE_MEASUREMENTS
|
|
value: "1"
|
|
- name: SERVER_API_HOST
|
|
value: https://sarex.contour.infra.sarex.tech
|
|
- name: SERVER_HOST
|
|
value: https://sarex.contour.infra.sarex.tech
|
|
- name: WORKFLOWS_HOST
|
|
value: https://sarex.contour.infra.sarex.tech
|
|
- name: WORKFLOWS_BASE_HOST
|
|
value: https://sarex.contour.infra.sarex.tech
|
|
- name: WORKFLOWS_USE
|
|
value: "1"
|
|
- name: SERVER_S3_STREAM_IMPORT
|
|
value: "1"
|
|
- name: SERVER_SAVE_DIFF_DEM
|
|
value: "1"
|
|
- name: SERVER_USE_CLICKHOUSE
|
|
value: "0"
|
|
- name: SERVER_USE_CREATE_COMPARED_GEOTIFF_TASK
|
|
value: "0"
|
|
- name: SERVER_USE_DJANGO_STORAGE
|
|
value: "1"
|
|
- name: SERVER_USE_METASHAPE
|
|
value: "0"
|
|
- name: SERVER_CHANGELOG_MODE_SYSTEM_LOG
|
|
value: "1"
|
|
- name: SERVER_CHANGELOG_MODE
|
|
value: "0"
|
|
- name: SERVER_DJANGO_URLS
|
|
value: "1"
|
|
- name: CHECK_IMPORT_HASH
|
|
value: "1"
|
|
- name: EAV_ENABLE
|
|
value: "1"
|
|
- name: SERVER_CHECK_IMPORT_HASH
|
|
value: "1"
|
|
- name: SERVER_CHUNKED_PATH
|
|
value: /tmp/chunked_uploads/%Y/%m/%d
|
|
- name: SERVER_HIDE_USER_SCROLL_PERMISSIONS
|
|
value: "0"
|
|
- name: SERVER_USE_WRORKFLOW_STATUS
|
|
value: "1"
|
|
- name: ZITADEL_HOST
|
|
value: https://zitadel-srx.wb.ru
|
|
- name: SERVER_KAFKA_ENABLED
|
|
value: "False"
|
|
- name: KAFKA_TOPICS
|
|
value: '{"planning": "message-hub-stage", "ams-sync": "ams-sync"}'
|
|
- name: KAFKA_SSL_CAFILE
|
|
value: /usr/local/share/ca-certificates/kafka.crt
|
|
- name: KC_USE_REDIRECT_LOGOUT
|
|
value: "False"
|
|
|
|
|
|
|
|
resources:
|
|
requests:
|
|
cpu: "100m"
|
|
memory: 256Mi
|
|
volumeMounts:
|
|
- name: django-configmap
|
|
mountPath: /opt/sarex/config/settings/production.py
|
|
subPath: production.py
|
|
- name: uwsgi-configmap
|
|
mountPath: /opt/sarex/uwsgi.ini
|
|
subPath: uwsgi.ini
|
|
imagePullSecrets:
|
|
- name: regcred
|