Add vfc-ztevnfmdriver log integration config
[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 from logging import config
18 from onaplogging import monkey
19 monkey.patch_all()
20
21 # Build paths inside the project like this: os.path.join(BASE_DIR, ...)
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     'drf_yasg',
50 ]
51
52 MIDDLEWARE_CLASSES = [
53     'django.middleware.security.SecurityMiddleware',
54     'django.contrib.sessions.middleware.SessionMiddleware',
55     'django.middleware.common.CommonMiddleware',
56     'django.middleware.csrf.CsrfViewMiddleware',
57     'django.contrib.auth.middleware.AuthenticationMiddleware',
58     'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
59     'django.contrib.messages.middleware.MessageMiddleware',
60     'django.middleware.clickjacking.XFrameOptionsMiddleware',
61     'driver.middleware.LogContextMiddleware',
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 # LOGGING = {
119 #     'version': 1,
120 #     'disable_existing_loggers': True,
121 #     'formatters': {
122 #         'standard': {
123 #             'format': '%(asctime)s:[%(name)s]:[%(filename)s]-[%(lineno)d] [%(levelname)s]:%(message)s',
124 #         },
125 #     },
126 #     'filters': {
127 #     },
128 #     'handlers': {
129 #         'driver_handler': {
130 #             'level': 'DEBUG',
131 #             'class': 'logging.handlers.RotatingFileHandler',
132 #             'filename': os.path.join(
133 #                 BASE_DIR,
134 #                 'logs/runtime_driver.log'),
135 #             'formatter': 'standard',
136 #             'maxBytes': 1024 * 1024 * 50,
137 #             'backupCount': 5,
138 #         },
139 #     },
140 #     'loggers': {
141 #         'driver': {
142 #             'handlers': ['driver_handler'],
143 #             'level': 'DEBUG',
144 #             'propagate': False},
145 #     }}
146
147 LOGGING_CONFIG = None
148 # yaml configuration of logging
149 LOGGING_FILE = os.path.join(BASE_DIR, 'driver/log.yml')
150 config.yamlConfig(filepath=LOGGING_FILE, watchDog=True)
151
152
153 if 'test' in sys.argv:
154     from driver.pub.config import config
155     config.REG_TO_MSB_WHEN_START = False
156     REST_FRAMEWORK = {}
157     import platform
158     if platform.system() == 'Linux':
159         TEST_RUNNER = 'xmlrunner.extra.djangotestrunner.XMLTestRunner'
160         TEST_OUTPUT_VERBOSE = True
161         TEST_OUTPUT_DESCRIPTIONS = True
162         TEST_OUTPUT_DIR = 'test-reports'