-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathexample.rb
53 lines (47 loc) · 1.34 KB
/
example.rb
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
module Example
Role = Struct.new(:name, :level)
User = Struct.new(:email, :roles)
class Role::Entity < Grape::Entity
expose :name, as: :code, documentation: { type: 'String', desc: 'Role Code/Name' }
expose :level, documentation: { type: 'String', desc: 'Role Access Level', values: [1, 2, 3] }
end
class User::Entity < Grape::Entity
expose :email, documentation: { type: 'String', desc: 'User Email' }
end
class User::FullEntity < User::Entity
expose :roles,
using: Role::Entity,
documentation: { is_array: true, desc: 'User Roles' } # if `type:...` omited it'll be inferred from `using:...`
end
class API < Grape::API
prefix 'api'
version 'v1'
desc 'List Users' do
success User::Entity
is_array true
security required: %w[admin/users.read]
end
params do
optional :filter, type: Hash do
optional :email, type: [String]
end
end
get '/users' do
[User.new(email: '[email protected]')]
end
desc 'Update User' do
success User::FullEntity
end
params do
optional :roles, type: [JSON] do
requires :name, type: String
end
end
put '/users/:email', requirements: { email: %r{\A[^/]+\Z} } do
User.new(
email: '[email protected]',
roles: [Role.new(name: 'admin')],
)
end
end
end