Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
gjl2004yn
jumpserver
提交
7ebe1c29
J
jumpserver
项目概览
gjl2004yn
/
jumpserver
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
jumpserver
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
7ebe1c29
编写于
6月 16, 2020
作者:
X
xinwen
提交者:
GitHub
6月 16, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[Update] 优化 dynamic settings (#4107)
上级
08904c2a
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
37 addition
and
2 deletion
+37
-2
apps/jumpserver/const.py
apps/jumpserver/const.py
+35
-1
apps/users/models/user.py
apps/users/models/user.py
+2
-1
未找到文件。
apps/jumpserver/const.py
浏览文件 @
7ebe1c29
# -*- coding: utf-8 -*-
#
import
os
from
werkzeug.local
import
LocalProxy
from
.conf
import
ConfigManager
from
common.local
import
thread_local
__all__
=
[
'BASE_DIR'
,
'PROJECT_DIR'
,
'VERSION'
,
'CONFIG'
,
'DYNAMIC'
]
__all__
=
[
'BASE_DIR'
,
'PROJECT_DIR'
,
'VERSION'
,
'CONFIG'
,
'DYNAMIC'
,
'LOCAL_DYNAMIC_SETTINGS'
]
BASE_DIR
=
os
.
path
.
dirname
(
os
.
path
.
dirname
(
os
.
path
.
abspath
(
__file__
)))
PROJECT_DIR
=
os
.
path
.
dirname
(
BASE_DIR
)
VERSION
=
'2.0.0'
CONFIG
=
ConfigManager
.
load_user_config
()
DYNAMIC
=
ConfigManager
.
get_dynamic_config
(
CONFIG
)
class
_Settings
:
pass
def
get_dynamic_cfg_from_thread_local
():
KEY
=
'dynamic_config'
try
:
cfg
=
getattr
(
thread_local
,
KEY
)
except
AttributeError
:
cfg
=
_Settings
()
setattr
(
thread_local
,
KEY
,
cfg
)
return
cfg
class
DynamicDefaultLocalProxy
(
LocalProxy
):
def
__getattr__
(
self
,
item
):
try
:
value
=
super
().
__getattr__
(
item
)
except
AttributeError
:
value
=
getattr
(
DYNAMIC
,
item
)()
setattr
(
self
,
item
,
value
)
return
value
LOCAL_DYNAMIC_SETTINGS
=
DynamicDefaultLocalProxy
(
get_dynamic_cfg_from_thread_local
)
apps/users/models/user.py
浏览文件 @
7ebe1c29
...
...
@@ -16,6 +16,7 @@ from django.utils.translation import ugettext_lazy as _
from
django.utils
import
timezone
from
django.shortcuts
import
reverse
from
jumpserver.const
import
LOCAL_DYNAMIC_SETTINGS
from
orgs.utils
import
current_org
from
common.utils
import
signer
,
date_expired_default
,
get_logger
,
lazyproperty
from
common
import
fields
...
...
@@ -394,7 +395,7 @@ class MFAMixin:
@
property
def
mfa_force_enabled
(
self
):
if
settings
.
SECURITY_MFA_AUTH
:
if
LOCAL_DYNAMIC_SETTINGS
.
SECURITY_MFA_AUTH
:
return
True
return
self
.
mfa_level
==
2
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录