agilicus 1.258.12__py3-none-any.whl → 1.259.2__py3-none-any.whl
Sign up to get free protection for your applications and to get access to all the features.
- agilicus/agilicus_api/api_client.py +1 -1
- agilicus/agilicus_api/configuration.py +1 -1
- agilicus/agilicus_api_README.md +1 -1
- agilicus/output/json.py +8 -0
- agilicus/policy/policies.py +41 -1
- agilicus/policy/policy_main.py +26 -0
- {agilicus-1.258.12.dist-info → agilicus-1.259.2.dist-info}/METADATA +2 -2
- {agilicus-1.258.12.dist-info → agilicus-1.259.2.dist-info}/RECORD +11 -11
- {agilicus-1.258.12.dist-info → agilicus-1.259.2.dist-info}/LICENSE.txt +0 -0
- {agilicus-1.258.12.dist-info → agilicus-1.259.2.dist-info}/WHEEL +0 -0
- {agilicus-1.258.12.dist-info → agilicus-1.259.2.dist-info}/entry_points.txt +0 -0
@@ -77,7 +77,7 @@ class ApiClient(object):
|
|
77
77
|
self.default_headers[header_name] = header_value
|
78
78
|
self.cookie = cookie
|
79
79
|
# Set default User-Agent.
|
80
|
-
self.user_agent = 'OpenAPI-Generator/1.
|
80
|
+
self.user_agent = 'OpenAPI-Generator/1.259.2/python'
|
81
81
|
|
82
82
|
def __enter__(self):
|
83
83
|
return self
|
@@ -387,7 +387,7 @@ class Configuration(object):
|
|
387
387
|
"OS: {env}\n"\
|
388
388
|
"Python Version: {pyversion}\n"\
|
389
389
|
"Version of the API: 2024.06.07\n"\
|
390
|
-
"SDK Package Version: 1.
|
390
|
+
"SDK Package Version: 1.259.2".\
|
391
391
|
format(env=sys.platform, pyversion=sys.version)
|
392
392
|
|
393
393
|
def get_host_settings(self):
|
agilicus/agilicus_api_README.md
CHANGED
@@ -4,7 +4,7 @@ Agilicus is API-first. Modern software is controlled by other software, is open,
|
|
4
4
|
The `agilicus_api` package is automatically generated by the [OpenAPI Generator](https://openapi-generator.tech) project:
|
5
5
|
|
6
6
|
- API version: 2024.06.07
|
7
|
-
- Package version: 1.
|
7
|
+
- Package version: 1.259.2
|
8
8
|
- Build package: org.openapitools.codegen.languages.PythonClientCodegen
|
9
9
|
For more information, please visit [https://www.agilicus.com/api](https://www.agilicus.com/api)
|
10
10
|
|
agilicus/output/json.py
CHANGED
@@ -8,6 +8,14 @@ def jsonify(ctx, entry):
|
|
8
8
|
|
9
9
|
|
10
10
|
def json_output_default(o):
|
11
|
+
try:
|
12
|
+
# The classes in our API do not serialise.
|
13
|
+
# attempt a to_dict. If that passes, use it,
|
14
|
+
# else continue to check for date
|
15
|
+
o = o.to_dict()
|
16
|
+
return o
|
17
|
+
except AttributeError:
|
18
|
+
pass
|
11
19
|
if isinstance(o, (datetime.date, datetime.datetime)):
|
12
20
|
return o.isoformat()
|
13
21
|
return None
|
agilicus/policy/policies.py
CHANGED
@@ -1,5 +1,7 @@
|
|
1
|
+
import copy
|
1
2
|
from ..input_helpers import (
|
2
3
|
get_org_from_input_or_ctx,
|
4
|
+
model_from_dict,
|
3
5
|
strip_none,
|
4
6
|
)
|
5
7
|
|
@@ -16,6 +18,8 @@ from agilicus import (
|
|
16
18
|
SimpleResourcePolicyTemplateStructure,
|
17
19
|
SimpleResourcePolicyTemplate,
|
18
20
|
StandaloneRuleName,
|
21
|
+
RuleCondition,
|
22
|
+
HttpRuleCondition,
|
19
23
|
EmptiableObjectType,
|
20
24
|
)
|
21
25
|
|
@@ -227,7 +231,9 @@ def migrate_resource(ctx, resource):
|
|
227
231
|
)
|
228
232
|
)
|
229
233
|
template = SimpleResourcePolicyTemplate(
|
230
|
-
rules=
|
234
|
+
rules=[
|
235
|
+
_migrate_http_rule(rule) for rule in resource.spec.config.rules_config.rules
|
236
|
+
],
|
231
237
|
policy_structure=policy_structures,
|
232
238
|
template_type="simple_resource",
|
233
239
|
)
|
@@ -259,3 +265,37 @@ def migrate_resource(ctx, resource):
|
|
259
265
|
to_dict=False,
|
260
266
|
)
|
261
267
|
return resp
|
268
|
+
|
269
|
+
|
270
|
+
def _migrate_http_rule(input_rule):
|
271
|
+
if input_rule.extended_condition is not None:
|
272
|
+
return input_rule
|
273
|
+
|
274
|
+
new_rule = copy.deepcopy(input_rule)
|
275
|
+
input_cond = new_rule.condition.to_dict()
|
276
|
+
input_cond["condition_type"] = "http_rule_condition"
|
277
|
+
cond = model_from_dict(HttpRuleCondition, input_cond)
|
278
|
+
new_rule.extended_condition = RuleCondition(
|
279
|
+
condition=cond,
|
280
|
+
negated=False,
|
281
|
+
)
|
282
|
+
del new_rule["condition"]
|
283
|
+
return new_rule
|
284
|
+
|
285
|
+
|
286
|
+
def create_policy_template(ctx, template_dict, **kwargs):
|
287
|
+
template_as_instance = model_from_dict(PolicyTemplateInstance, template_dict)
|
288
|
+
token = context.get_token(ctx)
|
289
|
+
apiclient = context.get_apiclient(ctx, token)
|
290
|
+
return apiclient.policy_templates_api.create_policy_template_instance(
|
291
|
+
template_as_instance
|
292
|
+
)
|
293
|
+
|
294
|
+
|
295
|
+
def replace_policy_template(ctx, instance_id, template_dict, **kwargs):
|
296
|
+
template_as_instance = model_from_dict(PolicyTemplateInstance, template_dict)
|
297
|
+
token = context.get_token(ctx)
|
298
|
+
apiclient = context.get_apiclient(ctx, token)
|
299
|
+
return apiclient.policy_templates_api.replace_policy_template_instance(
|
300
|
+
instance_id, policy_template_instance=template_as_instance
|
301
|
+
)
|
agilicus/policy/policy_main.py
CHANGED
@@ -1,4 +1,5 @@
|
|
1
1
|
import click
|
2
|
+
import click_extension
|
2
3
|
|
3
4
|
from . import policies
|
4
5
|
from ..output.table import output_entry
|
@@ -56,6 +57,31 @@ def cli_command_get_policy_template(ctx, **kwargs):
|
|
56
57
|
output_entry(ctx, policies.get_policy_template(ctx, **kwargs).to_dict())
|
57
58
|
|
58
59
|
|
60
|
+
@click.command(name="create-policy-template")
|
61
|
+
@click.option("--template-json-file", required=True, type=click_extension.JSONFile("r"))
|
62
|
+
@click.pass_context
|
63
|
+
def cli_command_create_policy_template(ctx, template_json_file, **kwargs):
|
64
|
+
output_entry(
|
65
|
+
ctx,
|
66
|
+
policies.create_policy_template(
|
67
|
+
ctx, template_dict=template_json_file, **kwargs
|
68
|
+
).to_dict(),
|
69
|
+
)
|
70
|
+
|
71
|
+
|
72
|
+
@click.command(name="replace-policy-template")
|
73
|
+
@click.option("--instance-id", required=True, type=str)
|
74
|
+
@click.option("--template-json-file", required=True, type=click_extension.JSONFile("r"))
|
75
|
+
@click.pass_context
|
76
|
+
def cli_command_replace_policy_template(ctx, template_json_file, **kwargs):
|
77
|
+
output_entry(
|
78
|
+
ctx,
|
79
|
+
policies.replace_policy_template(
|
80
|
+
ctx, template_dict=template_json_file, **kwargs
|
81
|
+
).to_dict(),
|
82
|
+
)
|
83
|
+
|
84
|
+
|
59
85
|
@click.command(name="delete-policy-template")
|
60
86
|
@click.option("--instance-id", default=None, required=True)
|
61
87
|
@click.option("--org-id", default=None)
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: agilicus
|
3
|
-
Version: 1.
|
3
|
+
Version: 1.259.2
|
4
4
|
Summary: Agilicus SDK
|
5
5
|
Home-page: https://www.agilicus.com/
|
6
6
|
License: MIT
|
@@ -14,7 +14,7 @@ Classifier: Programming Language :: Python :: 3.9
|
|
14
14
|
Classifier: Programming Language :: Python :: 3.10
|
15
15
|
Classifier: Programming Language :: Python :: 3.11
|
16
16
|
Provides-Extra: billing
|
17
|
-
Requires-Dist: PyJWT (>=2.
|
17
|
+
Requires-Dist: PyJWT (>=2.8.0,<3.0.0)
|
18
18
|
Requires-Dist: appdirs (>=1.4.4,<2.0.0)
|
19
19
|
Requires-Dist: babel (>=2.13.1,<3.0.0)
|
20
20
|
Requires-Dist: certifi (>=14.05.14)
|
@@ -71,9 +71,9 @@ agilicus/agilicus_api/api/users_api.py,sha256=vB0sKWct34S8spWM5V_cIXNnJYymsxi6Hj
|
|
71
71
|
agilicus/agilicus_api/api/users_api_mock.py,sha256=wA_xiqL3Pz3KjljKlsmf5NveLZS1FpbaKJHBp7QvarY,15411
|
72
72
|
agilicus/agilicus_api/api/whoami_api.py,sha256=n8pLGSBrUCi188FvTqP_xnVOfZIeabOK8v-UYTvWlKg,7941
|
73
73
|
agilicus/agilicus_api/api/whoami_api_mock.py,sha256=rlvZoWnMCqORMZBg7SOv6d3xp52kELdh6wXcCaIZ93w,346
|
74
|
-
agilicus/agilicus_api/api_client.py,sha256=
|
74
|
+
agilicus/agilicus_api/api_client.py,sha256=gi4KvwypTeyFhsso7xLlI4mE4ZtdwA0WQhc0klkvYPE,38845
|
75
75
|
agilicus/agilicus_api/apis/__init__.py,sha256=aJZD7x-umdSni6ZBr4XxzpH8pwtU9hA5LlCDxcqa1Q8,2224
|
76
|
-
agilicus/agilicus_api/configuration.py,sha256=
|
76
|
+
agilicus/agilicus_api/configuration.py,sha256=Us2ORRFgkTNGaOBAKBZeJb2tpewKj4PvsWNilHTfCVQ,18447
|
77
77
|
agilicus/agilicus_api/docs/APIKey.md,sha256=4cKuz4_l9HcEDnUrLwYbEnn9C2WoDayrjfrY1Ixgaf4,1747
|
78
78
|
agilicus/agilicus_api/docs/APIKeyIntrospect.md,sha256=nJ-zkuFm3JMbWFDYYN_vYyQk1snGBtBvIxtCQxamhAU,1019
|
79
79
|
agilicus/agilicus_api/docs/APIKeyIntrospectAuthorizationInfo.md,sha256=7RApOOLjvWQs5sw2jb25g7i3Kta1BiEY-s8VRXfppH8,725
|
@@ -2508,7 +2508,7 @@ agilicus/agilicus_api/test/test_x509_root_certificate.py,sha256=bg6sEfQxbFJV4g4E
|
|
2508
2508
|
agilicus/agilicus_api/test/test_x509_root_certificate_spec.py,sha256=4DXwyUGi6wJhmjp2gUm9jBqA_j_rPjwOwEACfpZ1L_k,2832
|
2509
2509
|
agilicus/agilicus_api/test/test_x509_root_certificate_status.py,sha256=5I8JM71Z_dR9ujggxPAgfv2ggO4P55y1FRViLXZiQTo,2846
|
2510
2510
|
agilicus/agilicus_api/test/test_xss_settings.py,sha256=jm4mFfUvM6c1vQToM-97bhMoJIkCxaXTni-l-jLAtQg,2746
|
2511
|
-
agilicus/agilicus_api_README.md,sha256=
|
2511
|
+
agilicus/agilicus_api_README.md,sha256=Fr03sFJHYq4hOvOstV8dRXBbBQ8-aLgYZLazuqHUr_0,160942
|
2512
2512
|
agilicus/aliases.ini,sha256=MxqiVo2f2xdUDVF1YDkNW36AIqN8hrYjlTVfraEUZXY,455
|
2513
2513
|
agilicus/amq.py,sha256=yxi-YTbJPVl10s78Hlr1dmrQR63iaSIoROGVILzFPmE,1775
|
2514
2514
|
agilicus/apps.py,sha256=QMiV9ThED6lqS2l7Jr5Mei7fNBo8FEvPEtCae1NK3Pk,51814
|
@@ -2565,15 +2565,15 @@ agilicus/orgs.py,sha256=cj8UW2nG5D7mR_OUrwHB1P6BOHg-XGGiWX06PDhu7kI,14179
|
|
2565
2565
|
agilicus/output/__init__.py,sha256=UKZbHS4t15vazJuN46FN-3HHqkxMXU0p3df2VcsSLcY,110
|
2566
2566
|
agilicus/output/column_builder.py,sha256=TWo4t8ygaTUv7qjD_moDroD1bKzzyTIao0FmLy5gs4o,4284
|
2567
2567
|
agilicus/output/console.py,sha256=xBURxlA7H1kmQ7zIKuifs_aQJq1cvmCJ5CtQVSo3_Ns,400
|
2568
|
-
agilicus/output/json.py,sha256
|
2568
|
+
agilicus/output/json.py,sha256=-5bX7ud1hIxux4l3P-K2gJXrE2gdZ0Ua1hfUOCX9MUM,899
|
2569
2569
|
agilicus/output/table.py,sha256=slOLs30rybyZYFGNd_5bh4gVVz7tNafg3sey_20H1w8,7906
|
2570
2570
|
agilicus/output/tests/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
2571
2571
|
agilicus/output/tests/column_builder_test.py,sha256=fKP4V5sqXtmEIr-Q0gWVSFdBqCUtugZkP6G5gML_T7I,2130
|
2572
2572
|
agilicus/pagination/pagination.py,sha256=hC7eLHxXKe4Iv7LdOZK3Dh8R_fKQIr9PPiWKJVyP4Nk,1672
|
2573
2573
|
agilicus/patches.py,sha256=qTqLOgCAcFZPcPOkgfqMnK9bnqTXMvj_0ERsjRFcZug,1384
|
2574
2574
|
agilicus/permissions.py,sha256=uB65yuDFICp1N10m0cdUjgizx9MQzAbLbAsBSTw1Rcc,2117
|
2575
|
-
agilicus/policy/policies.py,sha256=
|
2576
|
-
agilicus/policy/policy_main.py,sha256=
|
2575
|
+
agilicus/policy/policies.py,sha256=H4MKMJJuuQ7LsXRKH7d7TrcGLvzIkcuC5FmyO5OD1AE,8817
|
2576
|
+
agilicus/policy/policy_main.py,sha256=0fASWbzeWpaQEjwX5VOg90ZI-HZvOLCPJdrV3ahd4Hk,3732
|
2577
2577
|
agilicus/policy/templates.py,sha256=EUvAhOhSjDuLAe2UKIFEzBp5pNpOT5y1r7uyV_GG6uI,5638
|
2578
2578
|
agilicus/policy_config/policy_config.py,sha256=s1GwbBI5wuLINcViTKE8NdfcntLEegwpUEi7pqmdKkY,627
|
2579
2579
|
agilicus/policy_config/policy_config_main.py,sha256=ReiOziCvPShjunCt3ohrEMGq0IaP0eNyIXEvEg_WD1M,788
|
@@ -2599,8 +2599,8 @@ agilicus/trusted_certs/trusted_certs_main.py,sha256=6dHHWXvNIcUa_nA9ptigL4Vibe4n
|
|
2599
2599
|
agilicus/users.py,sha256=JT7TIiUOtSFXPOdxmIVFm7ygZTH1FjsIkD9j-vjLuMM,38474
|
2600
2600
|
agilicus/version.py,sha256=G9OFdL1v_4dLDfk6I6taDNypM5bbO-JHAwilsu9LYgg,23
|
2601
2601
|
agilicus/whoami.py,sha256=kqghtWMgZOd2rhKmfguDwCTm6A3gNS8Kj-S2IBxBtl0,206
|
2602
|
-
agilicus-1.
|
2603
|
-
agilicus-1.
|
2604
|
-
agilicus-1.
|
2605
|
-
agilicus-1.
|
2606
|
-
agilicus-1.
|
2602
|
+
agilicus-1.259.2.dist-info/LICENSE.txt,sha256=Zq4tqiCroC2CVrBB_PWjapRdvpae23nljdiaSkOzUho,1061
|
2603
|
+
agilicus-1.259.2.dist-info/METADATA,sha256=51RomgkReSYsdywA6igL3PHxLL4h5aYiR_4UqfZy25U,3822
|
2604
|
+
agilicus-1.259.2.dist-info/WHEEL,sha256=Zb28QaM1gQi8f4VCBhsUklF61CTlNYfs9YAZn-TOGFk,88
|
2605
|
+
agilicus-1.259.2.dist-info/entry_points.txt,sha256=a66hGozzLkHu0IewFzIMbSAhMTNTddUaA2T3_16Gb_s,51
|
2606
|
+
agilicus-1.259.2.dist-info/RECORD,,
|
File without changes
|
File without changes
|
File without changes
|