diff --git a/castellum_core/Dockerfile b/castellum_core/Dockerfile new file mode 100644 index 0000000000000000000000000000000000000000..1bfafeefaa5a1f5ed34c8ac9ea4fa86a86a16c0e --- /dev/null +++ b/castellum_core/Dockerfile @@ -0,0 +1,9 @@ +FROM python:3.6-alpine3.7 +ENV PYTHONUNBUFFERED 1 + +RUN apk update && apk add gcc make nodejs-npm python-dev musl-dev postgresql-dev openldap openldap-dev cyrus-sasl-dev + +COPY ./ code/ +WORKDIR code/ + +RUN make install diff --git a/castellum_core/castellum_core/castellum_core/settings/stage.py b/castellum_core/castellum_core/castellum_core/settings/stage.py index 9b20f5aa06bccdaf26086bb97ee1121081a6b308..f1ea8094b3c560228cbf9f5bebd0c9e1a2306200 100644 --- a/castellum_core/castellum_core/castellum_core/settings/stage.py +++ b/castellum_core/castellum_core/castellum_core/settings/stage.py @@ -10,20 +10,20 @@ SECRET_KEY = 'i#$kwk(s24ysn+l%+c!*z9u4+45)oex!-s#!bux#wf2pv2cc0d' DATABASES = { 'default': { - 'ENGINE': 'django.db.backends.sqlite3', - 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), + 'ENGINE': 'django.db.backends.postgresql', + 'NAME': 'postgres', + 'USER': 'postgres', + 'HOST': 'db', } } -ALLOWED_HOSTS = [ - 'localhost', -] +ALLOWED_HOSTS = ['*'] # LDAP # See https://django-auth-ldap.readthedocs.io/ AUTHENTICATION_BACKENDS.append("django_auth_ldap.backend.LDAPBackend") -AUTH_LDAP_SERVER_URI = 'ldap://localhost' +AUTH_LDAP_SERVER_URI = 'ldap://ldap' AUTH_LDAP_BIND_DN = 'cn=admin,dc=example,dc=org' AUTH_LDAP_BIND_PASSWORD = 'admin' AUTH_LDAP_USER_SEARCH = LDAPSearch('dc=example,dc=org', ldap.SCOPE_SUBTREE, '(uid=%(user)s)') diff --git a/castellum_core/setup.py b/castellum_core/setup.py index 5c1dd800fe124ae5de88b44c9457c638262b1962..1e85b1c5d805c237271e32a087bc7084f1bdc37d 100644 --- a/castellum_core/setup.py +++ b/castellum_core/setup.py @@ -13,6 +13,7 @@ setup( "Django==2.0.4", "django-auth-ldap==1.4.0", "django-bootstrap4==0.0.6", - "django-npm==1.0.0" + "django-npm==1.0.0", + "psycopg2==2.7.4", ], ) diff --git a/docker-compose.yml b/docker-compose.yml index 99ab7e8f05b54293129c8e4311e567b0f73d8e61..eac0a7d23d01c11808fb047af4d34879777de0fb 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -1,6 +1,8 @@ version: '2' services: + db: + image: postgres ldap: container_name: ldap image: osixia/openldap @@ -9,3 +11,18 @@ services: command: [--copy-service] volumes: - ./ldap/dummy_data.ldif:/container/service/slapd/assets/config/bootstrap/ldif/data.ldif + web: + build: castellum_core + environment: + DJANGO_SETTINGS_MODULE: castellum_core.settings.stage + command: > + sh -c "cd castellum_core && + make bootstrap && + python castellum_core/manage.py runserver 0.0.0.0:8000" + volumes: + - .:/code + ports: + - "8000:8000" + depends_on: + - db + - ldap