strongdm 16.4.0 → 16.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.git/ORIG_HEAD +1 -1
- data/.git/index +0 -0
- data/.git/logs/HEAD +3 -3
- data/.git/logs/refs/heads/master +2 -2
- data/.git/logs/refs/remotes/origin/HEAD +1 -1
- data/.git/objects/pack/{pack-091f4eff5af14631e219ef825252ead79d4eed4b.idx → pack-76fa290caa396eed2f723f800a152ef998a8b2de.idx} +0 -0
- data/.git/objects/pack/{pack-091f4eff5af14631e219ef825252ead79d4eed4b.pack → pack-76fa290caa396eed2f723f800a152ef998a8b2de.pack} +0 -0
- data/.git/packed-refs +3 -2
- data/.git/refs/heads/master +1 -1
- data/lib/grpc/authorization_policies_pb.rb +58 -0
- data/lib/grpc/control_panel_pb.rb +13 -0
- data/lib/grpc/control_panel_services_pb.rb +3 -0
- data/lib/grpc/plumbing.rb +564 -0
- data/lib/grpc/resourcetypes_pb.rb +150 -0
- data/lib/models/porcelain.rb +286 -0
- data/lib/strongdm.rb +1 -1
- data/lib/svc.rb +37 -0
- data/lib/version +1 -1
- data/lib/version.rb +1 -1
- metadata +6 -4
|
@@ -0,0 +1,150 @@
|
|
|
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: resourcetypes.proto
|
|
17
|
+
|
|
18
|
+
require "google/protobuf"
|
|
19
|
+
|
|
20
|
+
Google::Protobuf::DescriptorPool.generated_pool.build do
|
|
21
|
+
add_file("resourcetypes.proto", :syntax => :proto3) do
|
|
22
|
+
add_enum "v1.ResourceType" do
|
|
23
|
+
value :RESOURCE_TYPE_UNSPECIFIED, 0
|
|
24
|
+
value :RESOURCE_TYPE_AKS, 805
|
|
25
|
+
value :RESOURCE_TYPE_AKS_BASIC_AUTH, 806
|
|
26
|
+
value :RESOURCE_TYPE_AKS_SERVICE_ACCOUNT, 807
|
|
27
|
+
value :RESOURCE_TYPE_AKS_SERVICE_ACCOUNT_USER_IMPERSONATION, 810
|
|
28
|
+
value :RESOURCE_TYPE_AKS_USER_IMPERSONATION, 814
|
|
29
|
+
value :RESOURCE_TYPE_AMAZON_MQAMQP, 2502
|
|
30
|
+
value :RESOURCE_TYPE_AWS, 2300
|
|
31
|
+
value :RESOURCE_TYPE_AWS_CONSOLE, 3000
|
|
32
|
+
value :RESOURCE_TYPE_AWS_CONSOLE_STATIC_KEY_PAIR, 3001
|
|
33
|
+
value :RESOURCE_TYPE_AWS_INSTANCE_PROFILE, 2301
|
|
34
|
+
value :RESOURCE_TYPE_AEROSPIKE, 4600
|
|
35
|
+
value :RESOURCE_TYPE_AMAZON_EKS, 802
|
|
36
|
+
value :RESOURCE_TYPE_AMAZON_EKS_INSTANCE_PROFILE, 809
|
|
37
|
+
value :RESOURCE_TYPE_AMAZON_EKS_INSTANCE_PROFILE_USER_IMPERSONATION, 813
|
|
38
|
+
value :RESOURCE_TYPE_AMAZON_EKS_USER_IMPERSONATION, 818
|
|
39
|
+
value :RESOURCE_TYPE_AMAZON_ES, 600
|
|
40
|
+
value :RESOURCE_TYPE_AMAZON_ESIAM, 602
|
|
41
|
+
value :RESOURCE_TYPE_AMAZON_MQAMQP_091, 2501
|
|
42
|
+
value :RESOURCE_TYPE_ATHENA, 100
|
|
43
|
+
value :RESOURCE_TYPE_ATHENA_IAM, 3400
|
|
44
|
+
value :RESOURCE_TYPE_AURORA_MY_SQL, 1101
|
|
45
|
+
value :RESOURCE_TYPE_AURORA_MY_SQLIAM, 1109
|
|
46
|
+
value :RESOURCE_TYPE_AURORA_POSTGRES, 1301
|
|
47
|
+
value :RESOURCE_TYPE_AURORA_POSTGRES_IAM, 1309
|
|
48
|
+
value :RESOURCE_TYPE_AZURE, 2800
|
|
49
|
+
value :RESOURCE_TYPE_AZURE_CERT, 2801
|
|
50
|
+
value :RESOURCE_TYPE_AZURE_MY_SQL, 1107
|
|
51
|
+
value :RESOURCE_TYPE_AZURE_MY_SQL_MANAGED_IDENTITY, 1110
|
|
52
|
+
value :RESOURCE_TYPE_AZURE_POSTGRES, 1307
|
|
53
|
+
value :RESOURCE_TYPE_AZURE_POSTGRES_MANAGED_IDENTITY, 1308
|
|
54
|
+
value :RESOURCE_TYPE_BIGQUERY, 200
|
|
55
|
+
value :RESOURCE_TYPE_CASSANDRA, 300
|
|
56
|
+
value :RESOURCE_TYPE_CITUS, 1305
|
|
57
|
+
value :RESOURCE_TYPE_CLICK_HOUSE_HTTP, 5
|
|
58
|
+
value :RESOURCE_TYPE_CLICK_HOUSE_MY_SQL, 1108
|
|
59
|
+
value :RESOURCE_TYPE_CLICK_HOUSE_TCP, 6
|
|
60
|
+
value :RESOURCE_TYPE_CLUSTRIX, 1102
|
|
61
|
+
value :RESOURCE_TYPE_COCKROACH, 1303
|
|
62
|
+
value :RESOURCE_TYPE_COUCHBASE_DATABASE, 3201
|
|
63
|
+
value :RESOURCE_TYPE_COUCHBASE_WEB_UI, 3200
|
|
64
|
+
value :RESOURCE_TYPE_DB_2_I, 2400
|
|
65
|
+
value :RESOURCE_TYPE_DB_2_LUW, 2200
|
|
66
|
+
value :RESOURCE_TYPE_DOCUMENT_DB_HOST, 1052
|
|
67
|
+
value :RESOURCE_TYPE_DOCUMENT_DB_HOST_IAM, 1055
|
|
68
|
+
value :RESOURCE_TYPE_DOCUMENT_DB_REPLICA_SET, 1053
|
|
69
|
+
value :RESOURCE_TYPE_DOCUMENT_DB_REPLICA_SET_IAM, 1056
|
|
70
|
+
value :RESOURCE_TYPE_DRUID, 400
|
|
71
|
+
value :RESOURCE_TYPE_DYNAMO_DB, 500
|
|
72
|
+
value :RESOURCE_TYPE_DYNAMO_DBIAM, 501
|
|
73
|
+
value :RESOURCE_TYPE_ELASTIC, 601
|
|
74
|
+
value :RESOURCE_TYPE_ELASTI_CACHE_REDIS, 1601
|
|
75
|
+
value :RESOURCE_TYPE_ELASTI_CACHE_REDIS_IAM, 1603
|
|
76
|
+
value :RESOURCE_TYPE_ENTRA_ID, 2803
|
|
77
|
+
value :RESOURCE_TYPE_GCP, 2700
|
|
78
|
+
value :RESOURCE_TYPE_GCP_CONSOLE, 3300
|
|
79
|
+
value :RESOURCE_TYPE_GCPWIF, 2701
|
|
80
|
+
value :RESOURCE_TYPE_GIT_HUB, 3301
|
|
81
|
+
value :RESOURCE_TYPE_GOOGLE_ADMIN, 3302
|
|
82
|
+
value :RESOURCE_TYPE_GOOGLE_GKE, 803
|
|
83
|
+
value :RESOURCE_TYPE_GOOGLE_GKE_USER_IMPERSONATION, 816
|
|
84
|
+
value :RESOURCE_TYPE_GOOGLE_SPANNER, 4800
|
|
85
|
+
value :RESOURCE_TYPE_GREENPLUM, 1302
|
|
86
|
+
value :RESOURCE_TYPE_HTTP_AUTH, 702
|
|
87
|
+
value :RESOURCE_TYPE_HTTP_BASIC, 700
|
|
88
|
+
value :RESOURCE_TYPE_HTTP_NO_AUTH, 701
|
|
89
|
+
value :RESOURCE_TYPE_KUBERNETES, 800
|
|
90
|
+
value :RESOURCE_TYPE_KUBERNETES_BASIC_AUTH, 801
|
|
91
|
+
value :RESOURCE_TYPE_KUBERNETES_POD_IDENTITY, 819
|
|
92
|
+
value :RESOURCE_TYPE_KUBERNETES_SERVICE_ACCOUNT, 804
|
|
93
|
+
value :RESOURCE_TYPE_KUBERNETES_SERVICE_ACCOUNT_USER_IMPERSONATION, 808
|
|
94
|
+
value :RESOURCE_TYPE_KUBERNETES_USER_IMPERSONATION, 812
|
|
95
|
+
value :RESOURCE_TYPE_MCP, 4700
|
|
96
|
+
value :RESOURCE_TYPE_MCPDCR, 4701
|
|
97
|
+
value :RESOURCE_TYPE_MTLS_MY_SQL, 1106
|
|
98
|
+
value :RESOURCE_TYPE_MTLS_POSTGRES, 1306
|
|
99
|
+
value :RESOURCE_TYPE_MARIA, 1103
|
|
100
|
+
value :RESOURCE_TYPE_MEMCACHED, 900
|
|
101
|
+
value :RESOURCE_TYPE_MEM_SQL, 1104
|
|
102
|
+
value :RESOURCE_TYPE_MICROSOFT_365, 3303
|
|
103
|
+
value :RESOURCE_TYPE_MONGO_DB_HOST, 1002
|
|
104
|
+
value :RESOURCE_TYPE_MONGO_DB, 1000
|
|
105
|
+
value :RESOURCE_TYPE_MONGO_DB_LEGACY_REPLICA_SET, 1001
|
|
106
|
+
value :RESOURCE_TYPE_MONGO_DB_REPLICA_SET, 1003
|
|
107
|
+
value :RESOURCE_TYPE_MONGO_DB_SHARDED_CLUSTER, 1054
|
|
108
|
+
value :RESOURCE_TYPE_MY_SQL, 1100
|
|
109
|
+
value :RESOURCE_TYPE_NEPTUNE, 2250
|
|
110
|
+
value :RESOURCE_TYPE_NEPTUNE_IAM, 2201
|
|
111
|
+
value :RESOURCE_TYPE_OKTA_ADMIN, 3304
|
|
112
|
+
value :RESOURCE_TYPE_OKTA_GROUPS, 3500
|
|
113
|
+
value :RESOURCE_TYPE_ORACLE, 1200
|
|
114
|
+
value :RESOURCE_TYPE_ORACLE_NNE, 1201
|
|
115
|
+
value :RESOURCE_TYPE_POSTGRES, 1300
|
|
116
|
+
value :RESOURCE_TYPE_PRESTO, 1400
|
|
117
|
+
value :RESOURCE_TYPE_RDP, 1500
|
|
118
|
+
value :RESOURCE_TYPE_RDP_CERT, 1501
|
|
119
|
+
value :RESOURCE_TYPE_RDS_POSTGRES_IAM, 1310
|
|
120
|
+
value :RESOURCE_TYPE_RABBIT_MQAMQP_091, 2500
|
|
121
|
+
value :RESOURCE_TYPE_TCP, 2600
|
|
122
|
+
value :RESOURCE_TYPE_REDIS, 1600
|
|
123
|
+
value :RESOURCE_TYPE_REDIS_CLUSTER, 1602
|
|
124
|
+
value :RESOURCE_TYPE_REDSHIFT, 1304
|
|
125
|
+
value :RESOURCE_TYPE_REDSHIFT_IAM, 1312
|
|
126
|
+
value :RESOURCE_TYPE_REDSHIFT_SERVERLESS_IAM, 1311
|
|
127
|
+
value :RESOURCE_TYPE_SQL_SERVER, 1800
|
|
128
|
+
value :RESOURCE_TYPE_SQL_SERVER_AZURE_AD, 1805
|
|
129
|
+
value :RESOURCE_TYPE_SQL_SERVER_KERBEROS, 1810
|
|
130
|
+
value :RESOURCE_TYPE_SSH, 1900
|
|
131
|
+
value :RESOURCE_TYPE_SSH_CERT, 1901
|
|
132
|
+
value :RESOURCE_TYPE_SSH_CERT_USER_PROVISION, 1903
|
|
133
|
+
value :RESOURCE_TYPE_SSH_CUSTOMER_KEY, 1902
|
|
134
|
+
value :RESOURCE_TYPE_SSH_PASSWORD, 1904
|
|
135
|
+
value :RESOURCE_TYPE_SALESFORCE, 3305
|
|
136
|
+
value :RESOURCE_TYPE_SINGLE_STORE, 1105
|
|
137
|
+
value :RESOURCE_TYPE_SNOWFLAKE, 1700
|
|
138
|
+
value :RESOURCE_TYPE_SNOWSIGHT, 1701
|
|
139
|
+
value :RESOURCE_TYPE_SYBASE_ASE, 2000
|
|
140
|
+
value :RESOURCE_TYPE_SYBASE_IQ, 2001
|
|
141
|
+
value :RESOURCE_TYPE_TERADATA, 2100
|
|
142
|
+
value :RESOURCE_TYPE_TRINO, 1401
|
|
143
|
+
value :RESOURCE_TYPE_VERTICA, 4500
|
|
144
|
+
end
|
|
145
|
+
end
|
|
146
|
+
end
|
|
147
|
+
|
|
148
|
+
module V1
|
|
149
|
+
ResourceType = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("v1.ResourceType").enummodule
|
|
150
|
+
end
|
data/lib/models/porcelain.rb
CHANGED
|
@@ -16,6 +16,250 @@
|
|
|
16
16
|
# @internal Code generated by protogen. DO NOT EDIT.
|
|
17
17
|
|
|
18
18
|
module SDM
|
|
19
|
+
module ResourceType
|
|
20
|
+
UNSPECIFIED = "RESOURCE_TYPE_UNSPECIFIED"
|
|
21
|
+
|
|
22
|
+
AKS = "RESOURCE_TYPE_AKS"
|
|
23
|
+
|
|
24
|
+
AKS_BASIC_AUTH = "RESOURCE_TYPE_AKS_BASIC_AUTH"
|
|
25
|
+
|
|
26
|
+
AKS_SERVICE_ACCOUNT = "RESOURCE_TYPE_AKS_SERVICE_ACCOUNT"
|
|
27
|
+
|
|
28
|
+
AKS_SERVICE_ACCOUNT_USER_IMPERSONATION = "RESOURCE_TYPE_AKS_SERVICE_ACCOUNT_USER_IMPERSONATION"
|
|
29
|
+
|
|
30
|
+
AKS_USER_IMPERSONATION = "RESOURCE_TYPE_AKS_USER_IMPERSONATION"
|
|
31
|
+
|
|
32
|
+
AMAZON_MQAMQP = "RESOURCE_TYPE_AMAZON_MQAMQP"
|
|
33
|
+
|
|
34
|
+
AWS = "RESOURCE_TYPE_AWS"
|
|
35
|
+
|
|
36
|
+
AWS_CONSOLE = "RESOURCE_TYPE_AWS_CONSOLE"
|
|
37
|
+
|
|
38
|
+
AWS_CONSOLE_STATIC_KEY_PAIR = "RESOURCE_TYPE_AWS_CONSOLE_STATIC_KEY_PAIR"
|
|
39
|
+
|
|
40
|
+
AWS_INSTANCE_PROFILE = "RESOURCE_TYPE_AWS_INSTANCE_PROFILE"
|
|
41
|
+
|
|
42
|
+
AEROSPIKE = "RESOURCE_TYPE_AEROSPIKE"
|
|
43
|
+
|
|
44
|
+
AMAZON_EKS = "RESOURCE_TYPE_AMAZON_EKS"
|
|
45
|
+
|
|
46
|
+
AMAZON_EKS_INSTANCE_PROFILE = "RESOURCE_TYPE_AMAZON_EKS_INSTANCE_PROFILE"
|
|
47
|
+
|
|
48
|
+
AMAZON_EKS_INSTANCE_PROFILE_USER_IMPERSONATION = "RESOURCE_TYPE_AMAZON_EKS_INSTANCE_PROFILE_USER_IMPERSONATION"
|
|
49
|
+
|
|
50
|
+
AMAZON_EKS_USER_IMPERSONATION = "RESOURCE_TYPE_AMAZON_EKS_USER_IMPERSONATION"
|
|
51
|
+
|
|
52
|
+
AMAZON_ES = "RESOURCE_TYPE_AMAZON_ES"
|
|
53
|
+
|
|
54
|
+
AMAZON_ESIAM = "RESOURCE_TYPE_AMAZON_ESIAM"
|
|
55
|
+
|
|
56
|
+
AMAZON_MQAMQP_091 = "RESOURCE_TYPE_AMAZON_MQAMQP_091"
|
|
57
|
+
|
|
58
|
+
ATHENA = "RESOURCE_TYPE_ATHENA"
|
|
59
|
+
|
|
60
|
+
ATHENA_IAM = "RESOURCE_TYPE_ATHENA_IAM"
|
|
61
|
+
|
|
62
|
+
AURORA_MY_SQL = "RESOURCE_TYPE_AURORA_MY_SQL"
|
|
63
|
+
|
|
64
|
+
AURORA_MY_SQLIAM = "RESOURCE_TYPE_AURORA_MY_SQLIAM"
|
|
65
|
+
|
|
66
|
+
AURORA_POSTGRES = "RESOURCE_TYPE_AURORA_POSTGRES"
|
|
67
|
+
|
|
68
|
+
AURORA_POSTGRES_IAM = "RESOURCE_TYPE_AURORA_POSTGRES_IAM"
|
|
69
|
+
|
|
70
|
+
AZURE = "RESOURCE_TYPE_AZURE"
|
|
71
|
+
|
|
72
|
+
AZURE_CERT = "RESOURCE_TYPE_AZURE_CERT"
|
|
73
|
+
|
|
74
|
+
AZURE_MY_SQL = "RESOURCE_TYPE_AZURE_MY_SQL"
|
|
75
|
+
|
|
76
|
+
AZURE_MY_SQL_MANAGED_IDENTITY = "RESOURCE_TYPE_AZURE_MY_SQL_MANAGED_IDENTITY"
|
|
77
|
+
|
|
78
|
+
AZURE_POSTGRES = "RESOURCE_TYPE_AZURE_POSTGRES"
|
|
79
|
+
|
|
80
|
+
AZURE_POSTGRES_MANAGED_IDENTITY = "RESOURCE_TYPE_AZURE_POSTGRES_MANAGED_IDENTITY"
|
|
81
|
+
|
|
82
|
+
BIGQUERY = "RESOURCE_TYPE_BIGQUERY"
|
|
83
|
+
|
|
84
|
+
CASSANDRA = "RESOURCE_TYPE_CASSANDRA"
|
|
85
|
+
|
|
86
|
+
CITUS = "RESOURCE_TYPE_CITUS"
|
|
87
|
+
|
|
88
|
+
CLICK_HOUSE_HTTP = "RESOURCE_TYPE_CLICK_HOUSE_HTTP"
|
|
89
|
+
|
|
90
|
+
CLICK_HOUSE_MY_SQL = "RESOURCE_TYPE_CLICK_HOUSE_MY_SQL"
|
|
91
|
+
|
|
92
|
+
CLICK_HOUSE_TCP = "RESOURCE_TYPE_CLICK_HOUSE_TCP"
|
|
93
|
+
|
|
94
|
+
CLUSTRIX = "RESOURCE_TYPE_CLUSTRIX"
|
|
95
|
+
|
|
96
|
+
COCKROACH = "RESOURCE_TYPE_COCKROACH"
|
|
97
|
+
|
|
98
|
+
COUCHBASE_DATABASE = "RESOURCE_TYPE_COUCHBASE_DATABASE"
|
|
99
|
+
|
|
100
|
+
COUCHBASE_WEB_UI = "RESOURCE_TYPE_COUCHBASE_WEB_UI"
|
|
101
|
+
|
|
102
|
+
DB_2_I = "RESOURCE_TYPE_DB_2_I"
|
|
103
|
+
|
|
104
|
+
DB_2_LUW = "RESOURCE_TYPE_DB_2_LUW"
|
|
105
|
+
|
|
106
|
+
DOCUMENT_DB_HOST = "RESOURCE_TYPE_DOCUMENT_DB_HOST"
|
|
107
|
+
|
|
108
|
+
DOCUMENT_DB_HOST_IAM = "RESOURCE_TYPE_DOCUMENT_DB_HOST_IAM"
|
|
109
|
+
|
|
110
|
+
DOCUMENT_DB_REPLICA_SET = "RESOURCE_TYPE_DOCUMENT_DB_REPLICA_SET"
|
|
111
|
+
|
|
112
|
+
DOCUMENT_DB_REPLICA_SET_IAM = "RESOURCE_TYPE_DOCUMENT_DB_REPLICA_SET_IAM"
|
|
113
|
+
|
|
114
|
+
DRUID = "RESOURCE_TYPE_DRUID"
|
|
115
|
+
|
|
116
|
+
DYNAMO_DB = "RESOURCE_TYPE_DYNAMO_DB"
|
|
117
|
+
|
|
118
|
+
DYNAMO_DBIAM = "RESOURCE_TYPE_DYNAMO_DBIAM"
|
|
119
|
+
|
|
120
|
+
ELASTIC = "RESOURCE_TYPE_ELASTIC"
|
|
121
|
+
|
|
122
|
+
ELASTI_CACHE_REDIS = "RESOURCE_TYPE_ELASTI_CACHE_REDIS"
|
|
123
|
+
|
|
124
|
+
ELASTI_CACHE_REDIS_IAM = "RESOURCE_TYPE_ELASTI_CACHE_REDIS_IAM"
|
|
125
|
+
|
|
126
|
+
ENTRA_ID = "RESOURCE_TYPE_ENTRA_ID"
|
|
127
|
+
|
|
128
|
+
GCP = "RESOURCE_TYPE_GCP"
|
|
129
|
+
|
|
130
|
+
GCP_CONSOLE = "RESOURCE_TYPE_GCP_CONSOLE"
|
|
131
|
+
|
|
132
|
+
GCPWIF = "RESOURCE_TYPE_GCPWIF"
|
|
133
|
+
|
|
134
|
+
GIT_HUB = "RESOURCE_TYPE_GIT_HUB"
|
|
135
|
+
|
|
136
|
+
GOOGLE_ADMIN = "RESOURCE_TYPE_GOOGLE_ADMIN"
|
|
137
|
+
|
|
138
|
+
GOOGLE_GKE = "RESOURCE_TYPE_GOOGLE_GKE"
|
|
139
|
+
|
|
140
|
+
GOOGLE_GKE_USER_IMPERSONATION = "RESOURCE_TYPE_GOOGLE_GKE_USER_IMPERSONATION"
|
|
141
|
+
|
|
142
|
+
GOOGLE_SPANNER = "RESOURCE_TYPE_GOOGLE_SPANNER"
|
|
143
|
+
|
|
144
|
+
GREENPLUM = "RESOURCE_TYPE_GREENPLUM"
|
|
145
|
+
|
|
146
|
+
HTTP_AUTH = "RESOURCE_TYPE_HTTP_AUTH"
|
|
147
|
+
|
|
148
|
+
HTTP_BASIC = "RESOURCE_TYPE_HTTP_BASIC"
|
|
149
|
+
|
|
150
|
+
HTTP_NO_AUTH = "RESOURCE_TYPE_HTTP_NO_AUTH"
|
|
151
|
+
|
|
152
|
+
KUBERNETES = "RESOURCE_TYPE_KUBERNETES"
|
|
153
|
+
|
|
154
|
+
KUBERNETES_BASIC_AUTH = "RESOURCE_TYPE_KUBERNETES_BASIC_AUTH"
|
|
155
|
+
|
|
156
|
+
KUBERNETES_POD_IDENTITY = "RESOURCE_TYPE_KUBERNETES_POD_IDENTITY"
|
|
157
|
+
|
|
158
|
+
KUBERNETES_SERVICE_ACCOUNT = "RESOURCE_TYPE_KUBERNETES_SERVICE_ACCOUNT"
|
|
159
|
+
|
|
160
|
+
KUBERNETES_SERVICE_ACCOUNT_USER_IMPERSONATION = "RESOURCE_TYPE_KUBERNETES_SERVICE_ACCOUNT_USER_IMPERSONATION"
|
|
161
|
+
|
|
162
|
+
KUBERNETES_USER_IMPERSONATION = "RESOURCE_TYPE_KUBERNETES_USER_IMPERSONATION"
|
|
163
|
+
|
|
164
|
+
MCP = "RESOURCE_TYPE_MCP"
|
|
165
|
+
|
|
166
|
+
MCPDCR = "RESOURCE_TYPE_MCPDCR"
|
|
167
|
+
|
|
168
|
+
MTLS_MY_SQL = "RESOURCE_TYPE_MTLS_MY_SQL"
|
|
169
|
+
|
|
170
|
+
MTLS_POSTGRES = "RESOURCE_TYPE_MTLS_POSTGRES"
|
|
171
|
+
|
|
172
|
+
MARIA = "RESOURCE_TYPE_MARIA"
|
|
173
|
+
|
|
174
|
+
MEMCACHED = "RESOURCE_TYPE_MEMCACHED"
|
|
175
|
+
|
|
176
|
+
MEM_SQL = "RESOURCE_TYPE_MEM_SQL"
|
|
177
|
+
|
|
178
|
+
MICROSOFT_365 = "RESOURCE_TYPE_MICROSOFT_365"
|
|
179
|
+
|
|
180
|
+
MONGO_DB_HOST = "RESOURCE_TYPE_MONGO_DB_HOST"
|
|
181
|
+
|
|
182
|
+
MONGO_DB = "RESOURCE_TYPE_MONGO_DB"
|
|
183
|
+
|
|
184
|
+
MONGO_DB_LEGACY_REPLICA_SET = "RESOURCE_TYPE_MONGO_DB_LEGACY_REPLICA_SET"
|
|
185
|
+
|
|
186
|
+
MONGO_DB_REPLICA_SET = "RESOURCE_TYPE_MONGO_DB_REPLICA_SET"
|
|
187
|
+
|
|
188
|
+
MONGO_DB_SHARDED_CLUSTER = "RESOURCE_TYPE_MONGO_DB_SHARDED_CLUSTER"
|
|
189
|
+
|
|
190
|
+
MY_SQL = "RESOURCE_TYPE_MY_SQL"
|
|
191
|
+
|
|
192
|
+
NEPTUNE = "RESOURCE_TYPE_NEPTUNE"
|
|
193
|
+
|
|
194
|
+
NEPTUNE_IAM = "RESOURCE_TYPE_NEPTUNE_IAM"
|
|
195
|
+
|
|
196
|
+
OKTA_ADMIN = "RESOURCE_TYPE_OKTA_ADMIN"
|
|
197
|
+
|
|
198
|
+
OKTA_GROUPS = "RESOURCE_TYPE_OKTA_GROUPS"
|
|
199
|
+
|
|
200
|
+
ORACLE = "RESOURCE_TYPE_ORACLE"
|
|
201
|
+
|
|
202
|
+
ORACLE_NNE = "RESOURCE_TYPE_ORACLE_NNE"
|
|
203
|
+
|
|
204
|
+
POSTGRES = "RESOURCE_TYPE_POSTGRES"
|
|
205
|
+
|
|
206
|
+
PRESTO = "RESOURCE_TYPE_PRESTO"
|
|
207
|
+
|
|
208
|
+
RDP = "RESOURCE_TYPE_RDP"
|
|
209
|
+
|
|
210
|
+
RDP_CERT = "RESOURCE_TYPE_RDP_CERT"
|
|
211
|
+
|
|
212
|
+
RDS_POSTGRES_IAM = "RESOURCE_TYPE_RDS_POSTGRES_IAM"
|
|
213
|
+
|
|
214
|
+
RABBIT_MQAMQP_091 = "RESOURCE_TYPE_RABBIT_MQAMQP_091"
|
|
215
|
+
|
|
216
|
+
TCP = "RESOURCE_TYPE_TCP"
|
|
217
|
+
|
|
218
|
+
REDIS = "RESOURCE_TYPE_REDIS"
|
|
219
|
+
|
|
220
|
+
REDIS_CLUSTER = "RESOURCE_TYPE_REDIS_CLUSTER"
|
|
221
|
+
|
|
222
|
+
REDSHIFT = "RESOURCE_TYPE_REDSHIFT"
|
|
223
|
+
|
|
224
|
+
REDSHIFT_IAM = "RESOURCE_TYPE_REDSHIFT_IAM"
|
|
225
|
+
|
|
226
|
+
REDSHIFT_SERVERLESS_IAM = "RESOURCE_TYPE_REDSHIFT_SERVERLESS_IAM"
|
|
227
|
+
|
|
228
|
+
SQL_SERVER = "RESOURCE_TYPE_SQL_SERVER"
|
|
229
|
+
|
|
230
|
+
SQL_SERVER_AZURE_AD = "RESOURCE_TYPE_SQL_SERVER_AZURE_AD"
|
|
231
|
+
|
|
232
|
+
SQL_SERVER_KERBEROS = "RESOURCE_TYPE_SQL_SERVER_KERBEROS"
|
|
233
|
+
|
|
234
|
+
SSH = "RESOURCE_TYPE_SSH"
|
|
235
|
+
|
|
236
|
+
SSH_CERT = "RESOURCE_TYPE_SSH_CERT"
|
|
237
|
+
|
|
238
|
+
SSH_CERT_USER_PROVISION = "RESOURCE_TYPE_SSH_CERT_USER_PROVISION"
|
|
239
|
+
|
|
240
|
+
SSH_CUSTOMER_KEY = "RESOURCE_TYPE_SSH_CUSTOMER_KEY"
|
|
241
|
+
|
|
242
|
+
SSH_PASSWORD = "RESOURCE_TYPE_SSH_PASSWORD"
|
|
243
|
+
|
|
244
|
+
SALESFORCE = "RESOURCE_TYPE_SALESFORCE"
|
|
245
|
+
|
|
246
|
+
SINGLE_STORE = "RESOURCE_TYPE_SINGLE_STORE"
|
|
247
|
+
|
|
248
|
+
SNOWFLAKE = "RESOURCE_TYPE_SNOWFLAKE"
|
|
249
|
+
|
|
250
|
+
SNOWSIGHT = "RESOURCE_TYPE_SNOWSIGHT"
|
|
251
|
+
|
|
252
|
+
SYBASE_ASE = "RESOURCE_TYPE_SYBASE_ASE"
|
|
253
|
+
|
|
254
|
+
SYBASE_IQ = "RESOURCE_TYPE_SYBASE_IQ"
|
|
255
|
+
|
|
256
|
+
TERADATA = "RESOURCE_TYPE_TERADATA"
|
|
257
|
+
|
|
258
|
+
TRINO = "RESOURCE_TYPE_TRINO"
|
|
259
|
+
|
|
260
|
+
VERTICA = "RESOURCE_TYPE_VERTICA"
|
|
261
|
+
end
|
|
262
|
+
|
|
19
263
|
class AKS
|
|
20
264
|
# If true, allows users to fallback to the existing authentication mode (Leased Credential or Identity Set)
|
|
21
265
|
# when a resource role is not provided.
|
|
@@ -5479,6 +5723,48 @@ module SDM
|
|
|
5479
5723
|
end
|
|
5480
5724
|
end
|
|
5481
5725
|
|
|
5726
|
+
# ControlPanelGetOrgURLInfoResponse represents the response containing
|
|
5727
|
+
# organization URL configuration.
|
|
5728
|
+
class ControlPanelGetOrgURLInfoResponse
|
|
5729
|
+
# The base URL of the organization, e.g. https://app.strongdm.com
|
|
5730
|
+
attr_accessor :base_url
|
|
5731
|
+
# Reserved for future use.
|
|
5732
|
+
attr_accessor :meta
|
|
5733
|
+
# The OIDC issuer URL for the organization, used for OIDC federation
|
|
5734
|
+
# with cloud providers
|
|
5735
|
+
attr_accessor :oidc_issuer_url
|
|
5736
|
+
# Rate limit information.
|
|
5737
|
+
attr_accessor :rate_limit
|
|
5738
|
+
# The SAML metadata URL for the organization, used for SAML SSO configuration.
|
|
5739
|
+
attr_accessor :saml_metadata_url
|
|
5740
|
+
# The organization's website subdomain, used to construct URLs.
|
|
5741
|
+
attr_accessor :websites_subdomain
|
|
5742
|
+
|
|
5743
|
+
def initialize(
|
|
5744
|
+
base_url: nil,
|
|
5745
|
+
meta: nil,
|
|
5746
|
+
oidc_issuer_url: nil,
|
|
5747
|
+
rate_limit: nil,
|
|
5748
|
+
saml_metadata_url: nil,
|
|
5749
|
+
websites_subdomain: nil
|
|
5750
|
+
)
|
|
5751
|
+
@base_url = base_url == nil ? "" : base_url
|
|
5752
|
+
@meta = meta == nil ? nil : meta
|
|
5753
|
+
@oidc_issuer_url = oidc_issuer_url == nil ? "" : oidc_issuer_url
|
|
5754
|
+
@rate_limit = rate_limit == nil ? nil : rate_limit
|
|
5755
|
+
@saml_metadata_url = saml_metadata_url == nil ? "" : saml_metadata_url
|
|
5756
|
+
@websites_subdomain = websites_subdomain == nil ? "" : websites_subdomain
|
|
5757
|
+
end
|
|
5758
|
+
|
|
5759
|
+
def to_json(options = {})
|
|
5760
|
+
hash = {}
|
|
5761
|
+
self.instance_variables.each do |var|
|
|
5762
|
+
hash[var.id2name.delete_prefix("@")] = self.instance_variable_get var
|
|
5763
|
+
end
|
|
5764
|
+
hash.to_json
|
|
5765
|
+
end
|
|
5766
|
+
end
|
|
5767
|
+
|
|
5482
5768
|
# ControlPanelGetRDPCAPublicKeyResponse represents a request for an
|
|
5483
5769
|
# organization's RDP Certificate Authority public key.
|
|
5484
5770
|
class ControlPanelGetRDPCAPublicKeyResponse
|
data/lib/strongdm.rb
CHANGED
|
@@ -31,7 +31,7 @@ module SDM #:nodoc:
|
|
|
31
31
|
DEFAULT_RETRY_FACTOR = 1.6
|
|
32
32
|
DEFAULT_RETRY_JITTER = 0.2
|
|
33
33
|
API_VERSION = "2025-04-14"
|
|
34
|
-
USER_AGENT = "strongdm-sdk-ruby/16.
|
|
34
|
+
USER_AGENT = "strongdm-sdk-ruby/16.5.0"
|
|
35
35
|
private_constant :DEFAULT_BASE_RETRY_DELAY, :DEFAULT_MAX_RETRY_DELAY, :DEFAULT_RETRY_FACTOR, :DEFAULT_RETRY_JITTER, :API_VERSION, :USER_AGENT
|
|
36
36
|
|
|
37
37
|
# Creates a new strongDM API client.
|
data/lib/svc.rb
CHANGED
|
@@ -2443,6 +2443,43 @@ module SDM #:nodoc:
|
|
|
2443
2443
|
resp
|
|
2444
2444
|
end
|
|
2445
2445
|
|
|
2446
|
+
# GetOrgURLInfo retrieves URL configuration for the organization.
|
|
2447
|
+
# This includes the base URL, website subdomain, OIDC issuer URL, and SAML metadata URL.
|
|
2448
|
+
def get_org_url_info(
|
|
2449
|
+
deadline: nil
|
|
2450
|
+
)
|
|
2451
|
+
req = V1::ControlPanelGetOrgURLInfoRequest.new()
|
|
2452
|
+
|
|
2453
|
+
# Execute before interceptor hooks
|
|
2454
|
+
req = @parent.interceptor.execute_before("ControlPanel.GetOrgURLInfo", self, req)
|
|
2455
|
+
tries = 0
|
|
2456
|
+
plumbing_response = nil
|
|
2457
|
+
loop do
|
|
2458
|
+
begin
|
|
2459
|
+
plumbing_response = @stub.get_org_url_info(req, metadata: @parent.get_metadata("ControlPanel.GetOrgURLInfo", req), deadline: deadline)
|
|
2460
|
+
rescue => exception
|
|
2461
|
+
if (@parent.shouldRetry(tries, exception, deadline))
|
|
2462
|
+
tries + +sleep(@parent.exponentialBackoff(tries, deadline))
|
|
2463
|
+
next
|
|
2464
|
+
end
|
|
2465
|
+
raise Plumbing::convert_error_to_porcelain(exception)
|
|
2466
|
+
end
|
|
2467
|
+
break
|
|
2468
|
+
end
|
|
2469
|
+
|
|
2470
|
+
# Execute after interceptor hooks
|
|
2471
|
+
plumbing_response = @parent.interceptor.execute_after("ControlPanel.GetOrgURLInfo", self, req, plumbing_response)
|
|
2472
|
+
|
|
2473
|
+
resp = ControlPanelGetOrgURLInfoResponse.new()
|
|
2474
|
+
resp.base_url = (plumbing_response.base_url)
|
|
2475
|
+
resp.meta = Plumbing::convert_get_response_metadata_to_porcelain(plumbing_response.meta)
|
|
2476
|
+
resp.oidc_issuer_url = (plumbing_response.oidc_issuer_url)
|
|
2477
|
+
resp.rate_limit = Plumbing::convert_rate_limit_metadata_to_porcelain(plumbing_response.rate_limit)
|
|
2478
|
+
resp.saml_metadata_url = (plumbing_response.saml_metadata_url)
|
|
2479
|
+
resp.websites_subdomain = (plumbing_response.websites_subdomain)
|
|
2480
|
+
resp
|
|
2481
|
+
end
|
|
2482
|
+
|
|
2446
2483
|
# VerifyJWT reports whether the given JWT token (x-sdm-token) is valid.
|
|
2447
2484
|
def verify_jwt(
|
|
2448
2485
|
token,
|
data/lib/version
CHANGED
data/lib/version.rb
CHANGED
metadata
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
|
2
2
|
name: strongdm
|
|
3
3
|
version: !ruby/object:Gem::Version
|
|
4
|
-
version: 16.
|
|
4
|
+
version: 16.5.0
|
|
5
5
|
platform: ruby
|
|
6
6
|
authors:
|
|
7
7
|
- strongDM Team
|
|
8
8
|
autorequire:
|
|
9
9
|
bindir: bin
|
|
10
10
|
cert_chain: []
|
|
11
|
-
date: 2026-02-
|
|
11
|
+
date: 2026-02-04 00:00:00.000000000 Z
|
|
12
12
|
dependencies:
|
|
13
13
|
- !ruby/object:Gem::Dependency
|
|
14
14
|
name: grpc
|
|
@@ -81,8 +81,8 @@ files:
|
|
|
81
81
|
- "./.git/logs/HEAD"
|
|
82
82
|
- "./.git/logs/refs/heads/master"
|
|
83
83
|
- "./.git/logs/refs/remotes/origin/HEAD"
|
|
84
|
-
- "./.git/objects/pack/pack-
|
|
85
|
-
- "./.git/objects/pack/pack-
|
|
84
|
+
- "./.git/objects/pack/pack-76fa290caa396eed2f723f800a152ef998a8b2de.idx"
|
|
85
|
+
- "./.git/objects/pack/pack-76fa290caa396eed2f723f800a152ef998a8b2de.pack"
|
|
86
86
|
- "./.git/packed-refs"
|
|
87
87
|
- "./.git/refs/heads/master"
|
|
88
88
|
- "./.git/refs/remotes/origin/HEAD"
|
|
@@ -134,6 +134,7 @@ files:
|
|
|
134
134
|
- "./lib/grpc/approval_workflows_history_services_pb.rb"
|
|
135
135
|
- "./lib/grpc/approval_workflows_pb.rb"
|
|
136
136
|
- "./lib/grpc/approval_workflows_services_pb.rb"
|
|
137
|
+
- "./lib/grpc/authorization_policies_pb.rb"
|
|
137
138
|
- "./lib/grpc/control_panel_pb.rb"
|
|
138
139
|
- "./lib/grpc/control_panel_services_pb.rb"
|
|
139
140
|
- "./lib/grpc/custom_headers_pb.rb"
|
|
@@ -198,6 +199,7 @@ files:
|
|
|
198
199
|
- "./lib/grpc/resources_history_services_pb.rb"
|
|
199
200
|
- "./lib/grpc/resources_pb.rb"
|
|
200
201
|
- "./lib/grpc/resources_services_pb.rb"
|
|
202
|
+
- "./lib/grpc/resourcetypes_pb.rb"
|
|
201
203
|
- "./lib/grpc/role_resources_history_pb.rb"
|
|
202
204
|
- "./lib/grpc/role_resources_history_services_pb.rb"
|
|
203
205
|
- "./lib/grpc/role_resources_pb.rb"
|