2023-01-16 11:02:09 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
from django.utils.translation import ugettext_lazy as _
|
|
|
|
from rest_framework import serializers
|
|
|
|
|
|
|
|
from accounts.const import SecretType
|
|
|
|
from accounts.models import BaseAccount
|
|
|
|
from accounts.utils import validate_password_for_ansible, validate_ssh_key
|
|
|
|
from common.serializers.fields import EncryptedField, LabeledChoiceField
|
|
|
|
from orgs.mixins.serializers import BulkOrgResourceModelSerializer
|
|
|
|
|
|
|
|
__all__ = ['AuthValidateMixin', 'BaseAccountSerializer']
|
|
|
|
|
|
|
|
|
|
|
|
class AuthValidateMixin(serializers.Serializer):
|
|
|
|
secret_type = LabeledChoiceField(
|
|
|
|
choices=SecretType.choices, required=True, label=_('Secret type')
|
|
|
|
)
|
|
|
|
secret = EncryptedField(
|
2023-01-31 08:05:28 +00:00
|
|
|
label=_('Secret/Password'), required=False, max_length=40960, allow_blank=True,
|
2023-01-16 11:02:09 +00:00
|
|
|
allow_null=True, write_only=True,
|
|
|
|
)
|
|
|
|
passphrase = serializers.CharField(
|
|
|
|
allow_blank=True, allow_null=True, required=False, max_length=512,
|
|
|
|
write_only=True, label=_('Key password')
|
|
|
|
)
|
|
|
|
|
2023-02-15 12:16:01 +00:00
|
|
|
@staticmethod
|
|
|
|
def handle_secret(secret, secret_type, passphrase=None):
|
2023-01-16 11:02:09 +00:00
|
|
|
if not secret:
|
|
|
|
return ''
|
|
|
|
if secret_type == SecretType.PASSWORD:
|
|
|
|
validate_password_for_ansible(secret)
|
|
|
|
return secret
|
|
|
|
elif secret_type == SecretType.SSH_KEY:
|
|
|
|
passphrase = passphrase if passphrase else None
|
|
|
|
return validate_ssh_key(secret, passphrase)
|
|
|
|
else:
|
|
|
|
return secret
|
|
|
|
|
2023-02-15 12:16:01 +00:00
|
|
|
def clean_auth_fields(self, validated_data):
|
2023-02-20 12:22:26 +00:00
|
|
|
secret_type = validated_data.pop('secret_type', None)
|
2023-02-15 12:16:01 +00:00
|
|
|
passphrase = validated_data.get('passphrase')
|
|
|
|
secret = validated_data.pop('secret', None)
|
|
|
|
self.handle_secret(secret, secret_type, passphrase)
|
|
|
|
validated_data['secret'] = secret
|
2023-01-16 11:02:09 +00:00
|
|
|
for field in ('secret',):
|
|
|
|
value = validated_data.get(field)
|
2023-02-16 06:27:54 +00:00
|
|
|
if not value:
|
2023-01-16 11:02:09 +00:00
|
|
|
validated_data.pop(field, None)
|
|
|
|
validated_data.pop('passphrase', None)
|
|
|
|
|
|
|
|
def create(self, validated_data):
|
|
|
|
self.clean_auth_fields(validated_data)
|
|
|
|
return super().create(validated_data)
|
|
|
|
|
|
|
|
def update(self, instance, validated_data):
|
|
|
|
self.clean_auth_fields(validated_data)
|
|
|
|
return super().update(instance, validated_data)
|
|
|
|
|
|
|
|
|
|
|
|
class BaseAccountSerializer(AuthValidateMixin, BulkOrgResourceModelSerializer):
|
|
|
|
has_secret = serializers.BooleanField(label=_("Has secret"), read_only=True)
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
model = BaseAccount
|
|
|
|
fields_mini = ['id', 'name', 'username']
|
|
|
|
fields_small = fields_mini + [
|
|
|
|
'secret_type', 'secret', 'has_secret', 'passphrase',
|
2023-01-31 10:06:44 +00:00
|
|
|
'privileged', 'is_active', 'spec_info',
|
2023-01-16 11:02:09 +00:00
|
|
|
]
|
|
|
|
fields_other = ['created_by', 'date_created', 'date_updated', 'comment']
|
|
|
|
fields = fields_small + fields_other
|
|
|
|
read_only_fields = [
|
2023-01-31 10:06:44 +00:00
|
|
|
'has_secret', 'spec_info',
|
2023-01-16 11:02:09 +00:00
|
|
|
'date_verified', 'created_by', 'date_created',
|
|
|
|
]
|
|
|
|
extra_kwargs = {
|
2023-02-14 03:37:18 +00:00
|
|
|
'name': {'required': True},
|
2023-01-31 10:06:44 +00:00
|
|
|
'spec_info': {'label': _('Spec info')},
|
2023-01-16 11:02:09 +00:00
|
|
|
}
|