app.py 5.72 KB
Newer Older
wanli's avatar
wanli committed
1 2 3
# -*- coding: utf-8 -*-

from application.app import db, ma
4
from .base import PrimaryModel
wanli's avatar
wanli committed
5 6 7 8 9
from marshmallow import Schema, fields, INCLUDE, EXCLUDE

class AppModel(PrimaryModel):
    __tablename__ = 'evm_app'

wanli's avatar
wanli committed
10 11 12
    app_name = db.Column(db.String(70), index = True, nullable = False)
    app_icon = db.Column(db.String(200), nullable = False)
    app_version = db.Column(db.String(20), nullable = False)
13 14 15 16
    category = db.Column(db.String(50), nullable = False)
    category_2th = db.Column(db.String(50), nullable = False)
    developer = db.Column(db.String(50), nullable = False)
    download_url = db.Column(db.String(200), nullable = False, default = '')
wanli's avatar
wanli committed
17
    app_file_size = db.Column(db.Integer, nullable = False)
18
    app_screen_size = db.Column(db.String(20), nullable = False)
wanli's avatar
wanli committed
19
    app_arch = db.Column(db.String(20), nullable = False, default = '')
20
    app_review = db.Column(db.Integer, nullable = False, default = 0)
wanli's avatar
wanli committed
21 22 23 24 25

    # __table_args__ = (
    #     db.Index('idx_xxx', 'xxx', mysql_using='btree'),
    # )

26
    def __init__(self, app_name, app_icon, app_version, category='', category_2th='', developer=0, download_url='', app_file_size=0, app_screen_size='', app_arch='', app_review=0, create_by=None, create_at=None, update_by=None, update_at=None, remarks=""):
wanli's avatar
wanli committed
27 28 29 30 31 32 33 34 35 36 37
        self.app_name = app_name
        self.app_icon = app_icon
        self.app_version = app_version
        self.category = category
        self.category_2th = category_2th
        self.developer = developer
        self.download_url = download_url
        self.app_file_size = app_file_size
        self.app_screen_size = app_screen_size
        self.app_arch = app_arch
        self.app_review = app_review
38 39 40 41 42
        self.create_by = create_by
        self.create_at = create_at
        self.update_by = update_by
        self.update_at = update_at
        self.remarks = remarks
wanli's avatar
wanli committed
43 44 45 46

    def __repr__(self):
        return '<AppModel %r>' % (self.app_name)

47
    def to_dict(self):
wanli's avatar
wanli committed
48 49 50 51 52 53 54 55 56 57 58 59
        return {
            'app_name': self.app_name,
            'app_icon': self.app_icon,
            'app_version': self.app_version,
            'category': self.category,
            'category_2th': self.category_2th,
            'developer': self.developer,
            'download_url': self.download_url,
            'app_file_size': self.app_file_size,
            'app_screen_size': self.app_screen_size,
            'app_arch': self.app_arch,
            'app_review': self.app_review,
60 61 62 63
            "create_by": self.create_by,
            "update_by": self.update_by,
            "create_at": self.create_at.strftime("%Y-%m-%d %H:%M:%S") if self.create_at else None,
            "update_at": self.update_at.strftime("%Y-%m-%d %H:%M:%S") if self.update_at else None,
wanli's avatar
wanli committed
64 65 66 67 68 69
        }


class PostAppSchema(ma.SQLAlchemySchema):
    class Meta:
        # unknown = INCLUDE # 未知字段默认包含
wanli's avatar
wanli committed
70
        unknown = EXCLUDE # 未知字段默认排除
wanli's avatar
wanli committed
71 72 73
        model = AppModel

    app_name = ma.auto_field()
74
    app_icon = fields.String(required=False)
wanli's avatar
wanli committed
75 76
    app_version = ma.auto_field()
    category = ma.auto_field()
77 78
    category_2th = fields.String(required=False)
    developer = fields.String(required=False)
wanli's avatar
wanli committed
79 80
    app_screen_size = ma.auto_field()
    app_arch = ma.auto_field()
81 82 83
    app_review = ma.auto_field(required=False)
    logo = fields.Raw(required=False)
    fileList = fields.Raw(required=False)
wanli's avatar
wanli committed
84 85 86 87 88 89

postAppSchema = PostAppSchema()

class DeleteAppSchema(ma.SQLAlchemySchema):
    class Meta:
        # unknown = INCLUDE # 未知字段默认包含
wanli's avatar
wanli committed
90
        unknown = EXCLUDE # 未知字段默认排除
wanli's avatar
wanli committed
91 92 93 94 95 96 97 98
        model = AppModel


deleteAppSchema = DeleteAppSchema()

class GetListAppSchema(ma.SQLAlchemySchema):
    class Meta:
        # unknown = INCLUDE # 未知字段默认包含
wanli's avatar
wanli committed
99
        unknown = EXCLUDE # 未知字段默认排除
wanli's avatar
wanli committed
100 101
        model = AppModel

102 103 104 105
    id = fields.Integer(required=False, nullable=True)
    uuid = fields.String(required=False, nullable=True)
    page = fields.Integer(required=False, default=1, nullable=True)
    pageSize = fields.Integer(required=False, default=15, nullable=True)
106
    scope = fields.String(required=False, nullable=True)
107 108 109 110 111 112 113 114 115 116 117 118 119
    app_name = fields.String(required=False, nullable=True)
    app_icon = fields.String(required=False, nullable=True)
    app_version = fields.String(required=False, nullable=True)
    category = fields.String(required=False, nullable=True)
    category_2t = fields.String(required=False, nullable=True)
    app_arch = fields.String(required=False, nullable=True)
    download_url = fields.String(required=False, nullable=True)
    app_file_size = fields.Integer(required=False, nullable=True)
    app_screen_size = fields.String(required=False, nullable=True)
    app_review = fields.Integer(required=False, nullable=True)
    create_at = fields.DateTime(required=False, nullable=True)
    update_at = fields.DateTime(required=False, nullable=True)

wanli's avatar
wanli committed
120 121

getListAppSchema = GetListAppSchema()
122
getListAppsSchema = GetListAppSchema(many=True)
wanli's avatar
wanli committed
123 124 125 126

class GetAppSchema(ma.SQLAlchemySchema):
    class Meta:
        # unknown = INCLUDE # 未知字段默认包含
wanli's avatar
wanli committed
127
        unknown = EXCLUDE # 未知字段默认排除
wanli's avatar
wanli committed
128 129 130 131 132 133 134 135 136 137 138 139 140
        model = AppModel

    app_name = ma.auto_field()
    app_version = ma.auto_field()
    category = ma.auto_field()
    category_2th = ma.auto_field()
    app_arch = ma.auto_field()

getAppSchema = GetAppSchema()

class PutAppSchema(ma.SQLAlchemySchema):
    class Meta:
        # unknown = INCLUDE # 未知字段默认包含
wanli's avatar
wanli committed
141
        unknown = EXCLUDE # 未知字段默认排除
wanli's avatar
wanli committed
142 143 144 145 146 147 148 149 150 151 152 153
        model = AppModel

    app_name = ma.auto_field()
    app_icon = ma.auto_field()
    app_version = ma.auto_field()
    app_screen_size = ma.auto_field()
    app_arch = ma.auto_field()
    app_review = ma.auto_field()
    category = ma.auto_field()
    category_2th = ma.auto_field()

putAppSchema = PutAppSchema()