pulumi-ise 0.1.0__py3-none-any.whl

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.
Files changed (105) hide show
  1. pulumi_ise/__init__.py +362 -0
  2. pulumi_ise/_utilities.py +291 -0
  3. pulumi_ise/config/__init__.py +8 -0
  4. pulumi_ise/config/__init__.pyi +36 -0
  5. pulumi_ise/config/vars.py +52 -0
  6. pulumi_ise/deviceadmin/__init__.py +29 -0
  7. pulumi_ise/deviceadmin/_inputs.py +1952 -0
  8. pulumi_ise/deviceadmin/allowed_protocols_tacacs.py +376 -0
  9. pulumi_ise/deviceadmin/authentication_rule.py +1045 -0
  10. pulumi_ise/deviceadmin/authorization_exception_rule.py +937 -0
  11. pulumi_ise/deviceadmin/authorization_global_exception_rule.py +887 -0
  12. pulumi_ise/deviceadmin/authorization_rule.py +937 -0
  13. pulumi_ise/deviceadmin/condition.py +645 -0
  14. pulumi_ise/deviceadmin/get_allowed_protocols_tacacs.py +161 -0
  15. pulumi_ise/deviceadmin/get_authentication_rule.py +338 -0
  16. pulumi_ise/deviceadmin/get_authorization_exception_rule.py +312 -0
  17. pulumi_ise/deviceadmin/get_authorization_global_exception_rule.py +292 -0
  18. pulumi_ise/deviceadmin/get_authorization_rule.py +312 -0
  19. pulumi_ise/deviceadmin/get_condition.py +227 -0
  20. pulumi_ise/deviceadmin/get_policy_set.py +305 -0
  21. pulumi_ise/deviceadmin/get_tacacs_command_set.py +146 -0
  22. pulumi_ise/deviceadmin/get_tacacs_profile.py +133 -0
  23. pulumi_ise/deviceadmin/get_time_and_date_condition.py +265 -0
  24. pulumi_ise/deviceadmin/outputs.py +3173 -0
  25. pulumi_ise/deviceadmin/policy_set.py +942 -0
  26. pulumi_ise/deviceadmin/tacacs_command_set.py +321 -0
  27. pulumi_ise/deviceadmin/tacacs_profile.py +272 -0
  28. pulumi_ise/deviceadmin/time_and_date_condition.py +765 -0
  29. pulumi_ise/identitymanagement/__init__.py +26 -0
  30. pulumi_ise/identitymanagement/_inputs.py +313 -0
  31. pulumi_ise/identitymanagement/active_directory_add_groups.py +478 -0
  32. pulumi_ise/identitymanagement/active_directory_join_domain_with_all_nodes.py +211 -0
  33. pulumi_ise/identitymanagement/active_directory_join_point.py +1671 -0
  34. pulumi_ise/identitymanagement/certificate_authentication_profile.py +520 -0
  35. pulumi_ise/identitymanagement/endpoint.py +1371 -0
  36. pulumi_ise/identitymanagement/endpoint_identity_group.py +322 -0
  37. pulumi_ise/identitymanagement/get_active_directory_groups_by_domain.py +198 -0
  38. pulumi_ise/identitymanagement/get_active_directory_join_point.py +518 -0
  39. pulumi_ise/identitymanagement/get_certificate_authentication_profile.py +187 -0
  40. pulumi_ise/identitymanagement/get_endpoint.py +434 -0
  41. pulumi_ise/identitymanagement/get_endpoint_identity_group.py +148 -0
  42. pulumi_ise/identitymanagement/get_identity_source_sequence.py +159 -0
  43. pulumi_ise/identitymanagement/get_internal_user.py +278 -0
  44. pulumi_ise/identitymanagement/get_user_identity_group.py +135 -0
  45. pulumi_ise/identitymanagement/identity_source_sequence.py +371 -0
  46. pulumi_ise/identitymanagement/internal_user.py +825 -0
  47. pulumi_ise/identitymanagement/outputs.py +486 -0
  48. pulumi_ise/identitymanagement/user_identity_group.py +275 -0
  49. pulumi_ise/network/__init__.py +13 -0
  50. pulumi_ise/network/_inputs.py +69 -0
  51. pulumi_ise/network/device.py +2189 -0
  52. pulumi_ise/network/device_group.py +276 -0
  53. pulumi_ise/network/get_device.py +643 -0
  54. pulumi_ise/network/get_device_group.py +135 -0
  55. pulumi_ise/network/outputs.py +115 -0
  56. pulumi_ise/networkaccess/__init__.py +31 -0
  57. pulumi_ise/networkaccess/_inputs.py +1948 -0
  58. pulumi_ise/networkaccess/allowed_protocols.py +3962 -0
  59. pulumi_ise/networkaccess/authentication_rule.py +1045 -0
  60. pulumi_ise/networkaccess/authorization_exception_rule.py +937 -0
  61. pulumi_ise/networkaccess/authorization_global_exception_rule.py +887 -0
  62. pulumi_ise/networkaccess/authorization_profile.py +1677 -0
  63. pulumi_ise/networkaccess/authorization_rule.py +937 -0
  64. pulumi_ise/networkaccess/condition.py +645 -0
  65. pulumi_ise/networkaccess/dictionary.py +326 -0
  66. pulumi_ise/networkaccess/downloadable_acl.py +325 -0
  67. pulumi_ise/networkaccess/get_allowed_protocols.py +1097 -0
  68. pulumi_ise/networkaccess/get_authentication_rule.py +338 -0
  69. pulumi_ise/networkaccess/get_authorization_exception_rule.py +312 -0
  70. pulumi_ise/networkaccess/get_authorization_global_exception_rule.py +292 -0
  71. pulumi_ise/networkaccess/get_authorization_profile.py +526 -0
  72. pulumi_ise/networkaccess/get_authorization_rule.py +312 -0
  73. pulumi_ise/networkaccess/get_condition.py +227 -0
  74. pulumi_ise/networkaccess/get_dictionary.py +148 -0
  75. pulumi_ise/networkaccess/get_downloadable_acl.py +148 -0
  76. pulumi_ise/networkaccess/get_policy_set.py +305 -0
  77. pulumi_ise/networkaccess/get_time_and_date_condition.py +265 -0
  78. pulumi_ise/networkaccess/outputs.py +3188 -0
  79. pulumi_ise/networkaccess/policy_set.py +942 -0
  80. pulumi_ise/networkaccess/time_and_date_condition.py +765 -0
  81. pulumi_ise/provider.py +204 -0
  82. pulumi_ise/pulumi-plugin.json +4 -0
  83. pulumi_ise/py.typed +0 -0
  84. pulumi_ise/system/__init__.py +13 -0
  85. pulumi_ise/system/_inputs.py +56 -0
  86. pulumi_ise/system/get_license_tier_state.py +105 -0
  87. pulumi_ise/system/get_repository.py +187 -0
  88. pulumi_ise/system/license_tier_state.py +184 -0
  89. pulumi_ise/system/outputs.py +78 -0
  90. pulumi_ise/system/repository.py +473 -0
  91. pulumi_ise/trustsec/__init__.py +17 -0
  92. pulumi_ise/trustsec/egress_matrix_cell.py +424 -0
  93. pulumi_ise/trustsec/get_egress_matrix_cell.py +169 -0
  94. pulumi_ise/trustsec/get_ip_to_sgt_mapping.py +200 -0
  95. pulumi_ise/trustsec/get_ip_to_sgt_mapping_group.py +161 -0
  96. pulumi_ise/trustsec/get_security_group.py +161 -0
  97. pulumi_ise/trustsec/get_security_group_acl.py +161 -0
  98. pulumi_ise/trustsec/ip_to_sgt_mapping.py +512 -0
  99. pulumi_ise/trustsec/ip_to_sgt_mapping_group.py +371 -0
  100. pulumi_ise/trustsec/security_group.py +374 -0
  101. pulumi_ise/trustsec/security_group_acl.py +374 -0
  102. pulumi_ise-0.1.0.dist-info/METADATA +63 -0
  103. pulumi_ise-0.1.0.dist-info/RECORD +105 -0
  104. pulumi_ise-0.1.0.dist-info/WHEEL +5 -0
  105. pulumi_ise-0.1.0.dist-info/top_level.txt +1 -0
