mirror of https://github.com/jumpserver/jumpserver
33 lines
1.1 KiB
Python
33 lines
1.1 KiB
Python
# -*- coding: utf-8 -*-
|
|
#
|
|
from django.db import models
|
|
|
|
from common.mixins.models import CommonModelMixin
|
|
|
|
|
|
__all__ = ['FavoriteAsset']
|
|
|
|
|
|
class FavoriteAsset(CommonModelMixin):
|
|
user = models.ForeignKey('users.User', on_delete=models.CASCADE)
|
|
asset = models.ForeignKey('assets.Asset', on_delete=models.CASCADE)
|
|
|
|
class Meta:
|
|
unique_together = ('user', 'asset')
|
|
|
|
@classmethod
|
|
def get_user_favorite_assets_id(cls, user):
|
|
return cls.objects.filter(user=user).values_list('asset', flat=True)
|
|
|
|
@classmethod
|
|
def get_user_favorite_assets(cls, user, asset_perms_id=None):
|
|
from assets.models import Asset
|
|
from perms.utils.asset.user_permission import get_user_granted_all_assets
|
|
asset_ids = get_user_granted_all_assets(
|
|
user,
|
|
via_mapping_node=False,
|
|
asset_perms_id=asset_perms_id
|
|
).values_list('id', flat=True)
|
|
query_name = cls.asset.field.related_query_name()
|
|
return Asset.org_objects.filter(**{f'{query_name}__user_id': user.id}, id__in=asset_ids).distinct()
|