from datetime import datetime
from . import BaseSchema
from marshmallow import fields, validate, RAISE, INCLUDE, EXCLUDE

class AddSchema(BaseSchema):
    name = fields.String(required=True, validate=validate.Length(min=2, max=50))

    class Meta:
        unknown = EXCLUDE

class UpdatePasswordSchema(BaseSchema):
    uuid = fields.UUID(required=True)
    password = fields.String(required=True, validate=validate.Length(min=6, max=50))
    newPassword = fields.String(required=True, validate=validate.Length(min=6, max=50))

    class Meta:
        unknown = EXCLUDE

class DeleteSchema(BaseSchema):
    class Meta:
        unknown = EXCLUDE

class QuerySchema(BaseSchema):
    uuid = fields.UUID(required=False)
    scope_type = fields.String(required=False)
    name = fields.String(required=False, validate=validate.Length(min=2, max=20))
    pagenum = fields.Int(required=False)
    pagesize = fields.Int(required=False, max=50) # 防止用户传特别大的数,导致数据库查询阻塞

    class Meta:
        unknown = EXCLUDE

class ResponseSchema(BaseSchema):
    uuid = fields.UUID(required=True)
    name = fields.String(required=True, validate=validate.Length(min=2, max=50))
    create_at = fields.DateTime(required=False, default=datetime.now)
    update_at = fields.DateTime(required=False, default=datetime.now)

    class Meta:
        unknown = INCLUDE

class GetRoleUser(BaseSchema):
    roles = fields.List(fields.String, required=True)

    class Meta:
        unknown = EXCLUDE

class ExportProject(BaseSchema):
    project = fields.List(fields.String, required=True)
    production = fields.List(fields.String, required=True)
    condition = fields.Dict(required=False)

    class Meta:
        unknown = EXCLUDE