Compare commits
1 Commits
versions/m
...
features/m
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
37e85590e8 |
@@ -10,7 +10,6 @@ from mayan.apps.smart_settings.classes import Namespace
|
|||||||
|
|
||||||
from .literals import DEFAULT_COMMON_HOME_VIEW
|
from .literals import DEFAULT_COMMON_HOME_VIEW
|
||||||
|
|
||||||
|
|
||||||
namespace = Namespace(label=_('Common'), name='common')
|
namespace = Namespace(label=_('Common'), name='common')
|
||||||
|
|
||||||
setting_auto_logging = namespace.add_setting(
|
setting_auto_logging = namespace.add_setting(
|
||||||
@@ -99,318 +98,3 @@ setting_shared_storage_arguments = namespace.add_setting(
|
|||||||
os.path.join(settings.MEDIA_ROOT, 'shared_files')
|
os.path.join(settings.MEDIA_ROOT, 'shared_files')
|
||||||
), quoted=True
|
), quoted=True
|
||||||
)
|
)
|
||||||
|
|
||||||
namespace = Namespace(label=_('Django'), name='django')
|
|
||||||
|
|
||||||
setting_django_allowed_hosts = namespace.add_setting(
|
|
||||||
global_name='ALLOWED_HOSTS', default=settings.ALLOWED_HOSTS,
|
|
||||||
help_text=_(
|
|
||||||
'A list of strings representing the host/domain names that this site '
|
|
||||||
'can serve. This is a security measure to prevent HTTP Host header '
|
|
||||||
'attacks, which are possible even under many seemingly-safe web '
|
|
||||||
'server configurations. Values in this list can be '
|
|
||||||
'fully qualified names (e.g. \'www.example.com\'), in which case '
|
|
||||||
'they will be matched against the request\'s Host header exactly '
|
|
||||||
'(case-insensitive, not including port). A value beginning with a '
|
|
||||||
'period can be used as a subdomain wildcard: \'.example.com\' will '
|
|
||||||
'match example.com, www.example.com, and any other subdomain of '
|
|
||||||
'example.com. A value of \'*\' will match anything; in this case you '
|
|
||||||
'are responsible to provide your own validation of the Host header '
|
|
||||||
'(perhaps in a middleware; if so this middleware must be listed '
|
|
||||||
'first in MIDDLEWARE).'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_append_slash = namespace.add_setting(
|
|
||||||
global_name='APPEND_SLASH', default=settings.APPEND_SLASH,
|
|
||||||
help_text=_(
|
|
||||||
'When set to True, if the request URL does not match any of the '
|
|
||||||
'patterns in the URLconf and it doesn\'t end in a slash, an HTTP '
|
|
||||||
'redirect is issued to the same URL with a slash appended. Note '
|
|
||||||
'that the redirect may cause any data submitted in a POST request '
|
|
||||||
'to be lost. The APPEND_SLASH setting is only used if '
|
|
||||||
'CommonMiddleware is installed (see Middleware). See also '
|
|
||||||
'PREPEND_WWW.'
|
|
||||||
)
|
|
||||||
)
|
|
||||||
setting_django_auth_password_validators = namespace.add_setting(
|
|
||||||
global_name='AUTH_PASSWORD_VALIDATORS',
|
|
||||||
default=settings.AUTH_PASSWORD_VALIDATORS,
|
|
||||||
help_text=_(
|
|
||||||
'The list of validators that are used to check the strength of '
|
|
||||||
'user\'s passwords.'
|
|
||||||
)
|
|
||||||
)
|
|
||||||
setting_django_databases = namespace.add_setting(
|
|
||||||
global_name='DATABASES', default=settings.DATABASES,
|
|
||||||
help_text=_(
|
|
||||||
'A dictionary containing the settings for all databases to be used '
|
|
||||||
'with Django. It is a nested dictionary whose contents map a '
|
|
||||||
'database alias to a dictionary containing the options for an '
|
|
||||||
'individual database. The DATABASES setting must configure a '
|
|
||||||
'default database; any number of additional databases may also '
|
|
||||||
'be specified.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_data_upload_max_memory_size = namespace.add_setting(
|
|
||||||
global_name='DATA_UPLOAD_MAX_MEMORY_SIZE',
|
|
||||||
default=settings.DATA_UPLOAD_MAX_MEMORY_SIZE,
|
|
||||||
help_text=_(
|
|
||||||
'Default: 2621440 (i.e. 2.5 MB). The maximum size in bytes that a '
|
|
||||||
'request body may be before a SuspiciousOperation '
|
|
||||||
'(RequestDataTooBig) is raised. The check is done when accessing '
|
|
||||||
'request.body or request.POST and is calculated against the total '
|
|
||||||
'request size excluding any file upload data. You can set this to '
|
|
||||||
'None to disable the check. Applications that are expected to '
|
|
||||||
'receive unusually large form posts should tune this setting. The '
|
|
||||||
'amount of request data is correlated to the amount of memory '
|
|
||||||
'needed to process the request and populate the GET and POST '
|
|
||||||
'dictionaries. Large requests could be used as a '
|
|
||||||
'denial-of-service attack vector if left unchecked. Since web '
|
|
||||||
'servers don\'t typically perform deep request inspection, it\'s '
|
|
||||||
'not possible to perform a similar check at that level. See also '
|
|
||||||
'FILE_UPLOAD_MAX_MEMORY_SIZE.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_default_from_email = namespace.add_setting(
|
|
||||||
global_name='DEFAULT_FROM_EMAIL',
|
|
||||||
default=settings.DEFAULT_FROM_EMAIL,
|
|
||||||
help_text=_(
|
|
||||||
'Default: \'webmaster@localhost\' '
|
|
||||||
'Default email address to use for various automated correspondence '
|
|
||||||
'from the site manager(s). This doesn\'t include error messages sent '
|
|
||||||
'to ADMINS and MANAGERS; for that, see SERVER_EMAIL.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_disallowed_user_agents = namespace.add_setting(
|
|
||||||
global_name='DISALLOWED_USER_AGENTS',
|
|
||||||
default=settings.DISALLOWED_USER_AGENTS,
|
|
||||||
help_text=_(
|
|
||||||
'Default: [] (Empty list). List of compiled regular expression '
|
|
||||||
'objects representing User-Agent strings that are not allowed to '
|
|
||||||
'visit any page, systemwide. Use this for bad robots/crawlers. '
|
|
||||||
'This is only used if CommonMiddleware is installed '
|
|
||||||
'(see Middleware).'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_email_backend = namespace.add_setting(
|
|
||||||
global_name='EMAIL_BACKEND',
|
|
||||||
default=settings.EMAIL_BACKEND,
|
|
||||||
help_text=_(
|
|
||||||
'Default: \'django.core.mail.backends.smtp.EmailBackend\'. The '
|
|
||||||
'backend to use for sending emails.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_email_host = namespace.add_setting(
|
|
||||||
global_name='EMAIL_HOST',
|
|
||||||
default=settings.EMAIL_HOST,
|
|
||||||
help_text=_(
|
|
||||||
'Default: \'localhost\'. The host to use for sending email.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_email_host_password = namespace.add_setting(
|
|
||||||
global_name='EMAIL_HOST_PASSWORD',
|
|
||||||
default=settings.EMAIL_HOST_PASSWORD,
|
|
||||||
help_text=_(
|
|
||||||
'Default: \'\' (Empty string). Password to use for the SMTP '
|
|
||||||
'server defined in EMAIL_HOST. This setting is used in '
|
|
||||||
'conjunction with EMAIL_HOST_USER when authenticating to the '
|
|
||||||
'SMTP server. If either of these settings is empty, '
|
|
||||||
'Django won\'t attempt authentication.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_email_host_user = namespace.add_setting(
|
|
||||||
global_name='EMAIL_HOST_USER',
|
|
||||||
default=settings.EMAIL_HOST_USER,
|
|
||||||
help_text=_(
|
|
||||||
'Default: \'\' (Empty string). Username to use for the SMTP '
|
|
||||||
'server defined in EMAIL_HOST. If empty, Django won\'t attempt '
|
|
||||||
'authentication.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_email_port = namespace.add_setting(
|
|
||||||
global_name='EMAIL_PORT',
|
|
||||||
default=settings.EMAIL_PORT,
|
|
||||||
help_text=_(
|
|
||||||
'Default: 25. Port to use for the SMTP server defined in EMAIL_HOST.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_email_timeout = namespace.add_setting(
|
|
||||||
global_name='EMAIL_TIMEOUT',
|
|
||||||
default=settings.EMAIL_TIMEOUT,
|
|
||||||
help_text=_(
|
|
||||||
'Default: None. Specifies a timeout in seconds for blocking '
|
|
||||||
'operations like the connection attempt.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_email_user_tls = namespace.add_setting(
|
|
||||||
global_name='EMAIL_USE_TLS',
|
|
||||||
default=settings.EMAIL_USE_TLS,
|
|
||||||
help_text=_(
|
|
||||||
'Default: False. Whether to use a TLS (secure) connection when '
|
|
||||||
'talking to the SMTP server. This is used for explicit TLS '
|
|
||||||
'connections, generally on port 587. If you are experiencing '
|
|
||||||
'hanging connections, see the implicit TLS setting EMAIL_USE_SSL.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_email_user_ssl = namespace.add_setting(
|
|
||||||
global_name='EMAIL_USE_SSL',
|
|
||||||
default=settings.EMAIL_USE_SSL,
|
|
||||||
help_text=_(
|
|
||||||
'Default: False. Whether to use an implicit TLS (secure) connection '
|
|
||||||
'when talking to the SMTP server. In most email documentation this '
|
|
||||||
'type of TLS connection is referred to as SSL. It is generally used '
|
|
||||||
'on port 465. If you are experiencing problems, see the explicit '
|
|
||||||
'TLS setting EMAIL_USE_TLS. Note that EMAIL_USE_TLS/EMAIL_USE_SSL '
|
|
||||||
'are mutually exclusive, so only set one of those settings to True.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_file_upload_max_memory_size = namespace.add_setting(
|
|
||||||
global_name='FILE_UPLOAD_MAX_MEMORY_SIZE',
|
|
||||||
default=settings.FILE_UPLOAD_MAX_MEMORY_SIZE,
|
|
||||||
help_text=_(
|
|
||||||
'Default: 2621440 (i.e. 2.5 MB). The maximum size (in bytes) '
|
|
||||||
'that an upload will be before it gets streamed to the file '
|
|
||||||
'system. See Managing files for details. See also '
|
|
||||||
'DATA_UPLOAD_MAX_MEMORY_SIZE.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_login_url = namespace.add_setting(
|
|
||||||
global_name='LOGIN_URL',
|
|
||||||
default=settings.LOGIN_URL,
|
|
||||||
help_text=_(
|
|
||||||
'Default: \'/accounts/login/\' The URL where requests are '
|
|
||||||
'redirected for login, especially when using the login_required() '
|
|
||||||
'decorator. This setting also accepts named URL patterns which '
|
|
||||||
'can be used to reduce configuration duplication since you '
|
|
||||||
'don\'t have to define the URL in two places (settings '
|
|
||||||
'and URLconf).'
|
|
||||||
)
|
|
||||||
)
|
|
||||||
setting_django_login_redirect_url = namespace.add_setting(
|
|
||||||
global_name='LOGIN_REDIRECT_URL',
|
|
||||||
default=settings.LOGIN_REDIRECT_URL,
|
|
||||||
help_text=_(
|
|
||||||
'Default: \'/accounts/profile/\' The URL where requests are '
|
|
||||||
'redirected after login when the contrib.auth.login view gets no '
|
|
||||||
'next parameter. This is used by the login_required() decorator, '
|
|
||||||
'for example. This setting also accepts named URL patterns which '
|
|
||||||
'can be used to reduce configuration duplication since you don\'t '
|
|
||||||
'have to define the URL in two places (settings and URLconf).'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_logout_redirect_url = namespace.add_setting(
|
|
||||||
global_name='LOGOUT_REDIRECT_URL',
|
|
||||||
default=settings.LOGOUT_REDIRECT_URL,
|
|
||||||
help_text=_(
|
|
||||||
'Default: None. The URL where requests are redirected after a user '
|
|
||||||
'logs out using LogoutView (if the view doesn\'t get a next_page '
|
|
||||||
'argument). If None, no redirect will be performed and the logout '
|
|
||||||
'view will be rendered. This setting also accepts named URL '
|
|
||||||
'patterns which can be used to reduce configuration duplication '
|
|
||||||
'since you don\'t have to define the URL in two places (settings '
|
|
||||||
'and URLconf).'
|
|
||||||
)
|
|
||||||
)
|
|
||||||
setting_django_internal_ips = namespace.add_setting(
|
|
||||||
global_name='INTERNAL_IPS',
|
|
||||||
default=settings.INTERNAL_IPS,
|
|
||||||
help_text=_(
|
|
||||||
'A list of IP addresses, as strings, that: Allow the debug() '
|
|
||||||
'context processor to add some variables to the template context. '
|
|
||||||
'Can use the admindocs bookmarklets even if not logged in as a '
|
|
||||||
'staff user. Are marked as "internal" (as opposed to "EXTERNAL") '
|
|
||||||
'in AdminEmailHandler emails.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_languages = namespace.add_setting(
|
|
||||||
global_name='LANGUAGES',
|
|
||||||
default=settings.LANGUAGES,
|
|
||||||
help_text=_(
|
|
||||||
'A list of all available languages. The list is a list of '
|
|
||||||
'two-tuples in the format (language code, language name) '
|
|
||||||
'for example, (\'ja\', \'Japanese\'). This specifies which '
|
|
||||||
'languages are available for language selection. '
|
|
||||||
'Generally, the default value should suffice. Only set this '
|
|
||||||
'setting if you want to restrict language selection to a '
|
|
||||||
'subset of the Django-provided languages. '
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_language_code = namespace.add_setting(
|
|
||||||
global_name='LANGUAGE_CODE',
|
|
||||||
default=settings.LANGUAGE_CODE,
|
|
||||||
help_text=_(
|
|
||||||
'A string representing the language code for this installation. '
|
|
||||||
'This should be in standard language ID format. For example, U.S. '
|
|
||||||
'English is "en-us". It serves two purposes: If the locale '
|
|
||||||
'middleware isn\'t in use, it decides which translation is served '
|
|
||||||
'to all users. If the locale middleware is active, it provides a '
|
|
||||||
'fallback language in case the user\'s preferred language can\'t '
|
|
||||||
'be determined or is not supported by the website. It also provides '
|
|
||||||
'the fallback translation when a translation for a given literal '
|
|
||||||
'doesn\'t exist for the user\'s preferred language.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_static_url = namespace.add_setting(
|
|
||||||
global_name='STATIC_URL',
|
|
||||||
default=settings.STATIC_URL,
|
|
||||||
help_text=_(
|
|
||||||
'URL to use when referring to static files located in STATIC_ROOT. '
|
|
||||||
'Example: "/static/" or "http://static.example.com/" '
|
|
||||||
'If not None, this will be used as the base path for asset '
|
|
||||||
'definitions (the Media class) and the staticfiles app. '
|
|
||||||
'It must end in a slash if set to a non-empty value.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_staticfiles_storage = namespace.add_setting(
|
|
||||||
global_name='STATICFILES_STORAGE',
|
|
||||||
default=settings.STATICFILES_STORAGE,
|
|
||||||
help_text=_(
|
|
||||||
'The file storage engine to use when collecting static files with '
|
|
||||||
'the collectstatic management command. A ready-to-use instance of '
|
|
||||||
'the storage backend defined in this setting can be found at '
|
|
||||||
'django.contrib.staticfiles.storage.staticfiles_storage.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_time_zone = namespace.add_setting(
|
|
||||||
global_name='TIME_ZONE',
|
|
||||||
default=settings.TIME_ZONE,
|
|
||||||
help_text=_(
|
|
||||||
'A string representing the time zone for this installation. '
|
|
||||||
'Note that this isn\'t necessarily the time zone of the server. '
|
|
||||||
'For example, one server may serve multiple Django-powered sites, '
|
|
||||||
'each with a separate time zone setting.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_django_wsgi_application = namespace.add_setting(
|
|
||||||
global_name='WSGI_APPLICATION',
|
|
||||||
default=settings.WSGI_APPLICATION,
|
|
||||||
help_text=_(
|
|
||||||
'The full Python path of the WSGI application object that Django\'s '
|
|
||||||
'built-in servers (e.g. runserver) will use. The django-admin '
|
|
||||||
'startproject management command will create a simple wsgi.py '
|
|
||||||
'file with an application callable in it, and point this setting '
|
|
||||||
'to that application.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
|
|
||||||
namespace = Namespace(label=_('Celery'), name='celery')
|
|
||||||
|
|
||||||
setting_celery_broker_url = namespace.add_setting(
|
|
||||||
global_name='BROKER_URL', default=settings.BROKER_URL,
|
|
||||||
help_text=_(
|
|
||||||
'Default: "amqp://". Default broker URL. This must be a URL in '
|
|
||||||
'the form of: transport://userid:password@hostname:port/virtual_host '
|
|
||||||
'Only the scheme part (transport://) is required, the rest is '
|
|
||||||
'optional, and defaults to the specific transports default values.'
|
|
||||||
),
|
|
||||||
)
|
|
||||||
setting_celery_result_backend = namespace.add_setting(
|
|
||||||
global_name='CELERY_RESULT_BACKEND',
|
|
||||||
default=settings.CELERY_RESULT_BACKEND,
|
|
||||||
help_text=_(
|
|
||||||
'Default: No result backend enabled by default. The backend used '
|
|
||||||
'to store task results (tombstones). Refer to '
|
|
||||||
'http://docs.celeryproject.org/en/v4.1.0/userguide/configuration.'
|
|
||||||
'html#result-backend'
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ from .links import (
|
|||||||
link_namespace_detail, link_namespace_list, link_namespace_root_list,
|
link_namespace_detail, link_namespace_list, link_namespace_root_list,
|
||||||
link_setting_edit
|
link_setting_edit
|
||||||
)
|
)
|
||||||
|
from .settings import * # NOQA
|
||||||
from .widgets import setting_widget
|
from .widgets import setting_widget
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
302
mayan/apps/smart_settings/settings.py
Normal file
302
mayan/apps/smart_settings/settings.py
Normal file
@@ -0,0 +1,302 @@
|
|||||||
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
|
from django.conf import settings
|
||||||
|
from django.utils.translation import ugettext_lazy as _
|
||||||
|
|
||||||
|
from mayan.apps.smart_settings.classes import Namespace
|
||||||
|
|
||||||
|
# Don't import anything on start import, we just want to make it easy
|
||||||
|
# for apps.py to activate the settings in this module.
|
||||||
|
__all__ = ()
|
||||||
|
namespace = Namespace(label=_('Django'), name='django')
|
||||||
|
|
||||||
|
setting_django_allowed_hosts = namespace.add_setting(
|
||||||
|
global_name='ALLOWED_HOSTS', default=settings.ALLOWED_HOSTS,
|
||||||
|
help_text=_(
|
||||||
|
'A list of strings representing the host/domain names that this site '
|
||||||
|
'can serve. This is a security measure to prevent HTTP Host header '
|
||||||
|
'attacks, which are possible even under many seemingly-safe web '
|
||||||
|
'server configurations. Values in this list can be '
|
||||||
|
'fully qualified names (e.g. \'www.example.com\'), in which case '
|
||||||
|
'they will be matched against the request\'s Host header exactly '
|
||||||
|
'(case-insensitive, not including port). A value beginning with a '
|
||||||
|
'period can be used as a subdomain wildcard: \'.example.com\' will '
|
||||||
|
'match example.com, www.example.com, and any other subdomain of '
|
||||||
|
'example.com. A value of \'*\' will match anything; in this case you '
|
||||||
|
'are responsible to provide your own validation of the Host header '
|
||||||
|
'(perhaps in a middleware; if so this middleware must be listed '
|
||||||
|
'first in MIDDLEWARE).'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_append_slash = namespace.add_setting(
|
||||||
|
global_name='APPEND_SLASH', default=settings.APPEND_SLASH,
|
||||||
|
help_text=_(
|
||||||
|
'When set to True, if the request URL does not match any of the '
|
||||||
|
'patterns in the URLconf and it doesn\'t end in a slash, an HTTP '
|
||||||
|
'redirect is issued to the same URL with a slash appended. Note '
|
||||||
|
'that the redirect may cause any data submitted in a POST request '
|
||||||
|
'to be lost. The APPEND_SLASH setting is only used if '
|
||||||
|
'CommonMiddleware is installed (see Middleware). See also '
|
||||||
|
'PREPEND_WWW.'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
setting_django_auth_password_validators = namespace.add_setting(
|
||||||
|
global_name='AUTH_PASSWORD_VALIDATORS',
|
||||||
|
default=settings.AUTH_PASSWORD_VALIDATORS,
|
||||||
|
help_text=_(
|
||||||
|
'The list of validators that are used to check the strength of '
|
||||||
|
'user\'s passwords.'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
setting_django_databases = namespace.add_setting(
|
||||||
|
global_name='DATABASES', default=settings.DATABASES,
|
||||||
|
help_text=_(
|
||||||
|
'A dictionary containing the settings for all databases to be used '
|
||||||
|
'with Django. It is a nested dictionary whose contents map a '
|
||||||
|
'database alias to a dictionary containing the options for an '
|
||||||
|
'individual database. The DATABASES setting must configure a '
|
||||||
|
'default database; any number of additional databases may also '
|
||||||
|
'be specified.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_data_upload_max_memory_size = namespace.add_setting(
|
||||||
|
global_name='DATA_UPLOAD_MAX_MEMORY_SIZE',
|
||||||
|
default=settings.DATA_UPLOAD_MAX_MEMORY_SIZE,
|
||||||
|
help_text=_(
|
||||||
|
'Default: 2621440 (i.e. 2.5 MB). The maximum size in bytes that a '
|
||||||
|
'request body may be before a SuspiciousOperation '
|
||||||
|
'(RequestDataTooBig) is raised. The check is done when accessing '
|
||||||
|
'request.body or request.POST and is calculated against the total '
|
||||||
|
'request size excluding any file upload data. You can set this to '
|
||||||
|
'None to disable the check. Applications that are expected to '
|
||||||
|
'receive unusually large form posts should tune this setting. The '
|
||||||
|
'amount of request data is correlated to the amount of memory '
|
||||||
|
'needed to process the request and populate the GET and POST '
|
||||||
|
'dictionaries. Large requests could be used as a '
|
||||||
|
'denial-of-service attack vector if left unchecked. Since web '
|
||||||
|
'servers don\'t typically perform deep request inspection, it\'s '
|
||||||
|
'not possible to perform a similar check at that level. See also '
|
||||||
|
'FILE_UPLOAD_MAX_MEMORY_SIZE.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_default_from_email = namespace.add_setting(
|
||||||
|
global_name='DEFAULT_FROM_EMAIL',
|
||||||
|
default=settings.DEFAULT_FROM_EMAIL,
|
||||||
|
help_text=_(
|
||||||
|
'Default: \'webmaster@localhost\' '
|
||||||
|
'Default email address to use for various automated correspondence '
|
||||||
|
'from the site manager(s). This doesn\'t include error messages sent '
|
||||||
|
'to ADMINS and MANAGERS; for that, see SERVER_EMAIL.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_disallowed_user_agents = namespace.add_setting(
|
||||||
|
global_name='DISALLOWED_USER_AGENTS',
|
||||||
|
default=settings.DISALLOWED_USER_AGENTS,
|
||||||
|
help_text=_(
|
||||||
|
'Default: [] (Empty list). List of compiled regular expression '
|
||||||
|
'objects representing User-Agent strings that are not allowed to '
|
||||||
|
'visit any page, systemwide. Use this for bad robots/crawlers. '
|
||||||
|
'This is only used if CommonMiddleware is installed '
|
||||||
|
'(see Middleware).'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_email_backend = namespace.add_setting(
|
||||||
|
global_name='EMAIL_BACKEND',
|
||||||
|
default=settings.EMAIL_BACKEND,
|
||||||
|
help_text=_(
|
||||||
|
'Default: \'django.core.mail.backends.smtp.EmailBackend\'. The '
|
||||||
|
'backend to use for sending emails.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_email_host = namespace.add_setting(
|
||||||
|
global_name='EMAIL_HOST',
|
||||||
|
default=settings.EMAIL_HOST,
|
||||||
|
help_text=_(
|
||||||
|
'Default: \'localhost\'. The host to use for sending email.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_email_host_password = namespace.add_setting(
|
||||||
|
global_name='EMAIL_HOST_PASSWORD',
|
||||||
|
default=settings.EMAIL_HOST_PASSWORD,
|
||||||
|
help_text=_(
|
||||||
|
'Default: \'\' (Empty string). Password to use for the SMTP '
|
||||||
|
'server defined in EMAIL_HOST. This setting is used in '
|
||||||
|
'conjunction with EMAIL_HOST_USER when authenticating to the '
|
||||||
|
'SMTP server. If either of these settings is empty, '
|
||||||
|
'Django won\'t attempt authentication.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_email_host_user = namespace.add_setting(
|
||||||
|
global_name='EMAIL_HOST_USER',
|
||||||
|
default=settings.EMAIL_HOST_USER,
|
||||||
|
help_text=_(
|
||||||
|
'Default: \'\' (Empty string). Username to use for the SMTP '
|
||||||
|
'server defined in EMAIL_HOST. If empty, Django won\'t attempt '
|
||||||
|
'authentication.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_email_port = namespace.add_setting(
|
||||||
|
global_name='EMAIL_PORT',
|
||||||
|
default=settings.EMAIL_PORT,
|
||||||
|
help_text=_(
|
||||||
|
'Default: 25. Port to use for the SMTP server defined in EMAIL_HOST.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_email_timeout = namespace.add_setting(
|
||||||
|
global_name='EMAIL_TIMEOUT',
|
||||||
|
default=settings.EMAIL_TIMEOUT,
|
||||||
|
help_text=_(
|
||||||
|
'Default: None. Specifies a timeout in seconds for blocking '
|
||||||
|
'operations like the connection attempt.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_email_user_tls = namespace.add_setting(
|
||||||
|
global_name='EMAIL_USE_TLS',
|
||||||
|
default=settings.EMAIL_USE_TLS,
|
||||||
|
help_text=_(
|
||||||
|
'Default: False. Whether to use a TLS (secure) connection when '
|
||||||
|
'talking to the SMTP server. This is used for explicit TLS '
|
||||||
|
'connections, generally on port 587. If you are experiencing '
|
||||||
|
'hanging connections, see the implicit TLS setting EMAIL_USE_SSL.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_email_user_ssl = namespace.add_setting(
|
||||||
|
global_name='EMAIL_USE_SSL',
|
||||||
|
default=settings.EMAIL_USE_SSL,
|
||||||
|
help_text=_(
|
||||||
|
'Default: False. Whether to use an implicit TLS (secure) connection '
|
||||||
|
'when talking to the SMTP server. In most email documentation this '
|
||||||
|
'type of TLS connection is referred to as SSL. It is generally used '
|
||||||
|
'on port 465. If you are experiencing problems, see the explicit '
|
||||||
|
'TLS setting EMAIL_USE_TLS. Note that EMAIL_USE_TLS/EMAIL_USE_SSL '
|
||||||
|
'are mutually exclusive, so only set one of those settings to True.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_file_upload_max_memory_size = namespace.add_setting(
|
||||||
|
global_name='FILE_UPLOAD_MAX_MEMORY_SIZE',
|
||||||
|
default=settings.FILE_UPLOAD_MAX_MEMORY_SIZE,
|
||||||
|
help_text=_(
|
||||||
|
'Default: 2621440 (i.e. 2.5 MB). The maximum size (in bytes) '
|
||||||
|
'that an upload will be before it gets streamed to the file '
|
||||||
|
'system. See Managing files for details. See also '
|
||||||
|
'DATA_UPLOAD_MAX_MEMORY_SIZE.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_login_url = namespace.add_setting(
|
||||||
|
global_name='LOGIN_URL',
|
||||||
|
default=settings.LOGIN_URL,
|
||||||
|
help_text=_(
|
||||||
|
'Default: \'/accounts/login/\' The URL where requests are '
|
||||||
|
'redirected for login, especially when using the login_required() '
|
||||||
|
'decorator. This setting also accepts named URL patterns which '
|
||||||
|
'can be used to reduce configuration duplication since you '
|
||||||
|
'don\'t have to define the URL in two places (settings '
|
||||||
|
'and URLconf).'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
setting_django_login_redirect_url = namespace.add_setting(
|
||||||
|
global_name='LOGIN_REDIRECT_URL',
|
||||||
|
default=settings.LOGIN_REDIRECT_URL,
|
||||||
|
help_text=_(
|
||||||
|
'Default: \'/accounts/profile/\' The URL where requests are '
|
||||||
|
'redirected after login when the contrib.auth.login view gets no '
|
||||||
|
'next parameter. This is used by the login_required() decorator, '
|
||||||
|
'for example. This setting also accepts named URL patterns which '
|
||||||
|
'can be used to reduce configuration duplication since you don\'t '
|
||||||
|
'have to define the URL in two places (settings and URLconf).'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_logout_redirect_url = namespace.add_setting(
|
||||||
|
global_name='LOGOUT_REDIRECT_URL',
|
||||||
|
default=settings.LOGOUT_REDIRECT_URL,
|
||||||
|
help_text=_(
|
||||||
|
'Default: None. The URL where requests are redirected after a user '
|
||||||
|
'logs out using LogoutView (if the view doesn\'t get a next_page '
|
||||||
|
'argument). If None, no redirect will be performed and the logout '
|
||||||
|
'view will be rendered. This setting also accepts named URL '
|
||||||
|
'patterns which can be used to reduce configuration duplication '
|
||||||
|
'since you don\'t have to define the URL in two places (settings '
|
||||||
|
'and URLconf).'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
setting_django_internal_ips = namespace.add_setting(
|
||||||
|
global_name='INTERNAL_IPS',
|
||||||
|
default=settings.INTERNAL_IPS,
|
||||||
|
help_text=_(
|
||||||
|
'A list of IP addresses, as strings, that: Allow the debug() '
|
||||||
|
'context processor to add some variables to the template context. '
|
||||||
|
'Can use the admindocs bookmarklets even if not logged in as a '
|
||||||
|
'staff user. Are marked as "internal" (as opposed to "EXTERNAL") '
|
||||||
|
'in AdminEmailHandler emails.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_languages = namespace.add_setting(
|
||||||
|
global_name='LANGUAGES',
|
||||||
|
default=settings.LANGUAGES,
|
||||||
|
help_text=_(
|
||||||
|
'A list of all available languages. The list is a list of '
|
||||||
|
'two-tuples in the format (language code, language name) '
|
||||||
|
'for example, (\'ja\', \'Japanese\'). This specifies which '
|
||||||
|
'languages are available for language selection. '
|
||||||
|
'Generally, the default value should suffice. Only set this '
|
||||||
|
'setting if you want to restrict language selection to a '
|
||||||
|
'subset of the Django-provided languages. '
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_language_code = namespace.add_setting(
|
||||||
|
global_name='LANGUAGE_CODE',
|
||||||
|
default=settings.LANGUAGE_CODE,
|
||||||
|
help_text=_(
|
||||||
|
'A string representing the language code for this installation. '
|
||||||
|
'This should be in standard language ID format. For example, U.S. '
|
||||||
|
'English is "en-us". It serves two purposes: If the locale '
|
||||||
|
'middleware isn\'t in use, it decides which translation is served '
|
||||||
|
'to all users. If the locale middleware is active, it provides a '
|
||||||
|
'fallback language in case the user\'s preferred language can\'t '
|
||||||
|
'be determined or is not supported by the website. It also provides '
|
||||||
|
'the fallback translation when a translation for a given literal '
|
||||||
|
'doesn\'t exist for the user\'s preferred language.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_static_url = namespace.add_setting(
|
||||||
|
global_name='STATIC_URL',
|
||||||
|
default=settings.STATIC_URL,
|
||||||
|
help_text=_(
|
||||||
|
'URL to use when referring to static files located in STATIC_ROOT. '
|
||||||
|
'Example: "/static/" or "http://static.example.com/" '
|
||||||
|
'If not None, this will be used as the base path for asset '
|
||||||
|
'definitions (the Media class) and the staticfiles app. '
|
||||||
|
'It must end in a slash if set to a non-empty value.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_staticfiles_storage = namespace.add_setting(
|
||||||
|
global_name='STATICFILES_STORAGE',
|
||||||
|
default=settings.STATICFILES_STORAGE,
|
||||||
|
help_text=_(
|
||||||
|
'The file storage engine to use when collecting static files with '
|
||||||
|
'the collectstatic management command. A ready-to-use instance of '
|
||||||
|
'the storage backend defined in this setting can be found at '
|
||||||
|
'django.contrib.staticfiles.storage.staticfiles_storage.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_time_zone = namespace.add_setting(
|
||||||
|
global_name='TIME_ZONE',
|
||||||
|
default=settings.TIME_ZONE,
|
||||||
|
help_text=_(
|
||||||
|
'A string representing the time zone for this installation. '
|
||||||
|
'Note that this isn\'t necessarily the time zone of the server. '
|
||||||
|
'For example, one server may serve multiple Django-powered sites, '
|
||||||
|
'each with a separate time zone setting.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_django_wsgi_application = namespace.add_setting(
|
||||||
|
global_name='WSGI_APPLICATION',
|
||||||
|
default=settings.WSGI_APPLICATION,
|
||||||
|
help_text=_(
|
||||||
|
'The full Python path of the WSGI application object that Django\'s '
|
||||||
|
'built-in servers (e.g. runserver) will use. The django-admin '
|
||||||
|
'startproject management command will create a simple wsgi.py '
|
||||||
|
'file with an application callable in it, and point this setting '
|
||||||
|
'to that application.'
|
||||||
|
),
|
||||||
|
)
|
||||||
@@ -13,6 +13,7 @@ from .links import (
|
|||||||
link_queue_scheduled_task_list, link_queue_reserved_task_list,
|
link_queue_scheduled_task_list, link_queue_reserved_task_list,
|
||||||
link_task_manager
|
link_task_manager
|
||||||
)
|
)
|
||||||
|
from .settings import * # NOQA
|
||||||
|
|
||||||
|
|
||||||
class TaskManagerApp(MayanAppConfig):
|
class TaskManagerApp(MayanAppConfig):
|
||||||
|
|||||||
29
mayan/apps/task_manager/settings.py
Normal file
29
mayan/apps/task_manager/settings.py
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
|
from django.utils.translation import ugettext_lazy as _
|
||||||
|
|
||||||
|
from mayan.apps.smart_settings.classes import Namespace
|
||||||
|
|
||||||
|
# Don't import anything on start import, we just want to make it easy
|
||||||
|
# for apps.py to activate the settings in this module.
|
||||||
|
__all__ = ()
|
||||||
|
namespace = Namespace(label=_('Celery'), name='celery')
|
||||||
|
|
||||||
|
setting_celery_broker_url = namespace.add_setting(
|
||||||
|
global_name='BROKER_URL', default=None,
|
||||||
|
help_text=_(
|
||||||
|
'Default: "amqp://". Default broker URL. This must be a URL in '
|
||||||
|
'the form of: transport://userid:password@hostname:port/virtual_host '
|
||||||
|
'Only the scheme part (transport://) is required, the rest is '
|
||||||
|
'optional, and defaults to the specific transports default values.'
|
||||||
|
),
|
||||||
|
)
|
||||||
|
setting_celery_result_backend = namespace.add_setting(
|
||||||
|
global_name='CELERY_RESULT_BACKEND', default=None,
|
||||||
|
help_text=_(
|
||||||
|
'Default: No result backend enabled by default. The backend used '
|
||||||
|
'to store task results (tombstones). Refer to '
|
||||||
|
'http://docs.celeryproject.org/en/v4.1.0/userguide/configuration.'
|
||||||
|
'html#result-backend'
|
||||||
|
)
|
||||||
|
)
|
||||||
Reference in New Issue
Block a user