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
3cdabaf8
Unverified
Commit
3cdabaf8
authored
Jul 26, 2019
by
BaiJiangJie
Committed by
GitHub
Jul 26, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[Update] 系统用户资产管理页面获取相关的所有资产 (#3038)
* [Update] 系统用户资产管理页面获取相关的所有资产 * [Update] 系统用户资产管理页面获取相关的所有资产2
parent
28f0302e
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
31 additions
and
15 deletions
+31
-15
asset_user.py
apps/assets/api/asset_user.py
+1
-1
asset.py
apps/assets/models/asset.py
+1
-1
user.py
apps/assets/models/user.py
+16
-0
signals_handler.py
apps/assets/signals_handler.py
+10
-10
tasks.py
apps/assets/tasks.py
+3
-3
No files found.
apps/assets/api/asset_user.py
View file @
3cdabaf8
...
...
@@ -81,7 +81,7 @@ class AssetUserViewSet(IDInCacheFilterMixin, BulkModelViewSet):
manager
=
AssetUserManager
()
if
system_user_id
:
system_user
=
get_object_or_404
(
SystemUser
,
id
=
system_user_id
)
assets
=
system_user
.
assets
.
all
()
assets
=
system_user
.
get_all_assets
()
username
=
system_user
.
username
elif
admin_user_id
:
admin_user
=
get_object_or_404
(
AdminUser
,
id
=
admin_user_id
)
...
...
apps/assets/models/asset.py
View file @
3cdabaf8
...
...
@@ -12,7 +12,6 @@ from django.core.cache import cache
from
django.db
import
models
from
django.utils.translation
import
ugettext_lazy
as
_
from
.user
import
AdminUser
,
SystemUser
from
.utils
import
Connectivity
from
orgs.mixins
import
OrgModelMixin
,
OrgManager
...
...
@@ -320,6 +319,7 @@ class Asset(ProtocolsMixin, NodesRelationMixin, OrgModelMixin):
@classmethod
def
generate_fake
(
cls
,
count
=
100
):
from
.user
import
AdminUser
,
SystemUser
from
random
import
seed
,
choice
from
django.db
import
IntegrityError
from
.node
import
Node
...
...
apps/assets/models/user.py
View file @
3cdabaf8
...
...
@@ -4,12 +4,15 @@
import
logging
from
functools
import
reduce
from
django.db
import
models
from
django.db.models
import
Q
from
django.utils.translation
import
ugettext_lazy
as
_
from
django.core.validators
import
MinValueValidator
,
MaxValueValidator
from
common.utils
import
get_signer
from
.base
import
AssetUser
from
.asset
import
Asset
__all__
=
[
'AdminUser'
,
'SystemUser'
]
...
...
@@ -144,6 +147,19 @@ class SystemUser(AssetUser):
return
False
,
matched_cmd
return
True
,
None
def
get_all_assets
(
self
):
args
=
[
Q
(
systemuser
=
self
)]
pattern
=
set
()
nodes_keys
=
self
.
nodes
.
all
()
.
values_list
(
'key'
,
flat
=
True
)
for
key
in
nodes_keys
:
pattern
.
add
(
r'^{0}$|^{0}:'
.
format
(
key
))
pattern
=
'|'
.
join
(
list
(
pattern
))
if
pattern
:
args
.
append
(
Q
(
nodes__key__regex
=
pattern
))
args
=
reduce
(
lambda
x
,
y
:
x
|
y
,
args
)
assets
=
Asset
.
objects
.
filter
(
args
)
.
distinct
()
return
assets
class
Meta
:
ordering
=
[
'name'
]
unique_together
=
[(
'name'
,
'org_id'
)]
...
...
apps/assets/signals_handler.py
View file @
3cdabaf8
...
...
@@ -57,16 +57,16 @@ def on_system_user_update(sender, instance=None, created=True, **kwargs):
push_system_user_to_assets
.
delay
(
instance
,
assets
)
@receiver
(
m2m_changed
,
sender
=
SystemUser
.
nodes
.
through
)
def
on_system_user_nodes_change
(
sender
,
instance
=
None
,
**
kwargs
):
if
instance
and
kwargs
[
"action"
]
==
"post_add"
:
logger
.
info
(
"System user `{}` nodes update signal received"
.
format
(
instance
))
assets
=
set
()
nodes
=
kwargs
[
'model'
]
.
objects
.
filter
(
pk__in
=
kwargs
[
'pk_set'
])
for
node
in
nodes
:
assets
.
update
(
set
(
node
.
get_all_assets
()))
instance
.
assets
.
add
(
*
tuple
(
assets
))
#
@receiver(m2m_changed, sender=SystemUser.nodes.through)
#
def on_system_user_nodes_change(sender, instance=None, **kwargs):
#
if instance and kwargs["action"] == "post_add":
#
logger.info("System user `{}` nodes update signal received".format(instance))
#
assets = set()
#
nodes = kwargs['model'].objects.filter(pk__in=kwargs['pk_set'])
#
for node in nodes:
#
assets.update(set(node.get_all_assets()))
#
instance.assets.add(*tuple(assets))
#
@receiver
(
m2m_changed
,
sender
=
SystemUser
.
assets
.
through
)
def
on_system_user_assets_change
(
sender
,
instance
=
None
,
**
kwargs
):
...
...
apps/assets/tasks.py
View file @
3cdabaf8
...
...
@@ -347,7 +347,7 @@ def test_system_user_connectivity_util(system_user, assets, task_name):
@shared_task
def
test_system_user_connectivity_manual
(
system_user
):
task_name
=
_
(
"Test system user connectivity: {}"
)
.
format
(
system_user
)
assets
=
system_user
.
get_
related
_assets
()
assets
=
system_user
.
get_
all
_assets
()
return
test_system_user_connectivity_util
(
system_user
,
assets
,
task_name
)
...
...
@@ -367,7 +367,7 @@ def test_system_user_connectivity_period():
system_users
=
SystemUser
.
objects
.
all
()
for
system_user
in
system_users
:
task_name
=
_
(
"Test system user connectivity period: {}"
)
.
format
(
system_user
)
assets
=
system_user
.
get_
related
_assets
()
assets
=
system_user
.
get_
all
_assets
()
test_system_user_connectivity_util
(
system_user
,
assets
,
task_name
)
...
...
@@ -513,7 +513,7 @@ def push_system_user_util(system_user, assets, task_name):
@shared_task
def
push_system_user_to_assets_manual
(
system_user
):
assets
=
system_user
.
get_
related
_assets
()
assets
=
system_user
.
get_
all
_assets
()
task_name
=
_
(
"Push system users to assets: {}"
)
.
format
(
system_user
.
name
)
return
push_system_user_util
(
system_user
,
assets
,
task_name
=
task_name
)
...
...
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