a9e0d3d2f7920f36a8915ce3f64ec7832b91647a
[vfc/nfvo/driver/vnfm/svnfm.git] / zte / vmanager / driver / settings.py
1 # Copyright 2016-2017 ZTE Corporation.
2 #
3 # Licensed under the Apache License, Version 2.0 (the "License");
4 # you may not use this file except in compliance with the License.
5 # You may obtain a copy of the License at
6 #
7 #         http://www.apache.org/licenses/LICENSE-2.0
8 #
9 # Unless required by applicable law or agreed to in writing, software
10 # distributed under the License is distributed on an "AS IS" BASIS,
11 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 # See the License for the specific language governing permissions and
13 # limitations under the License.
14
15 import os
16 import sys
17 import platform
18 from logging import config
19
20 # Build paths inside the project like this: os.path.join(BASE_DIR, ...)
21 import yaml
22
23 BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
24
25
26 # Quick-start development settings - unsuitable for production
27 # See https://docs.djangoproject.com/en/1.9/howto/deployment/checklist/
28
29 # SECURITY WARNING: keep the secret key used in production secret!
30 SECRET_KEY = '3o-wney!99y)^h3v)0$j16l9=fdjxcb+a8g+q3tfbahcnu2b0o'
31
32 # SECURITY WARNING: don't run with debug turned on in production!
33 DEBUG = True
34
35 ALLOWED_HOSTS = ['*']
36
37
38 # Application definition
39
40 INSTALLED_APPS = [
41     'django.contrib.auth',
42     'django.contrib.contenttypes',
43     'django.contrib.sessions',
44     'django.contrib.messages',
45     'django.contrib.staticfiles',
46     'rest_framework',
47     'driver.pub.database',
48     'driver.interfaces',
49     'driver.swagger',
50     'drf_yasg',
51 ]
52
53 MIDDLEWARE_CLASSES = [
54     'django.middleware.security.SecurityMiddleware',
55     'django.contrib.sessions.middleware.SessionMiddleware',
56     'django.middleware.common.CommonMiddleware',
57     'django.middleware.csrf.CsrfViewMiddleware',
58     'django.contrib.auth.middleware.AuthenticationMiddleware',
59     'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
60     'django.contrib.messages.middleware.MessageMiddleware',
61     'django.middleware.clickjacking.XFrameOptionsMiddleware',
62 ]
63
64 ROOT_URLCONF = 'driver.urls'
65
66 WSGI_APPLICATION = 'driver.wsgi.application'
67
68
69 REST_FRAMEWORK = {
70     'DEFAULT_RENDERER_CLASSES': (
71         'rest_framework.renderers.JSONRenderer',
72     ),
73
74     'DEFAULT_PARSER_CLASSES': (
75         'rest_framework.parsers.JSONParser',
76         'rest_framework.parsers.MultiPartParser',
77     )
78 }
79
80 # drf-yasg
81 TEMPLATES = [
82     {
83         'BACKEND': 'django.template.backends.django.DjangoTemplates',
84         'DIRS': [],
85         'APP_DIRS': True,
86         'OPTIONS': {
87             'context_processors': [
88                 'django.template.context_processors.debug',
89                 'django.template.context_processors.request',
90                 'django.contrib.auth.context_processors.auth',
91                 'django.contrib.messages.context_processors.messages',
92             ],
93         },
94     },
95 ]
96
97 SWAGGER_SETTINGS = {
98     'LOGIN_URL': '/admin/login',
99     'LOGOUT_URL': '/admin/logout',
100
101     'DEFAULT_INFO': 'driver.swagger.urls.swagger_info'
102 }
103
104 DATABASES = {
105     'default': {
106         'ENGINE': 'django.db.backends.sqlite3',
107         'NAME': ':memory:',
108     },
109 }
110
111 TIME_ZONE = 'UTC'
112
113 # Static files (CSS, JavaScript, Images)
114 # https://docs.djangoproject.com/en/1.6/howto/static-files/
115
116 STATIC_URL = '/static/'
117
118 if platform.system() == 'Windows' or 'test' in sys.argv:
119     LOGGING = {
120         'version': 1,
121         'disable_existing_loggers': True,
122         'formatters': {
123             'standard': {
124                 'format': '%(asctime)s:[%(name)s]:[%(filename)s]-[%(lineno)d] [%(levelname)s]:%(message)s',
125             },
126         },
127         'filters': {
128         },
129         'handlers': {
130             'driver_handler': {
131                 'level': 'DEBUG',
132                 'class': 'logging.handlers.RotatingFileHandler',
133                 'filename': os.path.join(
134                     BASE_DIR,
135                     'logs/runtime_driver.log'),
136                 'formatter': 'standard',
137                 'maxBytes': 1024 * 1024 * 50,
138                 'backupCount': 5,
139             },
140         },
141         'loggers': {
142             'driver': {
143                 'handlers': ['driver_handler'],
144                 'level': 'DEBUG',
145                 'propagate': False},
146         }}
147 else:
148     LOGGING_CONFIG = None
149
150     log_path = '/var/log/onap/vfc/ztevnfmdriver'
151     if not os.path.exists(log_path):
152         os.makedirs(log_path)
153
154     # yaml configuration of logging
155     LOGGING_FILE = os.path.join(BASE_DIR, 'driver/log.yml')
156     config.yamlConfig(filepath=LOGGING_FILE, watchDog=True)
157     with open(file=LOGGING_FILE, mode='r', encoding="utf-8")as file:
158         logging_yaml = yaml.load(stream=file, Loader=yaml.FullLoader)
159     config.dictConfig(config=logging_yaml)
160
161
162 if 'test' in sys.argv:
163
164     from driver.pub.config import config
165     config.REG_TO_MSB_WHEN_START = False
166     REST_FRAMEWORK = {}
167     if platform.system() == 'Linux':
168         TEST_RUNNER = 'xmlrunner.extra.djangotestrunner.XMLTestRunner'
169         TEST_OUTPUT_VERBOSE = True
170         TEST_OUTPUT_DESCRIPTIONS = True
171         TEST_OUTPUT_DIR = 'test-reports'