serializer.py
2.1 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
from rest_framework import serializers
from .constants import EXTENSIONES_VALIDAS
from .models import Edicto, Precio, ComprobantePago
from usuario.serializers import UsuarioSerializer
class EdictoSerializer(serializers.ModelSerializer):
class Meta:
model = Edicto
fields = ('usuario',
'estado',
'cuerpo_edicto',
'cantidad_palabras',
'dias_publicar',
'cantidad_sellos',
'cantidad_copias',
'archivo',
'fecha_creacion',
'observaciones',
'fecha_publicacion',
)
included_serializers = {
'usuario': 'username.serializers.UsuarioListaSerializer',
}
read_only_fields = ('usuario', 'fecha_publicacion', 'cantidad_palabras', 'fecha_creacion')
def to_representation(self, instance):
data = super().to_representation(instance)
user = self.context['request'].user
if not user.is_staff:
data['fecha_publicacion'] = instance.fecha_publicacion
return data
@staticmethod
def validate_archivo(value):
filename, extension = value.name.rsplit(".", 1)
if extension.lower() not in EXTENSIONES_VALIDAS:
raise serializers.ValidationError("Archivos permitidos: .pdf")
return value
class PrecioSerializer(serializers.ModelSerializer):
usuario = UsuarioSerializer()
class Meta:
model = Precio
fields = ('usuario',
'moneda',
'precio',
'precio_ejemplar',
'vigencia_desde',
'vigencia_hasta',
)
def validate(self, data):
request = self.context.get('request')
user = request.user if request else None
if not user or user.is_anonymous:
raise serializers.ValidationError("El usuario debe estar autenticado.")
if not user.is_staff:
raise serializers.ValidationError("El usuario no es parte del personal designado.")
return data