perf: 收集账号

pull/8931/head
feng626 2022-09-20 16:18:23 +08:00
parent 7b4c2ce97e
commit 615f36c6f6
10 changed files with 13 additions and 15 deletions

View File

@ -1,16 +1,16 @@
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
# #
import django_filters
from rest_framework.decorators import action from rest_framework.decorators import action
from rest_framework.response import Response from rest_framework.response import Response
import django_filters
from common.utils import get_logger
from common.drf.filters import BaseFilterSet from common.drf.filters import BaseFilterSet
from common.utils import get_logger, get_object_or_none
from common.mixins.api import SuggestionMixin from common.mixins.api import SuggestionMixin
from orgs.mixins.api import OrgBulkModelViewSet from orgs.mixins.api import OrgBulkModelViewSet
from orgs.mixins import generics from orgs.mixins import generics
from assets.models import Asset, Node, Gateway
from assets import serializers from assets import serializers
from assets.models import Asset, Gateway
from assets.tasks import ( from assets.tasks import (
update_assets_hardware_info_manual, test_assets_connectivity_manual, update_assets_hardware_info_manual, test_assets_connectivity_manual,
) )

View File

@ -232,7 +232,7 @@ class AllTypes(ChoicesMixin, metaclass=IncludesTextChoicesMeta):
@staticmethod @staticmethod
def serialize_to_objs(choices): def serialize_to_objs(choices):
title = ['value', 'display_name'] title = ['value', 'label']
return [dict(zip(title, choice)) for choice in choices] return [dict(zip(title, choice)) for choice in choices]
@staticmethod @staticmethod

View File

@ -20,7 +20,7 @@ class GatheredUser(OrgModelMixin):
date_updated = models.DateTimeField(auto_now=True, verbose_name=_("Date updated")) date_updated = models.DateTimeField(auto_now=True, verbose_name=_("Date updated"))
@property @property
def hostname(self): def name(self):
return self.asset.name return self.asset.name
@property @property

View File

@ -8,5 +8,5 @@ from .domain import *
from .gathered_user import * from .gathered_user import *
from .favorite_asset import * from .favorite_asset import *
from .account import * from .account import *
from .backup import * from assets.serializers.account.backup import *
from .platform import * from .platform import *

View File

@ -7,7 +7,7 @@ from orgs.mixins.serializers import BulkOrgResourceModelSerializer
from ops.mixin import PeriodTaskSerializerMixin from ops.mixin import PeriodTaskSerializerMixin
from common.utils import get_logger from common.utils import get_logger
from ..models import AccountBackupPlan, AccountBackupPlanExecution from assets.models import AccountBackupPlan, AccountBackupPlanExecution
logger = get_logger(__file__) logger = get_logger(__file__)

View File

@ -8,8 +8,7 @@ __all__ = ['AccountFieldsSerializerMixin']
class AccountFieldsSerializerMixin(serializers.ModelSerializer): class AccountFieldsSerializerMixin(serializers.ModelSerializer):
class Meta: class Meta:
fields_mini = [ fields_mini = [
'id', 'name', 'username', 'privileged', 'id', 'name', 'username', 'privileged', 'platform', 'version'
'platform', 'version'
] ]
fields_write_only = ['password', 'private_key', 'public_key', 'passphrase'] fields_write_only = ['password', 'private_key', 'public_key', 'passphrase']
fields_other = ['date_created', 'date_updated', 'comment'] fields_other = ['date_created', 'date_updated', 'comment']

View File

@ -12,11 +12,10 @@ class GatheredUserSerializer(OrgResourceModelSerializerMixin):
model = GatheredUser model = GatheredUser
fields_mini = ['id'] fields_mini = ['id']
fields_small = fields_mini + [ fields_small = fields_mini + [
'username', 'ip_last_login', 'username', 'ip_last_login', 'present', 'name',
'present',
'date_last_login', 'date_created', 'date_updated' 'date_last_login', 'date_created', 'date_updated'
] ]
fields_fk = ['asset', 'name', 'ip'] fields_fk = ['asset', 'ip']
fields = fields_small + fields_fk fields = fields_small + fields_fk
read_only_fields = fields read_only_fields = fields
extra_kwargs = { extra_kwargs = {

View File

@ -90,7 +90,7 @@ class AssetAccountHandler(BaseAccountHandler):
category_dict = {} category_dict = {}
for i in AllTypes.grouped_choices_to_objs(): for i in AllTypes.grouped_choices_to_objs():
for j in i['children']: for j in i['children']:
category_dict[j['value']] = j['display_name'] category_dict[j['value']] = j['label']
header_fields = cls.get_header_fields(AccountSecretSerializer(qs.first())) header_fields = cls.get_header_fields(AccountSecretSerializer(qs.first()))
account_category_map = defaultdict(list) account_category_map = defaultdict(list)

View File

@ -32,7 +32,7 @@ urlpatterns = [
path('mfa/verify/', api.MFAChallengeVerifyApi.as_view(), name='mfa-verify'), path('mfa/verify/', api.MFAChallengeVerifyApi.as_view(), name='mfa-verify'),
path('mfa/challenge/', api.MFAChallengeVerifyApi.as_view(), name='mfa-challenge'), path('mfa/challenge/', api.MFAChallengeVerifyApi.as_view(), name='mfa-challenge'),
path('mfa/select/', api.MFASendCodeApi.as_view(), name='mfa-select'), path('mfa/select/', api.MFASendCodeApi.as_view(), name='mfa-select'),
path('mfa/send-code/', api.MFASendCodeApi.as_view(), name='mfa-send-codej'), path('mfa/send-code/', api.MFASendCodeApi.as_view(), name='mfa-send-code'),
path('password/verify/', api.UserPasswordVerifyApi.as_view(), name='user-password-verify'), path('password/verify/', api.UserPasswordVerifyApi.as_view(), name='user-password-verify'),
path('login-confirm-ticket/status/', api.TicketStatusApi.as_view(), name='login-confirm-ticket-status'), path('login-confirm-ticket/status/', api.TicketStatusApi.as_view(), name='login-confirm-ticket-status'),
] ]

View File

@ -87,7 +87,7 @@ class CeleryTaskSerializer(serializers.Serializer):
class ChoiceSerializer(serializers.Serializer): class ChoiceSerializer(serializers.Serializer):
display_name = serializers.CharField(label=_("Display name")) label = serializers.CharField(label=_("Label"))
value = serializers.CharField(label=_("Value")) value = serializers.CharField(label=_("Value"))