Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
J
jumpserver
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
ops
jumpserver
Commits
2391ce2d
Commit
2391ce2d
authored
Aug 12, 2019
by
jym503558564
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[Update] 修改小问题
parent
18d4d663
Hide whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
49 additions
and
44 deletions
+49
-44
views.py
apps/audits/views.py
+5
-5
views.py
apps/jumpserver/views.py
+3
-3
models.py
apps/orgs/models.py
+33
-28
asset_permission.py
apps/perms/forms/asset_permission.py
+1
-1
remote_app_permission.py
apps/perms/forms/remote_app_permission.py
+1
-1
asset_permission.py
apps/perms/views/asset_permission.py
+1
-1
remote_app_permission.py
apps/perms/views/remote_app_permission.py
+1
-1
user.py
apps/users/api/user.py
+1
-1
forms.py
apps/users/forms.py
+1
-1
group.py
apps/users/views/group.py
+1
-1
user.py
apps/users/views/user.py
+1
-1
No files found.
apps/audits/views.py
View file @
2391ce2d
...
@@ -119,7 +119,7 @@ class OperateLogListView(PermissionsMixin, DatetimeSearchMixin, ListView):
...
@@ -119,7 +119,7 @@ class OperateLogListView(PermissionsMixin, DatetimeSearchMixin, ListView):
def
get_context_data
(
self
,
**
kwargs
):
def
get_context_data
(
self
,
**
kwargs
):
context
=
{
context
=
{
'user_list'
:
current_org
.
get_org_
users_and_audito
rs
(),
'user_list'
:
current_org
.
get_org_
membe
rs
(),
'actions'
:
self
.
actions_dict
,
'actions'
:
self
.
actions_dict
,
'resource_type_list'
:
get_resource_type_list
(),
'resource_type_list'
:
get_resource_type_list
(),
'date_from'
:
self
.
date_from
,
'date_from'
:
self
.
date_from
,
...
@@ -142,7 +142,7 @@ class PasswordChangeLogList(PermissionsMixin, DatetimeSearchMixin, ListView):
...
@@ -142,7 +142,7 @@ class PasswordChangeLogList(PermissionsMixin, DatetimeSearchMixin, ListView):
permission_classes
=
[
IsOrgAdmin
|
IsAuditor
]
permission_classes
=
[
IsOrgAdmin
|
IsAuditor
]
def
get_queryset
(
self
):
def
get_queryset
(
self
):
users
=
current_org
.
get_org_
users_and_audito
rs
()
users
=
current_org
.
get_org_
membe
rs
()
self
.
queryset
=
super
()
.
get_queryset
()
.
filter
(
self
.
queryset
=
super
()
.
get_queryset
()
.
filter
(
user__in
=
[
user
.
__str__
()
for
user
in
users
]
user__in
=
[
user
.
__str__
()
for
user
in
users
]
)
)
...
@@ -159,7 +159,7 @@ class PasswordChangeLogList(PermissionsMixin, DatetimeSearchMixin, ListView):
...
@@ -159,7 +159,7 @@ class PasswordChangeLogList(PermissionsMixin, DatetimeSearchMixin, ListView):
def
get_context_data
(
self
,
**
kwargs
):
def
get_context_data
(
self
,
**
kwargs
):
context
=
{
context
=
{
'user_list'
:
current_org
.
get_org_
users_and_audito
rs
(),
'user_list'
:
current_org
.
get_org_
membe
rs
(),
'date_from'
:
self
.
date_from
,
'date_from'
:
self
.
date_from
,
'date_to'
:
self
.
date_to
,
'date_to'
:
self
.
date_to
,
'user'
:
self
.
user
,
'user'
:
self
.
user
,
...
@@ -180,7 +180,7 @@ class LoginLogListView(PermissionsMixin, DatetimeSearchMixin, ListView):
...
@@ -180,7 +180,7 @@ class LoginLogListView(PermissionsMixin, DatetimeSearchMixin, ListView):
@staticmethod
@staticmethod
def
get_org_users
():
def
get_org_users
():
users
=
current_org
.
get_org_
users_and_audito
rs
()
.
values_list
(
'username'
,
flat
=
True
)
users
=
current_org
.
get_org_
membe
rs
()
.
values_list
(
'username'
,
flat
=
True
)
return
users
return
users
def
get_queryset
(
self
):
def
get_queryset
(
self
):
...
@@ -234,7 +234,7 @@ class CommandExecutionListView(UserCommandExecutionListView):
...
@@ -234,7 +234,7 @@ class CommandExecutionListView(UserCommandExecutionListView):
return
queryset
return
queryset
def
get_user_list
(
self
):
def
get_user_list
(
self
):
users
=
current_org
.
get_org_
users_exclude_au
ditors
()
users
=
current_org
.
get_org_
members_exclude_an
ditors
()
return
users
return
users
def
get_context_data
(
self
,
**
kwargs
):
def
get_context_data
(
self
,
**
kwargs
):
...
...
apps/jumpserver/views.py
View file @
2391ce2d
...
@@ -45,7 +45,7 @@ class IndexView(PermissionsMixin, TemplateView):
...
@@ -45,7 +45,7 @@ class IndexView(PermissionsMixin, TemplateView):
@staticmethod
@staticmethod
def
get_user_count
():
def
get_user_count
():
return
current_org
.
get_org_
users_and_audito
rs
()
.
count
()
return
current_org
.
get_org_
membe
rs
()
.
count
()
@staticmethod
@staticmethod
def
get_asset_count
():
def
get_asset_count
():
...
@@ -100,7 +100,7 @@ class IndexView(PermissionsMixin, TemplateView):
...
@@ -100,7 +100,7 @@ class IndexView(PermissionsMixin, TemplateView):
return
self
.
session_month
.
values
(
'user'
)
.
distinct
()
.
count
()
return
self
.
session_month
.
values
(
'user'
)
.
distinct
()
.
count
()
def
get_month_inactive_user_total
(
self
):
def
get_month_inactive_user_total
(
self
):
count
=
current_org
.
get_org_
users_and_audito
rs
()
.
count
()
-
self
.
get_month_active_user_total
()
count
=
current_org
.
get_org_
membe
rs
()
.
count
()
-
self
.
get_month_active_user_total
()
if
count
<
0
:
if
count
<
0
:
count
=
0
count
=
0
return
count
return
count
...
@@ -116,7 +116,7 @@ class IndexView(PermissionsMixin, TemplateView):
...
@@ -116,7 +116,7 @@ class IndexView(PermissionsMixin, TemplateView):
@staticmethod
@staticmethod
def
get_user_disabled_total
():
def
get_user_disabled_total
():
return
current_org
.
get_org_
users_and_audito
rs
()
.
filter
(
is_active
=
False
)
.
count
()
return
current_org
.
get_org_
membe
rs
()
.
filter
(
is_active
=
False
)
.
count
()
@staticmethod
@staticmethod
def
get_asset_disabled_total
():
def
get_asset_disabled_total
():
...
...
apps/orgs/models.py
View file @
2391ce2d
...
@@ -67,35 +67,20 @@ class Organization(models.Model):
...
@@ -67,35 +67,20 @@ class Organization(models.Model):
org
=
cls
.
default
()
if
default
else
None
org
=
cls
.
default
()
if
default
else
None
return
org
return
org
def
get_org_users
(
self
,
include_app
=
False
):
# def get_org_users(self, include_app=False):
from
users.models
import
User
# from users.models import User
if
self
.
is_real
():
# if self.is_real():
users
=
self
.
users
.
all
()
# users = self.users.all()
else
:
# else:
users
=
User
.
objects
.
all
()
# users = User.objects.all()
if
not
include_app
:
# if not include_app:
users
=
users
.
exclude
(
role
=
User
.
ROLE_APP
)
# users = users.exclude(role=User.ROLE_APP)
return
users
# return users
def
get_org_users_and_auditors
(
self
,
include_app
=
False
):
def
get_org_users
(
self
):
from
users.models
import
User
if
self
.
is_real
():
if
self
.
is_real
():
users
=
self
.
users
.
all
()
|
self
.
auditors
.
all
()
return
self
.
users
.
all
()
else
:
return
[]
users
=
User
.
objects
.
all
()
if
not
include_app
:
users
=
users
.
exclude
(
role
=
User
.
ROLE_APP
)
return
users
def
get_org_users_exclude_auditors
(
self
,
include_app
=
False
):
from
users.models
import
User
if
self
.
is_real
():
users
=
self
.
users
.
all
()
else
:
users
=
User
.
objects
.
exclude
(
role
=
User
.
ROLE_AUDITOR
)
if
not
include_app
:
users
=
users
.
exclude
(
role
=
User
.
ROLE_APP
)
return
users
def
get_org_admins
(
self
):
def
get_org_admins
(
self
):
if
self
.
is_real
():
if
self
.
is_real
():
...
@@ -107,6 +92,26 @@ class Organization(models.Model):
...
@@ -107,6 +92,26 @@ class Organization(models.Model):
return
self
.
auditors
.
all
()
return
self
.
auditors
.
all
()
return
[]
return
[]
def
get_org_members
(
self
,
include_app
=
False
):
from
users.models
import
User
if
self
.
is_real
():
members
=
self
.
users
.
all
()
|
self
.
auditors
.
all
()
else
:
members
=
User
.
objects
.
all
()
if
not
include_app
:
members
=
members
.
exclude
(
role
=
User
.
ROLE_APP
)
return
members
def
get_org_members_exclude_auditors
(
self
,
include_app
=
False
):
from
users.models
import
User
if
self
.
is_real
():
members_exclude_auditors
=
self
.
users
.
all
()
else
:
members_exclude_auditors
=
User
.
objects
.
exclude
(
role
=
User
.
ROLE_AUDITOR
)
if
not
include_app
:
members_exclude_auditors
=
members_exclude_auditors
.
exclude
(
role
=
User
.
ROLE_APP
)
return
members_exclude_auditors
def
can_admin_by
(
self
,
user
):
def
can_admin_by
(
self
,
user
):
if
user
.
is_superuser
:
if
user
.
is_superuser
:
return
True
return
True
...
...
apps/perms/forms/asset_permission.py
View file @
2391ce2d
...
@@ -39,7 +39,7 @@ class AssetPermissionForm(OrgModelForm):
...
@@ -39,7 +39,7 @@ class AssetPermissionForm(OrgModelForm):
def
__init__
(
self
,
*
args
,
**
kwargs
):
def
__init__
(
self
,
*
args
,
**
kwargs
):
super
()
.
__init__
(
*
args
,
**
kwargs
)
super
()
.
__init__
(
*
args
,
**
kwargs
)
users_field
=
self
.
fields
.
get
(
'users'
)
users_field
=
self
.
fields
.
get
(
'users'
)
users_field
.
queryset
=
current_org
.
get_org_
users_exclude_au
ditors
()
users_field
.
queryset
=
current_org
.
get_org_
members_exclude_an
ditors
()
nodes_field
=
self
.
fields
[
'nodes'
]
nodes_field
=
self
.
fields
[
'nodes'
]
nodes_field
.
choices
=
((
n
.
id
,
n
.
full_value
)
for
n
in
Node
.
get_queryset
())
nodes_field
.
choices
=
((
n
.
id
,
n
.
full_value
)
for
n
in
Node
.
get_queryset
())
...
...
apps/perms/forms/remote_app_permission.py
View file @
2391ce2d
...
@@ -19,7 +19,7 @@ class RemoteAppPermissionCreateUpdateForm(OrgModelForm):
...
@@ -19,7 +19,7 @@ class RemoteAppPermissionCreateUpdateForm(OrgModelForm):
super
()
.
__init__
(
*
args
,
**
kwargs
)
super
()
.
__init__
(
*
args
,
**
kwargs
)
users_field
=
self
.
fields
.
get
(
'users'
)
users_field
=
self
.
fields
.
get
(
'users'
)
if
hasattr
(
users_field
,
'queryset'
):
if
hasattr
(
users_field
,
'queryset'
):
users_field
.
queryset
=
current_org
.
get_org_
users_exclude_au
ditors
()
users_field
.
queryset
=
current_org
.
get_org_
members_exclude_an
ditors
()
class
Meta
:
class
Meta
:
model
=
RemoteAppPermission
model
=
RemoteAppPermission
...
...
apps/perms/views/asset_permission.py
View file @
2391ce2d
...
@@ -135,7 +135,7 @@ class AssetPermissionUserView(PermissionsMixin,
...
@@ -135,7 +135,7 @@ class AssetPermissionUserView(PermissionsMixin,
context
=
{
context
=
{
'app'
:
_
(
'Perms'
),
'app'
:
_
(
'Perms'
),
'action'
:
_
(
'Asset permission user list'
),
'action'
:
_
(
'Asset permission user list'
),
'users_remain'
:
current_org
.
get_org_
users_exclude_au
ditors
()
.
exclude
(
'users_remain'
:
current_org
.
get_org_
members_exclude_an
ditors
()
.
exclude
(
assetpermission
=
self
.
object
assetpermission
=
self
.
object
),
),
'user_groups_remain'
:
UserGroup
.
objects
.
exclude
(
'user_groups_remain'
:
UserGroup
.
objects
.
exclude
(
...
...
apps/perms/views/remote_app_permission.py
View file @
2391ce2d
...
@@ -107,7 +107,7 @@ class RemoteAppPermissionUserView(PermissionsMixin,
...
@@ -107,7 +107,7 @@ class RemoteAppPermissionUserView(PermissionsMixin,
context
=
{
context
=
{
'app'
:
_
(
'Perms'
),
'app'
:
_
(
'Perms'
),
'action'
:
_
(
'RemoteApp permission user list'
),
'action'
:
_
(
'RemoteApp permission user list'
),
'users_remain'
:
current_org
.
get_org_
users_exclude_au
ditors
()
.
exclude
(
'users_remain'
:
current_org
.
get_org_
members_exclude_an
ditors
()
.
exclude
(
remoteapppermission
=
self
.
object
remoteapppermission
=
self
.
object
),
),
'user_groups_remain'
:
UserGroup
.
objects
.
exclude
(
'user_groups_remain'
:
UserGroup
.
objects
.
exclude
(
...
...
apps/users/api/user.py
View file @
2391ce2d
...
@@ -60,7 +60,7 @@ class UserViewSet(IDInCacheFilterMixin, BulkModelViewSet):
...
@@ -60,7 +60,7 @@ class UserViewSet(IDInCacheFilterMixin, BulkModelViewSet):
self
.
send_created_signal
(
users
)
self
.
send_created_signal
(
users
)
def
get_queryset
(
self
):
def
get_queryset
(
self
):
queryset
=
current_org
.
get_org_
users_and_audito
rs
()
.
prefetch_related
(
'groups'
)
queryset
=
current_org
.
get_org_
membe
rs
()
.
prefetch_related
(
'groups'
)
return
queryset
return
queryset
def
get_permissions
(
self
):
def
get_permissions
(
self
):
...
...
apps/users/forms.py
View file @
2391ce2d
...
@@ -335,7 +335,7 @@ class UserGroupForm(OrgModelForm):
...
@@ -335,7 +335,7 @@ class UserGroupForm(OrgModelForm):
return
return
users_field
=
self
.
fields
.
get
(
'users'
)
users_field
=
self
.
fields
.
get
(
'users'
)
if
hasattr
(
users_field
,
'queryset'
):
if
hasattr
(
users_field
,
'queryset'
):
users_field
.
queryset
=
current_org
.
get_org_
us
ers_exclude_auditors
()
users_field
.
queryset
=
current_org
.
get_org_
memb
ers_exclude_auditors
()
def
save
(
self
,
commit
=
True
):
def
save
(
self
,
commit
=
True
):
group
=
super
()
.
save
(
commit
=
commit
)
group
=
super
()
.
save
(
commit
=
commit
)
...
...
apps/users/views/group.py
View file @
2391ce2d
...
@@ -76,7 +76,7 @@ class UserGroupDetailView(PermissionsMixin, DetailView):
...
@@ -76,7 +76,7 @@ class UserGroupDetailView(PermissionsMixin, DetailView):
permission_classes
=
[
IsOrgAdmin
]
permission_classes
=
[
IsOrgAdmin
]
def
get_context_data
(
self
,
**
kwargs
):
def
get_context_data
(
self
,
**
kwargs
):
users
=
current_org
.
get_org_
users_exclude_au
ditors
()
.
exclude
(
id__in
=
self
.
object
.
users
.
all
())
users
=
current_org
.
get_org_
members_exclude_an
ditors
()
.
exclude
(
id__in
=
self
.
object
.
users
.
all
())
context
=
{
context
=
{
'app'
:
_
(
'Users'
),
'app'
:
_
(
'Users'
),
'action'
:
_
(
'User group detail'
),
'action'
:
_
(
'User group detail'
),
...
...
apps/users/views/user.py
View file @
2391ce2d
...
@@ -195,7 +195,7 @@ class UserDetailView(PermissionsMixin, DetailView):
...
@@ -195,7 +195,7 @@ class UserDetailView(PermissionsMixin, DetailView):
def
get_queryset
(
self
):
def
get_queryset
(
self
):
queryset
=
super
()
.
get_queryset
()
queryset
=
super
()
.
get_queryset
()
org_users
=
current_org
.
get_org_
users_and_audito
rs
()
.
values_list
(
'id'
,
flat
=
True
)
org_users
=
current_org
.
get_org_
membe
rs
()
.
values_list
(
'id'
,
flat
=
True
)
queryset
=
queryset
.
filter
(
id__in
=
org_users
)
queryset
=
queryset
.
filter
(
id__in
=
org_users
)
return
queryset
return
queryset
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment