strongdm 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (216) hide show
  1. checksums.yaml +7 -0
  2. data/LICENSE +201 -0
  3. data/README.md +30 -0
  4. data/doc/Google.html +95 -0
  5. data/doc/Google/Protobuf.html +95 -0
  6. data/doc/LICENSE.html +294 -0
  7. data/doc/Object.html +290 -0
  8. data/doc/README_md.html +128 -0
  9. data/doc/SDM.html +143 -0
  10. data/doc/SDM/AKS.html +347 -0
  11. data/doc/SDM/AKSBasicAuth.html +279 -0
  12. data/doc/SDM/AKSServiceAccount.html +262 -0
  13. data/doc/SDM/AccountAttachment.html +217 -0
  14. data/doc/SDM/AccountAttachmentCreateOptions.html +182 -0
  15. data/doc/SDM/AccountAttachmentCreateResponse.html +216 -0
  16. data/doc/SDM/AccountAttachmentDeleteResponse.html +199 -0
  17. data/doc/SDM/AccountAttachmentGetResponse.html +215 -0
  18. data/doc/SDM/AccountAttachments.html +429 -0
  19. data/doc/SDM/AccountCreateResponse.html +232 -0
  20. data/doc/SDM/AccountDeleteResponse.html +197 -0
  21. data/doc/SDM/AccountGetResponse.html +214 -0
  22. data/doc/SDM/AccountGrant.html +253 -0
  23. data/doc/SDM/AccountGrantCreateResponse.html +215 -0
  24. data/doc/SDM/AccountGrantDeleteResponse.html +198 -0
  25. data/doc/SDM/AccountGrantGetResponse.html +214 -0
  26. data/doc/SDM/AccountGrants.html +425 -0
  27. data/doc/SDM/AccountUpdateResponse.html +214 -0
  28. data/doc/SDM/Accounts.html +492 -0
  29. data/doc/SDM/AlreadyExistsError.html +161 -0
  30. data/doc/SDM/AmazonEKS.html +330 -0
  31. data/doc/SDM/AmazonES.html +296 -0
  32. data/doc/SDM/Athena.html +296 -0
  33. data/doc/SDM/AuroraMysql.html +313 -0
  34. data/doc/SDM/AuroraPostgres.html +330 -0
  35. data/doc/SDM/AuthenticationError.html +161 -0
  36. data/doc/SDM/BadRequestError.html +161 -0
  37. data/doc/SDM/BigQuery.html +296 -0
  38. data/doc/SDM/Cassandra.html +313 -0
  39. data/doc/SDM/Client.html +549 -0
  40. data/doc/SDM/Clustrix.html +313 -0
  41. data/doc/SDM/Cockroach.html +330 -0
  42. data/doc/SDM/CreateResponseMetadata.html +156 -0
  43. data/doc/SDM/DeadlineExceededError.html +161 -0
  44. data/doc/SDM/DeleteResponseMetadata.html +156 -0
  45. data/doc/SDM/Druid.html +296 -0
  46. data/doc/SDM/DynamoDB.html +296 -0
  47. data/doc/SDM/Elastic.html +313 -0
  48. data/doc/SDM/ElasticacheRedis.html +296 -0
  49. data/doc/SDM/Gateway.html +252 -0
  50. data/doc/SDM/GetResponseMetadata.html +156 -0
  51. data/doc/SDM/GoogleGKE.html +296 -0
  52. data/doc/SDM/Greenplum.html +330 -0
  53. data/doc/SDM/HTTPAuth.html +313 -0
  54. data/doc/SDM/HTTPBasicAuth.html +330 -0
  55. data/doc/SDM/HTTPNoAuth.html +296 -0
  56. data/doc/SDM/InternalError.html +161 -0
  57. data/doc/SDM/Kubernetes.html +347 -0
  58. data/doc/SDM/KubernetesBasicAuth.html +279 -0
  59. data/doc/SDM/KubernetesServiceAccount.html +262 -0
  60. data/doc/SDM/Maria.html +313 -0
  61. data/doc/SDM/Memcached.html +262 -0
  62. data/doc/SDM/Memsql.html +313 -0
  63. data/doc/SDM/MongoHost.html +330 -0
  64. data/doc/SDM/MongoLegacyHost.html +347 -0
  65. data/doc/SDM/MongoLegacyReplicaset.html +364 -0
  66. data/doc/SDM/MongoReplicaSet.html +364 -0
  67. data/doc/SDM/Mysql.html +313 -0
  68. data/doc/SDM/NodeCreateResponse.html +232 -0
  69. data/doc/SDM/NodeDeleteResponse.html +197 -0
  70. data/doc/SDM/NodeGetResponse.html +214 -0
  71. data/doc/SDM/NodeUpdateResponse.html +214 -0
  72. data/doc/SDM/Nodes.html +493 -0
  73. data/doc/SDM/NotFoundError.html +161 -0
  74. data/doc/SDM/Oracle.html +330 -0
  75. data/doc/SDM/PermissionError.html +161 -0
  76. data/doc/SDM/Plumbing.html +15821 -0
  77. data/doc/SDM/Postgres.html +330 -0
  78. data/doc/SDM/Presto.html +330 -0
  79. data/doc/SDM/RDP.html +296 -0
  80. data/doc/SDM/RPCError.html +182 -0
  81. data/doc/SDM/RateLimitError.html +183 -0
  82. data/doc/SDM/RateLimitMetadata.html +233 -0
  83. data/doc/SDM/Redis.html +279 -0
  84. data/doc/SDM/Redshift.html +330 -0
  85. data/doc/SDM/Relay.html +216 -0
  86. data/doc/SDM/ResourceCreateResponse.html +214 -0
  87. data/doc/SDM/ResourceDeleteResponse.html +197 -0
  88. data/doc/SDM/ResourceGetResponse.html +214 -0
  89. data/doc/SDM/ResourceUpdateResponse.html +215 -0
  90. data/doc/SDM/Resources.html +482 -0
  91. data/doc/SDM/Role.html +216 -0
  92. data/doc/SDM/RoleAttachment.html +216 -0
  93. data/doc/SDM/RoleAttachmentCreateResponse.html +216 -0
  94. data/doc/SDM/RoleAttachmentDeleteResponse.html +199 -0
  95. data/doc/SDM/RoleAttachmentGetResponse.html +214 -0
  96. data/doc/SDM/RoleAttachments.html +427 -0
  97. data/doc/SDM/RoleCreateResponse.html +215 -0
  98. data/doc/SDM/RoleDeleteResponse.html +197 -0
  99. data/doc/SDM/RoleGetResponse.html +214 -0
  100. data/doc/SDM/RoleGrant.html +214 -0
  101. data/doc/SDM/RoleGrantCreateResponse.html +215 -0
  102. data/doc/SDM/RoleGrantDeleteResponse.html +198 -0
  103. data/doc/SDM/RoleGrantGetResponse.html +214 -0
  104. data/doc/SDM/RoleGrants.html +427 -0
  105. data/doc/SDM/RoleUpdateResponse.html +215 -0
  106. data/doc/SDM/Roles.html +490 -0
  107. data/doc/SDM/SQLServer.html +347 -0
  108. data/doc/SDM/SSH.html +296 -0
  109. data/doc/SDM/Service.html +215 -0
  110. data/doc/SDM/Snowflake.html +313 -0
  111. data/doc/SDM/Sybase.html +296 -0
  112. data/doc/SDM/SybaseIQ.html +296 -0
  113. data/doc/SDM/Teradata.html +296 -0
  114. data/doc/SDM/UpdateResponseMetadata.html +156 -0
  115. data/doc/SDM/User.html +248 -0
  116. data/doc/V1.html +864 -0
  117. data/doc/V1/AccountAttachments.html +109 -0
  118. data/doc/V1/AccountAttachments/Service.html +116 -0
  119. data/doc/V1/AccountGrants.html +109 -0
  120. data/doc/V1/AccountGrants/Service.html +117 -0
  121. data/doc/V1/Accounts.html +109 -0
  122. data/doc/V1/Accounts/Service.html +122 -0
  123. data/doc/V1/Nodes.html +109 -0
  124. data/doc/V1/Nodes/Service.html +124 -0
  125. data/doc/V1/Resources.html +109 -0
  126. data/doc/V1/Resources/Service.html +113 -0
  127. data/doc/V1/RoleAttachments.html +109 -0
  128. data/doc/V1/RoleAttachments/Service.html +119 -0
  129. data/doc/V1/RoleGrants.html +109 -0
  130. data/doc/V1/RoleGrants/Service.html +119 -0
  131. data/doc/V1/Roles.html +109 -0
  132. data/doc/V1/Roles/Service.html +120 -0
  133. data/doc/created.rid +37 -0
  134. data/doc/css/fonts.css +167 -0
  135. data/doc/css/rdoc.css +590 -0
  136. data/doc/examples/Gemfile.html +95 -0
  137. data/doc/examples/Gemfile_lock.html +112 -0
  138. data/doc/examples/README_md.html +95 -0
  139. data/doc/fonts/Lato-Light.ttf +0 -0
  140. data/doc/fonts/Lato-LightItalic.ttf +0 -0
  141. data/doc/fonts/Lato-Regular.ttf +0 -0
  142. data/doc/fonts/Lato-RegularItalic.ttf +0 -0
  143. data/doc/fonts/SourceCodePro-Bold.ttf +0 -0
  144. data/doc/fonts/SourceCodePro-Regular.ttf +0 -0
  145. data/doc/images/add.png +0 -0
  146. data/doc/images/arrow_up.png +0 -0
  147. data/doc/images/brick.png +0 -0
  148. data/doc/images/brick_link.png +0 -0
  149. data/doc/images/bug.png +0 -0
  150. data/doc/images/bullet_black.png +0 -0
  151. data/doc/images/bullet_toggle_minus.png +0 -0
  152. data/doc/images/bullet_toggle_plus.png +0 -0
  153. data/doc/images/date.png +0 -0
  154. data/doc/images/delete.png +0 -0
  155. data/doc/images/find.png +0 -0
  156. data/doc/images/loadingAnimation.gif +0 -0
  157. data/doc/images/macFFBgHack.png +0 -0
  158. data/doc/images/package.png +0 -0
  159. data/doc/images/page_green.png +0 -0
  160. data/doc/images/page_white_text.png +0 -0
  161. data/doc/images/page_white_width.png +0 -0
  162. data/doc/images/plugin.png +0 -0
  163. data/doc/images/ruby.png +0 -0
  164. data/doc/images/tag_blue.png +0 -0
  165. data/doc/images/tag_green.png +0 -0
  166. data/doc/images/transparent.png +0 -0
  167. data/doc/images/wrench.png +0 -0
  168. data/doc/images/wrench_orange.png +0 -0
  169. data/doc/images/zoom.png +0 -0
  170. data/doc/index.html +353 -0
  171. data/doc/js/darkfish.js +161 -0
  172. data/doc/js/jquery.js +4 -0
  173. data/doc/js/navigation.js +142 -0
  174. data/doc/js/navigation.js.gz +0 -0
  175. data/doc/js/search.js +109 -0
  176. data/doc/js/search_index.js +1 -0
  177. data/doc/js/search_index.js.gz +0 -0
  178. data/doc/js/searcher.js +228 -0
  179. data/doc/js/searcher.js.gz +0 -0
  180. data/doc/lib/version.html +98 -0
  181. data/doc/strongdm_gemspec.html +117 -0
  182. data/doc/table_of_contents.html +3002 -0
  183. data/examples/Gemfile +3 -0
  184. data/examples/Gemfile.lock +14 -0
  185. data/examples/README.md +5 -0
  186. data/examples/listUsers.rb +21 -0
  187. data/examples/panicButton.rb +154 -0
  188. data/lib/errors/errors.rb +85 -0
  189. data/lib/grpc/account_attachments_pb.rb +84 -0
  190. data/lib/grpc/account_attachments_services_pb.rb +44 -0
  191. data/lib/grpc/account_grants_pb.rb +82 -0
  192. data/lib/grpc/account_grants_services_pb.rb +44 -0
  193. data/lib/grpc/accounts_pb.rb +107 -0
  194. data/lib/grpc/accounts_services_pb.rb +49 -0
  195. data/lib/grpc/drivers_pb.rb +601 -0
  196. data/lib/grpc/nodes_pb.rb +107 -0
  197. data/lib/grpc/nodes_services_pb.rb +49 -0
  198. data/lib/grpc/options_pb.rb +60 -0
  199. data/lib/grpc/plumbing.rb +4283 -0
  200. data/lib/grpc/protoc-gen-swagger/options/annotations_pb.rb +15 -0
  201. data/lib/grpc/resources_pb.rb +85 -0
  202. data/lib/grpc/resources_services_pb.rb +45 -0
  203. data/lib/grpc/role_attachments_pb.rb +79 -0
  204. data/lib/grpc/role_attachments_services_pb.rb +47 -0
  205. data/lib/grpc/role_grants_pb.rb +79 -0
  206. data/lib/grpc/role_grants_services_pb.rb +47 -0
  207. data/lib/grpc/roles_pb.rb +91 -0
  208. data/lib/grpc/roles_services_pb.rb +50 -0
  209. data/lib/grpc/spec_pb.rb +95 -0
  210. data/lib/models/porcelain.rb +4033 -0
  211. data/lib/strongdm.rb +128 -0
  212. data/lib/svc.rb +1331 -0
  213. data/lib/version +3 -0
  214. data/lib/version.rb +17 -0
  215. data/strongdm.gemspec +23 -0
  216. metadata +318 -0
data/examples/Gemfile ADDED
@@ -0,0 +1,3 @@
1
+ source 'https://rubygems.org'
2
+
3
+ gem 'strongdm'
@@ -0,0 +1,14 @@
1
+ GEM
2
+ specs:
3
+ ipaddr (1.2.2)
4
+ openssl (2.1.2)
5
+ ipaddr
6
+
7
+ PLATFORMS
8
+ ruby
9
+
10
+ DEPENDENCIES
11
+ openssl
12
+
13
+ BUNDLED WITH
14
+ 1.17.2
@@ -0,0 +1,5 @@
1
+ Prior to running examples, run:
2
+
3
+ ```ShellSession
4
+ $ bundler install
5
+ ```
@@ -0,0 +1,21 @@
1
+ # Copyright 2020 StrongDM Inc
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+ #
15
+ require "strongdm"
16
+
17
+ client = SDM::Client.new(ENV['SDM_API_ACCESS_KEY'], ENV['SDM_API_SECRET_KEY'])
18
+ users = client.accounts.list('')
19
+ users.each { |user|
20
+ p user
21
+ }
@@ -0,0 +1,154 @@
1
+ # Copyright 2020 StrongDM Inc
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+ #
15
+ # Copyright 2020 StrongDM Inc
16
+ #
17
+ # Licensed under the Apache License, Version 2.0 (the "License");
18
+ # you may not use this file except in compliance with the License.
19
+ # You may obtain a copy of the License at
20
+ #
21
+ # http://www.apache.org/licenses/LICENSE-2.0
22
+ #
23
+ # Unless required by applicable law or agreed to in writing, software
24
+ # distributed under the License is distributed on an "AS IS" BASIS,
25
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
26
+ # See the License for the specific language governing permissions and
27
+ # limitations under the License.
28
+ #
29
+
30
+ require "strongdm"
31
+ require "OpenSSL"
32
+ require "JSON"
33
+
34
+ # panicButton.rb suspends all users except for one admin,
35
+ # in the fake use case of a critical break in or something
36
+ # usage:
37
+ # ruby panicButton.rb adminuser@email.com
38
+ # to revert back to pre-panic state:
39
+ # ruby panicButton.rb revert
40
+ def main
41
+ access_key = ENV["SDM_API_ACCESS_KEY"]
42
+ secret_key = ENV["SDM_API_SECRET_KEY"]
43
+ if access_key == nil or secret_key == nil
44
+ puts "SDM_API_ACCESS_KEY and SDM_API_SECRET_KEY must be provided"
45
+ return
46
+ end
47
+ client = SDM::Client.new(access_key, secret_key)
48
+
49
+ if ARGV.size == 1 and ARGV[0] == "revert"
50
+ state_file = File.open("state.json")
51
+ state = JSON.load(state_file)
52
+
53
+ reinstated_count = 0
54
+
55
+ users = client.accounts.list('')
56
+ users.each{ |user|
57
+ if user.suspended
58
+ reinstated_count += 1
59
+ user.suspended = false
60
+ client.accounts.update(user)
61
+ end
62
+ }
63
+ state["attachments"].each { |attachment|
64
+ begin
65
+ a = SDM::AccountAttachment.new()
66
+ a.account_id = attachment["account_id"]
67
+ a.role_id = attachment["role_id"]
68
+ client.account_attachments.create(a)
69
+ rescue SDM::AlreadyExistsError
70
+ rescue => ex
71
+ puts "skipping creation of attachment due to error: " + ex.to_s
72
+ end
73
+ }
74
+ state["grants"].each { |attachment|
75
+ begin
76
+ g = SDM::AccountGrant.new()
77
+ g.account_id = attachment["account_id"]
78
+ g.resource_id = attachment["resource_id"]
79
+ client.account_grants.create(g)
80
+ rescue SDM::AlreadyExistsError
81
+ rescue => ex
82
+ puts "skipping creation of grant due to error: " + ex.to_s
83
+ end
84
+ }
85
+
86
+ puts "reinstated " + reinstated_count.to_s + " users"
87
+ puts "recreated " + state["attachments"].size.to_s + " account attachments"
88
+ puts "recreated " + state["grants"].size.to_s + " account grants"
89
+
90
+ return
91
+ end
92
+
93
+ admin_email = ""
94
+ if ARGV.size == 1
95
+ admin_email = ARGV[0]
96
+ else
97
+ puts "please provide an admin email to preserve"
98
+ return 1
99
+ end
100
+
101
+ admin_user_id = ""
102
+ users = client.accounts.list("email:?", admin_email)
103
+ users.each{ |user|
104
+ admin_user_id = user.id
105
+ }
106
+
107
+ account_attachments = client.account_attachments.list('')
108
+ account_grants = client.account_grants.list('')
109
+
110
+ state = {
111
+ 'attachments': account_attachments.map{|x|
112
+ if x.account_id != admin_user_id
113
+ out = {
114
+ 'account_id': x.account_id,
115
+ 'role_id': x.role_id,
116
+ }
117
+ end
118
+ }.reject{|x| x == nil},
119
+ 'grants': account_grants.map{|x|
120
+ if x.account_id != admin_user_id and x.valid_until == nil
121
+ out = {
122
+ 'account_id': x.account_id,
123
+ 'resource_id': x.resource_id,
124
+ }
125
+ end
126
+ }.reject{|x| x == nil},
127
+ }
128
+
129
+ puts "storing " + state[:attachments].size.to_s + " account attachments in state"
130
+ puts "storing " + state[:grants].size.to_s + " account grants in state"
131
+
132
+ state_file = File.open("state.json", "w")
133
+ state_file.write(state.to_json)
134
+
135
+ suspended_count = 0
136
+ users = client.accounts.list('')
137
+ users.each{ |user|
138
+ if user.instance_of? SDM::User and user.email == admin_email
139
+ next
140
+ end
141
+ user.suspended = true
142
+ begin
143
+ client.accounts.update(user)
144
+ suspended_count += 1
145
+ rescue StandardError => ex
146
+ puts "skipping user " + user.id + " on account of error: " + ex.to_s
147
+ end
148
+ }
149
+
150
+ puts "suspended " + suspended_count.to_s + " users"
151
+
152
+ end
153
+
154
+ main()
@@ -0,0 +1,85 @@
1
+ # Copyright 2020 StrongDM Inc
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+ #
15
+ # This file was generated by protogen. DO NOT EDIT.
16
+
17
+ module SDM
18
+
19
+ # RPCError is a generic RPC error
20
+ class RPCError < StandardError
21
+ attr_reader :code
22
+ def initialize(msg, code)
23
+ @code = code
24
+ super(msg)
25
+ end
26
+ end
27
+
28
+ # DeadlineExceededError indicates an RPC call timed out
29
+ class DeadlineExceededError < RPCError
30
+ def initialize(msg)
31
+ super(msg, 4)
32
+ end
33
+ end
34
+
35
+ # AlreadyExistsError is used when an entity already exists in the system
36
+ class AlreadyExistsError < RPCError
37
+ def initialize(msg)
38
+ super(msg, 6)
39
+ end
40
+ end
41
+
42
+ # NotFoundError is used when an entity does not exist in the system
43
+ class NotFoundError < RPCError
44
+ def initialize(msg)
45
+ super(msg, 5)
46
+ end
47
+ end
48
+
49
+ # BadRequestError identifies a bad request sent by the client
50
+ class BadRequestError < RPCError
51
+ def initialize(msg)
52
+ super(msg, 3)
53
+ end
54
+ end
55
+
56
+ # AuthenticationError is used to specify an authentication failure condition
57
+ class AuthenticationError < RPCError
58
+ def initialize(msg)
59
+ super(msg, 16)
60
+ end
61
+ end
62
+
63
+ # PermissionError is used to specify a permissions violation
64
+ class PermissionError < RPCError
65
+ def initialize(msg)
66
+ super(msg, 7)
67
+ end
68
+ end
69
+
70
+ # InternalError is used to specify an internal system error
71
+ class InternalError < RPCError
72
+ def initialize(msg)
73
+ super(msg, 13)
74
+ end
75
+ end
76
+
77
+ # RateLimitError is used for rate limit excess condition
78
+ class RateLimitError < RPCError
79
+ attr_reader :rate_limit
80
+ def initialize(msg, rate_limit)
81
+ @rate_limit = rate_limit
82
+ super(msg, 8)
83
+ end
84
+ end
85
+ end
@@ -0,0 +1,84 @@
1
+ # Copyright 2020 StrongDM Inc
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+ #
15
+ # Generated by the protocol buffer compiler. DO NOT EDIT!
16
+ # source: account_attachments.proto
17
+
18
+ require 'google/protobuf'
19
+
20
+ require 'google/api/annotations_pb'
21
+ require 'protoc-gen-swagger/options/annotations_pb'
22
+ require 'options_pb'
23
+ require 'spec_pb'
24
+ Google::Protobuf::DescriptorPool.generated_pool.build do
25
+ add_file("account_attachments.proto", :syntax => :proto3) do
26
+ add_message "v1.AccountAttachmentCreateRequest" do
27
+ optional :meta, :message, 1, "v1.CreateRequestMetadata"
28
+ optional :account_attachment, :message, 2, "v1.AccountAttachment"
29
+ optional :options, :message, 3, "v1.AccountAttachmentCreateOptions"
30
+ end
31
+ add_message "v1.AccountAttachmentCreateOptions" do
32
+ optional :overwrite, :bool, 1
33
+ end
34
+ add_message "v1.AccountAttachmentCreateResponse" do
35
+ optional :meta, :message, 1, "v1.CreateResponseMetadata"
36
+ optional :account_attachment, :message, 2, "v1.AccountAttachment"
37
+ optional :rate_limit, :message, 3, "v1.RateLimitMetadata"
38
+ end
39
+ add_message "v1.AccountAttachmentGetRequest" do
40
+ optional :meta, :message, 1, "v1.GetRequestMetadata"
41
+ optional :id, :string, 2
42
+ end
43
+ add_message "v1.AccountAttachmentGetResponse" do
44
+ optional :meta, :message, 1, "v1.GetResponseMetadata"
45
+ optional :account_attachment, :message, 2, "v1.AccountAttachment"
46
+ optional :rate_limit, :message, 3, "v1.RateLimitMetadata"
47
+ end
48
+ add_message "v1.AccountAttachmentDeleteRequest" do
49
+ optional :meta, :message, 1, "v1.DeleteRequestMetadata"
50
+ optional :id, :string, 2
51
+ end
52
+ add_message "v1.AccountAttachmentDeleteResponse" do
53
+ optional :meta, :message, 1, "v1.DeleteResponseMetadata"
54
+ optional :rate_limit, :message, 2, "v1.RateLimitMetadata"
55
+ end
56
+ add_message "v1.AccountAttachmentListRequest" do
57
+ optional :meta, :message, 1, "v1.ListRequestMetadata"
58
+ optional :filter, :string, 2
59
+ end
60
+ add_message "v1.AccountAttachmentListResponse" do
61
+ optional :meta, :message, 1, "v1.ListResponseMetadata"
62
+ repeated :account_attachments, :message, 2, "v1.AccountAttachment"
63
+ optional :rate_limit, :message, 3, "v1.RateLimitMetadata"
64
+ end
65
+ add_message "v1.AccountAttachment" do
66
+ optional :id, :string, 1
67
+ optional :account_id, :string, 2
68
+ optional :role_id, :string, 3
69
+ end
70
+ end
71
+ end
72
+
73
+ module V1
74
+ AccountAttachmentCreateRequest = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountAttachmentCreateRequest").msgclass
75
+ AccountAttachmentCreateOptions = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountAttachmentCreateOptions").msgclass
76
+ AccountAttachmentCreateResponse = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountAttachmentCreateResponse").msgclass
77
+ AccountAttachmentGetRequest = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountAttachmentGetRequest").msgclass
78
+ AccountAttachmentGetResponse = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountAttachmentGetResponse").msgclass
79
+ AccountAttachmentDeleteRequest = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountAttachmentDeleteRequest").msgclass
80
+ AccountAttachmentDeleteResponse = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountAttachmentDeleteResponse").msgclass
81
+ AccountAttachmentListRequest = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountAttachmentListRequest").msgclass
82
+ AccountAttachmentListResponse = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountAttachmentListResponse").msgclass
83
+ AccountAttachment = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountAttachment").msgclass
84
+ end
@@ -0,0 +1,44 @@
1
+ # Copyright 2020 StrongDM Inc
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+ #
15
+ # Generated by the protocol buffer compiler. DO NOT EDIT!
16
+ # Source: account_attachments.proto for package 'v1'
17
+
18
+ require 'grpc'
19
+ require 'account_attachments_pb'
20
+
21
+ module V1
22
+ module AccountAttachments
23
+ # AccountAttachments assign an account to a role.
24
+ class Service
25
+
26
+ include GRPC::GenericService
27
+
28
+ self.marshal_class_method = :encode
29
+ self.unmarshal_class_method = :decode
30
+ self.service_name = 'v1.AccountAttachments'
31
+
32
+ # Create registers a new AccountAttachment.
33
+ rpc :Create, AccountAttachmentCreateRequest, AccountAttachmentCreateResponse
34
+ # Get reads one AccountAttachment by ID.
35
+ rpc :Get, AccountAttachmentGetRequest, AccountAttachmentGetResponse
36
+ # Delete removes a AccountAttachment by ID.
37
+ rpc :Delete, AccountAttachmentDeleteRequest, AccountAttachmentDeleteResponse
38
+ # List gets a list of AccountAttachments matching a given set of criteria.
39
+ rpc :List, AccountAttachmentListRequest, AccountAttachmentListResponse
40
+ end
41
+
42
+ Stub = Service.rpc_stub_class
43
+ end
44
+ end
@@ -0,0 +1,82 @@
1
+ # Copyright 2020 StrongDM Inc
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+ #
15
+ # Generated by the protocol buffer compiler. DO NOT EDIT!
16
+ # source: account_grants.proto
17
+
18
+ require 'google/protobuf'
19
+
20
+ require 'google/api/annotations_pb'
21
+ require 'protoc-gen-swagger/options/annotations_pb'
22
+ require 'google/protobuf/timestamp_pb'
23
+ require 'options_pb'
24
+ require 'spec_pb'
25
+ Google::Protobuf::DescriptorPool.generated_pool.build do
26
+ add_file("account_grants.proto", :syntax => :proto3) do
27
+ add_message "v1.AccountGrantCreateRequest" do
28
+ optional :meta, :message, 1, "v1.CreateRequestMetadata"
29
+ optional :account_grant, :message, 2, "v1.AccountGrant"
30
+ end
31
+ add_message "v1.AccountGrantCreateResponse" do
32
+ optional :meta, :message, 1, "v1.CreateResponseMetadata"
33
+ optional :account_grant, :message, 2, "v1.AccountGrant"
34
+ optional :rate_limit, :message, 3, "v1.RateLimitMetadata"
35
+ end
36
+ add_message "v1.AccountGrantGetRequest" do
37
+ optional :meta, :message, 1, "v1.GetRequestMetadata"
38
+ optional :id, :string, 2
39
+ end
40
+ add_message "v1.AccountGrantGetResponse" do
41
+ optional :meta, :message, 1, "v1.GetResponseMetadata"
42
+ optional :account_grant, :message, 2, "v1.AccountGrant"
43
+ optional :rate_limit, :message, 3, "v1.RateLimitMetadata"
44
+ end
45
+ add_message "v1.AccountGrantDeleteRequest" do
46
+ optional :meta, :message, 1, "v1.DeleteRequestMetadata"
47
+ optional :id, :string, 2
48
+ end
49
+ add_message "v1.AccountGrantDeleteResponse" do
50
+ optional :meta, :message, 1, "v1.DeleteResponseMetadata"
51
+ optional :rate_limit, :message, 2, "v1.RateLimitMetadata"
52
+ end
53
+ add_message "v1.AccountGrantListRequest" do
54
+ optional :meta, :message, 1, "v1.ListRequestMetadata"
55
+ optional :filter, :string, 2
56
+ end
57
+ add_message "v1.AccountGrantListResponse" do
58
+ optional :meta, :message, 1, "v1.ListResponseMetadata"
59
+ repeated :account_grants, :message, 2, "v1.AccountGrant"
60
+ optional :rate_limit, :message, 3, "v1.RateLimitMetadata"
61
+ end
62
+ add_message "v1.AccountGrant" do
63
+ optional :id, :string, 1
64
+ optional :resource_id, :string, 2
65
+ optional :account_id, :string, 3
66
+ optional :start_from, :message, 4, "google.protobuf.Timestamp"
67
+ optional :valid_until, :message, 5, "google.protobuf.Timestamp"
68
+ end
69
+ end
70
+ end
71
+
72
+ module V1
73
+ AccountGrantCreateRequest = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountGrantCreateRequest").msgclass
74
+ AccountGrantCreateResponse = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountGrantCreateResponse").msgclass
75
+ AccountGrantGetRequest = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountGrantGetRequest").msgclass
76
+ AccountGrantGetResponse = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountGrantGetResponse").msgclass
77
+ AccountGrantDeleteRequest = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountGrantDeleteRequest").msgclass
78
+ AccountGrantDeleteResponse = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountGrantDeleteResponse").msgclass
79
+ AccountGrantListRequest = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountGrantListRequest").msgclass
80
+ AccountGrantListResponse = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountGrantListResponse").msgclass
81
+ AccountGrant = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.AccountGrant").msgclass
82
+ end