scheme_list.py
2.2 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
69
70
71
72
73
74
75
76
77
78
79
# coding=utf-8
#author: 4N
#createtime: 2021/9/16
#email: nheweijun@sina.com
import uuid
from app.models import TileScheme,db
from app.util.component.ApiTemplate import ApiTemplate
from app.util.component.ModelVisitor import ModelVisitor
from sqlalchemy import or_
import datetime
class Api(ApiTemplate):
api_name = "查询切片方案"
def process(self):
# 返回结果
res = {}
res["result"] = False
try:
# 业务逻辑
page_index = int(self.para.get("page_index", "0"))
page_size = int(self.para.get("page_size", "10"))
alias = self.para.get("alias")
name = self.para.get("name")
schemes = TileScheme.query
# 并集
if alias and name:
schemes = schemes.filter(or_(TileScheme.alias.like("%" + alias + "%") , TileScheme.name.like("%" + name + "%")))
else:
if alias:
schemes = schemes.filter(TileScheme.alias.like("%" + alias + "%"))
if name:
schemes = schemes.filter(TileScheme.name.like("%" + name + "%"))
schemes = schemes.limit(page_size).offset(page_index).all()
res["data"] = ModelVisitor.objects_to_jsonarray(schemes)
res["result"] = True
except Exception as e:
raise e
return res
api_doc = {
"tags": ["方案接口"],
"parameters": [
{"name": "page_index",
"in": "formData",
"type": "int",
"description": "页"},
{"name": "page_size",
"in": "formData",
"type": "int",
"description": "页大小"},
{"name": "alias",
"in": "formData",
"type": "string"},
{"name": "name",
"in": "formData",
"type": "string"},
],
"responses": {
200: {
"schema": {
"properties": {
}
}
}
}
}