-
Notifications
You must be signed in to change notification settings - Fork 236
/
Copy pathuser.thrift
128 lines (114 loc) · 2.6 KB
/
user.thrift
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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
/*
* Copyright 2024 CloudWeGo Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
namespace go user
include "openapi.thrift"
enum Code {
Success = 1
ParamInvalid = 2
DBErr = 3
}
enum Gender {
Unknown = 0
Male = 1
Female = 2
}
struct User {
1: i64 user_id
2: string name (
openapi.property = '{
title: "Name",
description: "Name",
type: "string",
min_length: 1,
max_length: 50
}'
)
3: Gender gender
4: i64 age
5: string introduce
}
struct CreateUserRequest{
1: string name
2: Gender gender
3: i64 age
4: string introduce
}
struct CreateUserResponse{
1: Code code
2: string msg
}
struct QueryUserRequest{
1: optional string Keyword
2: i64 page
3: i64 page_size
}
struct QueryUserResponse{
1: Code code
2: string msg
3: list<User> users
4: i64 total
}
struct DeleteUserRequest{
//用户编号
1: i64 user_id
}
struct DeleteUserResponse{
1: Code code
2: string msg
}
struct UpdateUserRequest{
1: i64 user_id
2: string name
//性别
3: Gender gender
4: i64 age
5: string introduce
}
struct UpdateUserResponse{
1: Code code
2: string msg(
openapi.property = '{
title: "response content",
description: "response content",
type: "string",
min_length: 1,
max_length: 80
}'
)
}(
openapi.schema = '{
title: "Hello - response",
description: "Hello - response",
required: [
"msg"
]
}'
)
// UserService描述
service UserService {
UpdateUserResponse UpdateUser(1:UpdateUserRequest req)
DeleteUserResponse DeleteUser(1:DeleteUserRequest req)
QueryUserResponse QueryUser(1: QueryUserRequest req)
CreateUserResponse CreateUser(1:CreateUserRequest req)
}(
api.base_domain = "127.0.0.1:8888",
openapi.document = '{
info: {
title: "kitex example swagger doc",
version: "0.0.1"
}
}'
)