pulumi_ise/__init__.py ADDED
@@ -0,0 +1,362 @@
1
+ # coding=utf-8
2
+ # *** WARNING: this file was generated by the Pulumi Terraform Bridge (tfgen) Tool. ***
3
+ # *** Do not edit by hand unless you're certain you know what you are doing! ***
4
+
5
+ from . import _utilities
6
+ import typing
7
+ # Export this package's modules as members:
8
+ from .provider import *
9
+
10
+ # Make subpackages available:
11
+ if typing.TYPE_CHECKING:
12
+ import pulumi_ise.config as __config
13
+ config = __config
14
+ import pulumi_ise.deviceadmin as __deviceadmin
15
+ deviceadmin = __deviceadmin
16
+ import pulumi_ise.identitymanagement as __identitymanagement
17
+ identitymanagement = __identitymanagement
18
+ import pulumi_ise.network as __network
19
+ network = __network
20
+ import pulumi_ise.networkaccess as __networkaccess
21
+ networkaccess = __networkaccess
22
+ import pulumi_ise.system as __system
23
+ system = __system
24
+ import pulumi_ise.trustsec as __trustsec
25
+ trustsec = __trustsec
26
+ else:
27
+ config = _utilities.lazy_import('pulumi_ise.config')
28
+ deviceadmin = _utilities.lazy_import('pulumi_ise.deviceadmin')
29
+ identitymanagement = _utilities.lazy_import('pulumi_ise.identitymanagement')
30
+ network = _utilities.lazy_import('pulumi_ise.network')
31
+ networkaccess = _utilities.lazy_import('pulumi_ise.networkaccess')
32
+ system = _utilities.lazy_import('pulumi_ise.system')
33
+ trustsec = _utilities.lazy_import('pulumi_ise.trustsec')
34
+
35
+ _utilities.register(
36
+ resource_modules="""
37
+ [
38
+ {
39
+ "pkg": "ise",
40
+ "mod": "deviceadmin/allowedProtocolsTacacs",
41
+ "fqn": "pulumi_ise.deviceadmin",
42
+ "classes": {
43
+ "ise:deviceadmin/allowedProtocolsTacacs:AllowedProtocolsTacacs": "AllowedProtocolsTacacs"
44
+ }
45
+ },
46
+ {
47
+ "pkg": "ise",
48
+ "mod": "deviceadmin/authenticationRule",
49
+ "fqn": "pulumi_ise.deviceadmin",
50
+ "classes": {
51
+ "ise:deviceadmin/authenticationRule:AuthenticationRule": "AuthenticationRule"
52
+ }
53
+ },
54
+ {
55
+ "pkg": "ise",
56
+ "mod": "deviceadmin/authorizationExceptionRule",
57
+ "fqn": "pulumi_ise.deviceadmin",
58
+ "classes": {
59
+ "ise:deviceadmin/authorizationExceptionRule:AuthorizationExceptionRule": "AuthorizationExceptionRule"
60
+ }
61
+ },
62
+ {
63
+ "pkg": "ise",
64
+ "mod": "deviceadmin/authorizationGlobalExceptionRule",
65
+ "fqn": "pulumi_ise.deviceadmin",
66
+ "classes": {
67
+ "ise:deviceadmin/authorizationGlobalExceptionRule:AuthorizationGlobalExceptionRule": "AuthorizationGlobalExceptionRule"
68
+ }
69
+ },
70
+ {
71
+ "pkg": "ise",
72
+ "mod": "deviceadmin/authorizationRule",
73
+ "fqn": "pulumi_ise.deviceadmin",
74
+ "classes": {
75
+ "ise:deviceadmin/authorizationRule:AuthorizationRule": "AuthorizationRule"
76
+ }
77
+ },
78
+ {
79
+ "pkg": "ise",
80
+ "mod": "deviceadmin/condition",
81
+ "fqn": "pulumi_ise.deviceadmin",
82
+ "classes": {
83
+ "ise:deviceadmin/condition:Condition": "Condition"
84
+ }
85
+ },
86
+ {
87
+ "pkg": "ise",
88
+ "mod": "deviceadmin/policySet",
89
+ "fqn": "pulumi_ise.deviceadmin",
90
+ "classes": {
91
+ "ise:deviceadmin/policySet:PolicySet": "PolicySet"
92
+ }
93
+ },
94
+ {
95
+ "pkg": "ise",
96
+ "mod": "deviceadmin/tacacsCommandSet",
97
+ "fqn": "pulumi_ise.deviceadmin",
98
+ "classes": {
99
+ "ise:deviceadmin/tacacsCommandSet:TacacsCommandSet": "TacacsCommandSet"
100
+ }
101
+ },
102
+ {
103
+ "pkg": "ise",
104
+ "mod": "deviceadmin/tacacsProfile",
105
+ "fqn": "pulumi_ise.deviceadmin",
106
+ "classes": {
107
+ "ise:deviceadmin/tacacsProfile:TacacsProfile": "TacacsProfile"
108
+ }
109
+ },
110
+ {
111
+ "pkg": "ise",
112
+ "mod": "deviceadmin/timeAndDateCondition",
113
+ "fqn": "pulumi_ise.deviceadmin",
114
+ "classes": {
115
+ "ise:deviceadmin/timeAndDateCondition:TimeAndDateCondition": "TimeAndDateCondition"
116
+ }
117
+ },
118
+ {
119
+ "pkg": "ise",
120
+ "mod": "identitymanagement/activeDirectoryAddGroups",
121
+ "fqn": "pulumi_ise.identitymanagement",
122
+ "classes": {
123
+ "ise:identitymanagement/activeDirectoryAddGroups:ActiveDirectoryAddGroups": "ActiveDirectoryAddGroups"
124
+ }
125
+ },
126
+ {
127
+ "pkg": "ise",
128
+ "mod": "identitymanagement/activeDirectoryJoinDomainWithAllNodes",
129
+ "fqn": "pulumi_ise.identitymanagement",
130
+ "classes": {
131
+ "ise:identitymanagement/activeDirectoryJoinDomainWithAllNodes:ActiveDirectoryJoinDomainWithAllNodes": "ActiveDirectoryJoinDomainWithAllNodes"
132
+ }
133
+ },
134
+ {
135
+ "pkg": "ise",
136
+ "mod": "identitymanagement/activeDirectoryJoinPoint",
137
+ "fqn": "pulumi_ise.identitymanagement",
138
+ "classes": {
139
+ "ise:identitymanagement/activeDirectoryJoinPoint:ActiveDirectoryJoinPoint": "ActiveDirectoryJoinPoint"
140
+ }
141
+ },
142
+ {
143
+ "pkg": "ise",
144
+ "mod": "identitymanagement/certificateAuthenticationProfile",
145
+ "fqn": "pulumi_ise.identitymanagement",
146
+ "classes": {
147
+ "ise:identitymanagement/certificateAuthenticationProfile:CertificateAuthenticationProfile": "CertificateAuthenticationProfile"
148
+ }
149
+ },
150
+ {
151
+ "pkg": "ise",
152
+ "mod": "identitymanagement/endpoint",
153
+ "fqn": "pulumi_ise.identitymanagement",
154
+ "classes": {
155
+ "ise:identitymanagement/endpoint:Endpoint": "Endpoint"
156
+ }
157
+ },
158
+ {
159
+ "pkg": "ise",
160
+ "mod": "identitymanagement/endpointIdentityGroup",
161
+ "fqn": "pulumi_ise.identitymanagement",
162
+ "classes": {
163
+ "ise:identitymanagement/endpointIdentityGroup:EndpointIdentityGroup": "EndpointIdentityGroup"
164
+ }
165
+ },
166
+ {
167
+ "pkg": "ise",
168
+ "mod": "identitymanagement/identitySourceSequence",
169
+ "fqn": "pulumi_ise.identitymanagement",
170
+ "classes": {
171
+ "ise:identitymanagement/identitySourceSequence:IdentitySourceSequence": "IdentitySourceSequence"
172
+ }
173
+ },
174
+ {
175
+ "pkg": "ise",
176
+ "mod": "identitymanagement/internalUser",
177
+ "fqn": "pulumi_ise.identitymanagement",
178
+ "classes": {
179
+ "ise:identitymanagement/internalUser:InternalUser": "InternalUser"
180
+ }
181
+ },
182
+ {
183
+ "pkg": "ise",
184
+ "mod": "identitymanagement/userIdentityGroup",
185
+ "fqn": "pulumi_ise.identitymanagement",
186
+ "classes": {
187
+ "ise:identitymanagement/userIdentityGroup:UserIdentityGroup": "UserIdentityGroup"
188
+ }
189
+ },
190
+ {
191
+ "pkg": "ise",
192
+ "mod": "network/device",
193
+ "fqn": "pulumi_ise.network",
194
+ "classes": {
195
+ "ise:network/device:Device": "Device"
196
+ }
197
+ },
198
+ {
199
+ "pkg": "ise",
200
+ "mod": "network/deviceGroup",
201
+ "fqn": "pulumi_ise.network",
202
+ "classes": {
203
+ "ise:network/deviceGroup:DeviceGroup": "DeviceGroup"
204
+ }
205
+ },
206
+ {
207
+ "pkg": "ise",
208
+ "mod": "networkaccess/allowedProtocols",
209
+ "fqn": "pulumi_ise.networkaccess",
210
+ "classes": {
211
+ "ise:networkaccess/allowedProtocols:AllowedProtocols": "AllowedProtocols"
212
+ }
213
+ },
214
+ {
215
+ "pkg": "ise",
216
+ "mod": "networkaccess/authenticationRule",
217
+ "fqn": "pulumi_ise.networkaccess",
218
+ "classes": {
219
+ "ise:networkaccess/authenticationRule:AuthenticationRule": "AuthenticationRule"
220
+ }
221
+ },
222
+ {
223
+ "pkg": "ise",
224
+ "mod": "networkaccess/authorizationExceptionRule",
225
+ "fqn": "pulumi_ise.networkaccess",
226
+ "classes": {
227
+ "ise:networkaccess/authorizationExceptionRule:AuthorizationExceptionRule": "AuthorizationExceptionRule"
228
+ }
229
+ },
230
+ {
231
+ "pkg": "ise",
232
+ "mod": "networkaccess/authorizationGlobalExceptionRule",
233
+ "fqn": "pulumi_ise.networkaccess",
234
+ "classes": {
235
+ "ise:networkaccess/authorizationGlobalExceptionRule:AuthorizationGlobalExceptionRule": "AuthorizationGlobalExceptionRule"
236
+ }
237
+ },
238
+ {
239
+ "pkg": "ise",
240
+ "mod": "networkaccess/authorizationProfile",
241
+ "fqn": "pulumi_ise.networkaccess",
242
+ "classes": {
243
+ "ise:networkaccess/authorizationProfile:AuthorizationProfile": "AuthorizationProfile"
244
+ }
245
+ },
246
+ {
247
+ "pkg": "ise",
248
+ "mod": "networkaccess/authorizationRule",
249
+ "fqn": "pulumi_ise.networkaccess",
250
+ "classes": {
251
+ "ise:networkaccess/authorizationRule:AuthorizationRule": "AuthorizationRule"
252
+ }
253
+ },
254
+ {
255
+ "pkg": "ise",
256
+ "mod": "networkaccess/condition",
257
+ "fqn": "pulumi_ise.networkaccess",
258
+ "classes": {
259
+ "ise:networkaccess/condition:Condition": "Condition"
260
+ }
261
+ },
262
+ {
263
+ "pkg": "ise",
264
+ "mod": "networkaccess/dictionary",
265
+ "fqn": "pulumi_ise.networkaccess",
266
+ "classes": {
267
+ "ise:networkaccess/dictionary:Dictionary": "Dictionary"
268
+ }
269
+ },
270
+ {
271
+ "pkg": "ise",
272
+ "mod": "networkaccess/downloadableAcl",
273
+ "fqn": "pulumi_ise.networkaccess",
274
+ "classes": {
275
+ "ise:networkaccess/downloadableAcl:DownloadableAcl": "DownloadableAcl"
276
+ }
277
+ },
278
+ {
279
+ "pkg": "ise",
280
+ "mod": "networkaccess/policySet",
281
+ "fqn": "pulumi_ise.networkaccess",
282
+ "classes": {
283
+ "ise:networkaccess/policySet:PolicySet": "PolicySet"
284
+ }
285
+ },
286
+ {
287
+ "pkg": "ise",
288
+ "mod": "networkaccess/timeAndDateCondition",
289
+ "fqn": "pulumi_ise.networkaccess",
290
+ "classes": {
291
+ "ise:networkaccess/timeAndDateCondition:TimeAndDateCondition": "TimeAndDateCondition"
292
+ }
293
+ },
294
+ {
295
+ "pkg": "ise",
296
+ "mod": "system/licenseTierState",
297
+ "fqn": "pulumi_ise.system",
298
+ "classes": {
299
+ "ise:system/licenseTierState:LicenseTierState": "LicenseTierState"
300
+ }
301
+ },
302
+ {
303
+ "pkg": "ise",
304
+ "mod": "system/repository",
305
+ "fqn": "pulumi_ise.system",
306
+ "classes": {
307
+ "ise:system/repository:Repository": "Repository"
308
+ }
309
+ },
310
+ {
311
+ "pkg": "ise",
312
+ "mod": "trustsec/egressMatrixCell",
313
+ "fqn": "pulumi_ise.trustsec",
314
+ "classes": {
315
+ "ise:trustsec/egressMatrixCell:EgressMatrixCell": "EgressMatrixCell"
316
+ }
317
+ },
318
+ {
319
+ "pkg": "ise",
320
+ "mod": "trustsec/ipToSgtMapping",
321
+ "fqn": "pulumi_ise.trustsec",
322
+ "classes": {
323
+ "ise:trustsec/ipToSgtMapping:IpToSgtMapping": "IpToSgtMapping"
324
+ }
325
+ },
326
+ {
327
+ "pkg": "ise",
328
+ "mod": "trustsec/ipToSgtMappingGroup",
329
+ "fqn": "pulumi_ise.trustsec",
330
+ "classes": {
331
+ "ise:trustsec/ipToSgtMappingGroup:IpToSgtMappingGroup": "IpToSgtMappingGroup"
332
+ }
333
+ },
334
+ {
335
+ "pkg": "ise",
336
+ "mod": "trustsec/securityGroup",
337
+ "fqn": "pulumi_ise.trustsec",
338
+ "classes": {
339
+ "ise:trustsec/securityGroup:SecurityGroup": "SecurityGroup"
340
+ }
341
+ },
342
+ {
343
+ "pkg": "ise",
344
+ "mod": "trustsec/securityGroupAcl",
345
+ "fqn": "pulumi_ise.trustsec",
346
+ "classes": {
347
+ "ise:trustsec/securityGroupAcl:SecurityGroupAcl": "SecurityGroupAcl"
348
+ }
349
+ }
350
+ ]
351
+ """,
352
+ resource_packages="""
353
+ [
354
+ {
355
+ "pkg": "ise",
356
+ "token": "pulumi:providers:ise",
357
+ "fqn": "pulumi_ise",
358
+ "class": "Provider"
359
+ }
360
+ ]
361
+ """
362
+ )
@@ -0,0 +1,291 @@
1
+ # coding=utf-8
2
+ # *** WARNING: this file was generated by the Pulumi Terraform Bridge (tfgen) Tool. ***
3
+ # *** Do not edit by hand unless you're certain you know what you are doing! ***
4
+
5
+
6
+ import asyncio
7
+ import importlib.metadata
8
+ import importlib.util
9
+ import inspect
10
+ import json
11
+ import os
12
+ import sys
13
+ import typing
14
+
15
+ import pulumi
16
+ import pulumi.runtime
17
+ from pulumi.runtime.sync_await import _sync_await
18
+
19
+ from semver import VersionInfo as SemverVersion
20
+ from parver import Version as PEP440Version
21
+
22
+
23
+ def get_env(*args):
24
+ for v in args:
25
+ value = os.getenv(v)
26
+ if value is not None:
27
+ return value
28
+ return None
29
+
30
+
31
+ def get_env_bool(*args):
32
+ str = get_env(*args)
33
+ if str is not None:
34
+ # NOTE: these values are taken from https://golang.org/src/strconv/atob.go?s=351:391#L1, which is what
35
+ # Terraform uses internally when parsing boolean values.
36
+ if str in ["1", "t", "T", "true", "TRUE", "True"]:
37
+ return True
38
+ if str in ["0", "f", "F", "false", "FALSE", "False"]:
39
+ return False
40
+ return None
41
+
42
+
43
+ def get_env_int(*args):
44
+ str = get_env(*args)
45
+ if str is not None:
46
+ try:
47
+ return int(str)
48
+ except:
49
+ return None
50
+ return None
51
+
52
+
53
+ def get_env_float(*args):
54
+ str = get_env(*args)
55
+ if str is not None:
56
+ try:
57
+ return float(str)
58
+ except:
59
+ return None
60
+ return None
61
+
62
+
63
+ def _get_semver_version():
64
+ # __name__ is set to the fully-qualified name of the current module, In our case, it will be
65
+ # <some module>._utilities. <some module> is the module we want to query the version for.
66
+ root_package, *rest = __name__.split('.')
67
+
68
+ # pkg_resources uses setuptools to inspect the set of installed packages. We use it here to ask
69
+ # for the currently installed version of the root package (i.e. us) and get its version.
70
+
71
+ # Unfortunately, PEP440 and semver differ slightly in incompatible ways. The Pulumi engine expects
72
+ # to receive a valid semver string when receiving requests from the language host, so it's our
73
+ # responsibility as the library to convert our own PEP440 version into a valid semver string.
74
+
75
+ pep440_version_string = importlib.metadata.version(root_package)
76
+ pep440_version = PEP440Version.parse(pep440_version_string)
77
+ (major, minor, patch) = pep440_version.release
78
+ prerelease = None
79
+ if pep440_version.pre_tag == 'a':
80
+ prerelease = f"alpha.{pep440_version.pre}"
81
+ elif pep440_version.pre_tag == 'b':
82
+ prerelease = f"beta.{pep440_version.pre}"
83
+ elif pep440_version.pre_tag == 'rc':
84
+ prerelease = f"rc.{pep440_version.pre}"
85
+ elif pep440_version.dev is not None:
86
+ prerelease = f"dev.{pep440_version.dev}"
87
+
88
+ # The only significant difference between PEP440 and semver as it pertains to us is that PEP440 has explicit support
89
+ # for dev builds, while semver encodes them as "prerelease" versions. In order to bridge between the two, we convert
90
+ # our dev build version into a prerelease tag. This matches what all of our other packages do when constructing
91
+ # their own semver string.
92
+ return SemverVersion(major=major, minor=minor, patch=patch, prerelease=prerelease)
93
+
94
+
95
+ # Determine the version once and cache the value, which measurably improves program performance.
96
+ _version = _get_semver_version()
97
+ _version_str = str(_version)
98
+
99
+
100
+ def get_version():
101
+ return _version_str
102
+
103
+ def get_resource_opts_defaults() -> pulumi.ResourceOptions:
104
+ return pulumi.ResourceOptions(
105
+ version=get_version(),
106
+ plugin_download_url=get_plugin_download_url(),
107
+ )
108
+
109
+ def get_invoke_opts_defaults() -> pulumi.InvokeOptions:
110
+ return pulumi.InvokeOptions(
111
+ version=get_version(),
112
+ plugin_download_url=get_plugin_download_url(),
113
+ )
114
+
115
+ def get_resource_args_opts(resource_args_type, resource_options_type, *args, **kwargs):
116
+ """
117
+ Return the resource args and options given the *args and **kwargs of a resource's
118
+ __init__ method.
119
+ """
120
+
121
+ resource_args, opts = None, None
122
+
123
+ # If the first item is the resource args type, save it and remove it from the args list.
124
+ if args and isinstance(args[0], resource_args_type):
125
+ resource_args, args = args[0], args[1:]
126
+
127
+ # Now look at the first item in the args list again.
128
+ # If the first item is the resource options class, save it.
129
+ if args and isinstance(args[0], resource_options_type):
130
+ opts = args[0]
131
+
132
+ # If resource_args is None, see if "args" is in kwargs, and, if so, if it's typed as the
133
+ # the resource args type.
134
+ if resource_args is None:
135
+ a = kwargs.get("args")
136
+ if isinstance(a, resource_args_type):
137
+ resource_args = a
138
+
139
+ # If opts is None, look it up in kwargs.
140
+ if opts is None:
141
+ opts = kwargs.get("opts")
142
+
143
+ return resource_args, opts
144
+
145
+
146
+ # Temporary: just use pulumi._utils.lazy_import once everyone upgrades.
147
+ def lazy_import(fullname):
148
+
149
+ import pulumi._utils as u
150
+ f = getattr(u, 'lazy_import', None)
151
+ if f is None:
152
+ f = _lazy_import_temp
153
+
154
+ return f(fullname)
155
+
156
+
157
+ # Copied from pulumi._utils.lazy_import, see comments there.
158
+ def _lazy_import_temp(fullname):
159
+ m = sys.modules.get(fullname, None)
160
+ if m is not None:
161
+ return m
162
+
163
+ spec = importlib.util.find_spec(fullname)
164
+
165
+ m = sys.modules.get(fullname, None)
166
+ if m is not None:
167
+ return m
168
+
169
+ loader = importlib.util.LazyLoader(spec.loader)
170
+ spec.loader = loader
171
+ module = importlib.util.module_from_spec(spec)
172
+
173
+ m = sys.modules.get(fullname, None)
174
+ if m is not None:
175
+ return m
176
+
177
+ sys.modules[fullname] = module
178
+ loader.exec_module(module)
179
+ return module
180
+
181
+
182
+ class Package(pulumi.runtime.ResourcePackage):
183
+ def __init__(self, pkg_info):
184
+ super().__init__()
185
+ self.pkg_info = pkg_info
186
+
187
+ def version(self):
188
+ return _version
189
+
190
+ def construct_provider(self, name: str, typ: str, urn: str) -> pulumi.ProviderResource:
191
+ if typ != self.pkg_info['token']:
192
+ raise Exception(f"unknown provider type {typ}")
193
+ Provider = getattr(lazy_import(self.pkg_info['fqn']), self.pkg_info['class'])
194
+ return Provider(name, pulumi.ResourceOptions(urn=urn))
195
+
196
+
197
+ class Module(pulumi.runtime.ResourceModule):
198
+ def __init__(self, mod_info):
199
+ super().__init__()
200
+ self.mod_info = mod_info
201
+
202
+ def version(self):
203
+ return _version
204
+
205
+ def construct(self, name: str, typ: str, urn: str) -> pulumi.Resource:
206
+ class_name = self.mod_info['classes'].get(typ, None)
207
+
208
+ if class_name is None:
209
+ raise Exception(f"unknown resource type {typ}")
210
+
211
+ TheClass = getattr(lazy_import(self.mod_info['fqn']), class_name)
212
+ return TheClass(name, pulumi.ResourceOptions(urn=urn))
213
+
214
+
215
+ def register(resource_modules, resource_packages):
216
+ resource_modules = json.loads(resource_modules)
217
+ resource_packages = json.loads(resource_packages)
218
+
219
+ for pkg_info in resource_packages:
220
+ pulumi.runtime.register_resource_package(pkg_info['pkg'], Package(pkg_info))
221
+
222
+ for mod_info in resource_modules:
223
+ pulumi.runtime.register_resource_module(
224
+ mod_info['pkg'],
225
+ mod_info['mod'],
226
+ Module(mod_info))
227
+
228
+
229
+ _F = typing.TypeVar('_F', bound=typing.Callable[..., typing.Any])
230
+
231
+
232
+ def lift_output_func(func: typing.Any) -> typing.Callable[[_F], _F]:
233
+ """Decorator internally used on {fn}_output lifted function versions
234
+ to implement them automatically from the un-lifted function."""
235
+
236
+ func_sig = inspect.signature(func)
237
+
238
+ def lifted_func(*args, opts=None, **kwargs):
239
+ bound_args = func_sig.bind(*args, **kwargs)
240
+ # Convert tuple to list, see pulumi/pulumi#8172
241
+ args_list = list(bound_args.args)
242
+ return pulumi.Output.from_input({
243
+ 'args': args_list,
244
+ 'kwargs': bound_args.kwargs
245
+ }).apply(lambda resolved_args: func(*resolved_args['args'],
246
+ opts=opts,
247
+ **resolved_args['kwargs']))
248
+
249
+ return (lambda _: lifted_func)
250
+
251
+
252
+ def call_plain(
253
+ tok: str,
254
+ props: pulumi.Inputs,
255
+ res: typing.Optional[pulumi.Resource] = None,
256
+ typ: typing.Optional[type] = None,
257
+ ) -> typing.Any:
258
+ """
259
+ Wraps pulumi.runtime.plain to force the output and return it plainly.
260
+ """
261
+
262
+ output = pulumi.runtime.call(tok, props, res, typ)
263
+
264
+ # Ingoring deps silently. They are typically non-empty, r.f() calls include r as a dependency.
265
+ result, known, secret, _ = _sync_await(asyncio.ensure_future(_await_output(output)))
266
+
267
+ problem = None
268
+ if not known:
269
+ problem = ' an unknown value'
270
+ elif secret:
271
+ problem = ' a secret value'
272
+
273
+ if problem:
274
+ raise AssertionError(
275
+ f"Plain resource method '{tok}' incorrectly returned {problem}. "
276
+ + "This is an error in the provider, please report this to the provider developer."
277
+ )
278
+
279
+ return result
280
+
281
+
282
+ async def _await_output(o: pulumi.Output[typing.Any]) -> typing.Tuple[object, bool, bool, set]:
283
+ return (
284
+ await o._future,
285
+ await o._is_known,
286
+ await o._is_secret,
287
+ await o._resources,
288
+ )
289
+
290
+ def get_plugin_download_url():
291
+ return None
@@ -0,0 +1,8 @@
1
+ # coding=utf-8
2
+ # *** WARNING: this file was generated by the Pulumi Terraform Bridge (tfgen) Tool. ***
3
+ # *** Do not edit by hand unless you're certain you know what you are doing! ***
4
+
5
+ import sys
6
+ from .vars import _ExportableConfig
7
+
8
+ sys.modules[__name__].__class__ = _ExportableConfig
@@ -0,0 +1,36 @@
1
+ # coding=utf-8
2
+ # *** WARNING: this file was generated by the Pulumi Terraform Bridge (tfgen) Tool. ***
3
+ # *** Do not edit by hand unless you're certain you know what you are doing! ***
4
+
5
+ import copy
6
+ import warnings
7
+ import pulumi
8
+ import pulumi.runtime
9
+ from typing import Any, Mapping, Optional, Sequence, Union, overload
10
+ from .. import _utilities
11
+
12
+ insecure: Optional[bool]
13
+ """
14
+ Allow insecure HTTPS client. This can also be set as the ISE_INSECURE environment variable. Defaults to `true`.
15
+ """
16
+
17
+ password: Optional[str]
18
+ """
19
+ Password for the ISE instance. This can also be set as the ISE_PASSWORD environment variable.
20
+ """
21
+
22
+ retries: Optional[int]
23
+ """
24
+ Number of retries for REST API calls. This can also be set as the ISE_RETRIES environment variable. Defaults to `3`.
25
+ """
26
+
27
+ url: Optional[str]
28
+ """
29
+ URL of the Cisco ISE instance. This can also be set as the ISE_URL environment variable.
30
+ """
31
+
32
+ username: Optional[str]
33
+ """
34
+ Username for the ISE instance. This can also be set as the ISE_USERNAME environment variable.
35
+ """
36
+