From 20271a4938817bfd79c18921dcd0116060844735 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kamil=20K=C4=99dziak?= Date: Wed, 13 Nov 2024 10:58:10 +0000 Subject: [PATCH 1/3] docs: add the print page (#407) **Issue number:** ADDON-75611 ## Summary ### Changes > Please provide a summary of what's being changed Documentation changes: added print button that shows the whole documentation on one page. In order to enable this feature, first level headings needed to be added to files. ### User experience > Please describe what the user experience looks like before and after this change None ## Checklist If your change doesn't seem to apply, please leave them unchecked. * [x] I have performed a self-review of this change * [ ] Changes have been tested * [ ] Changes are documented * [x] PR title follows [conventional commit semantics](https://www.conventionalcommits.org/en/v1.0.0/) --- docs/acl.md | 2 + docs/bulletin_rest_client.md | 2 + docs/conf_manager.md | 2 + docs/credentials.md | 2 + docs/file_monitor.md | 2 + docs/hec_config.md | 2 + docs/log.md | 2 + docs/modular_input/checkpointer.md | 2 + docs/modular_input/event.md | 2 + docs/modular_input/event_writer.md | 2 + docs/modular_input/modular_input.md | 2 + docs/net_utils.md | 2 + docs/orphan_process_monitor.md | 2 + docs/pattern.md | 2 + docs/server_info.md | 2 + docs/splunk_rest_client.md | 2 + docs/splunkenv.md | 2 + docs/theme_overrides/partials/header.html | 104 ++++++++++ docs/time_parser.md | 2 + docs/timer_queue.md | 2 + docs/user_access.md | 2 + docs/utils.md | 2 + mkdocs.yml | 8 +- poetry.lock | 226 ++++++++++++---------- pyproject.toml | 1 + solnlib/log.py | 4 +- 26 files changed, 285 insertions(+), 100 deletions(-) create mode 100644 docs/theme_overrides/partials/header.html diff --git a/docs/acl.md b/docs/acl.md index 2e5f914b..bc1dbc5c 100644 --- a/docs/acl.md +++ b/docs/acl.md @@ -1 +1,3 @@ +# acl.py + ::: solnlib.acl \ No newline at end of file diff --git a/docs/bulletin_rest_client.md b/docs/bulletin_rest_client.md index 361aff8d..581e51e2 100644 --- a/docs/bulletin_rest_client.md +++ b/docs/bulletin_rest_client.md @@ -1 +1,3 @@ +# bulletin_rest_client.py + ::: solnlib.bulletin_rest_client \ No newline at end of file diff --git a/docs/conf_manager.md b/docs/conf_manager.md index 26c591ac..6c0dd1c1 100644 --- a/docs/conf_manager.md +++ b/docs/conf_manager.md @@ -1 +1,3 @@ +# conf_manager.py + ::: solnlib.conf_manager \ No newline at end of file diff --git a/docs/credentials.md b/docs/credentials.md index 9be2640c..b61716c9 100644 --- a/docs/credentials.md +++ b/docs/credentials.md @@ -1 +1,3 @@ +# credentials.py + ::: solnlib.credentials \ No newline at end of file diff --git a/docs/file_monitor.md b/docs/file_monitor.md index e05d2dda..21be0f0b 100644 --- a/docs/file_monitor.md +++ b/docs/file_monitor.md @@ -1 +1,3 @@ +# file_monitor.py + ::: solnlib.file_monitor \ No newline at end of file diff --git a/docs/hec_config.md b/docs/hec_config.md index 82717847..7794f53c 100644 --- a/docs/hec_config.md +++ b/docs/hec_config.md @@ -1 +1,3 @@ +# hec_config.py + ::: solnlib.hec_config \ No newline at end of file diff --git a/docs/log.md b/docs/log.md index 38efe335..d5a02162 100644 --- a/docs/log.md +++ b/docs/log.md @@ -1 +1,3 @@ +# log.py + ::: solnlib.log \ No newline at end of file diff --git a/docs/modular_input/checkpointer.md b/docs/modular_input/checkpointer.md index 00cbe6d1..09fabdc8 100644 --- a/docs/modular_input/checkpointer.md +++ b/docs/modular_input/checkpointer.md @@ -1 +1,3 @@ +# checkpointer.py + ::: solnlib.modular_input.checkpointer \ No newline at end of file diff --git a/docs/modular_input/event.md b/docs/modular_input/event.md index 7e1ced64..d0b14b92 100644 --- a/docs/modular_input/event.md +++ b/docs/modular_input/event.md @@ -1 +1,3 @@ +# event.py + ::: solnlib.modular_input.event \ No newline at end of file diff --git a/docs/modular_input/event_writer.md b/docs/modular_input/event_writer.md index caabce76..23726f3f 100644 --- a/docs/modular_input/event_writer.md +++ b/docs/modular_input/event_writer.md @@ -1 +1,3 @@ +# event_writer.py + ::: solnlib.modular_input.event_writer \ No newline at end of file diff --git a/docs/modular_input/modular_input.md b/docs/modular_input/modular_input.md index b1fa2047..a0694e9f 100644 --- a/docs/modular_input/modular_input.md +++ b/docs/modular_input/modular_input.md @@ -1 +1,3 @@ +# modular_input.py + ::: solnlib.modular_input.modular_input \ No newline at end of file diff --git a/docs/net_utils.md b/docs/net_utils.md index fb88d597..b412a6b5 100644 --- a/docs/net_utils.md +++ b/docs/net_utils.md @@ -1 +1,3 @@ +# net_utils.py + ::: solnlib.net_utils \ No newline at end of file diff --git a/docs/orphan_process_monitor.md b/docs/orphan_process_monitor.md index bd30e95f..cf306ff4 100644 --- a/docs/orphan_process_monitor.md +++ b/docs/orphan_process_monitor.md @@ -1 +1,3 @@ +# orphan_process_monitor.py + ::: solnlib.orphan_process_monitor \ No newline at end of file diff --git a/docs/pattern.md b/docs/pattern.md index f583db80..3cd25835 100644 --- a/docs/pattern.md +++ b/docs/pattern.md @@ -1 +1,3 @@ +# pattern.py + ::: solnlib.pattern \ No newline at end of file diff --git a/docs/server_info.md b/docs/server_info.md index 84862f94..4bd076d6 100644 --- a/docs/server_info.md +++ b/docs/server_info.md @@ -1 +1,3 @@ +# server_info.py + ::: solnlib.server_info \ No newline at end of file diff --git a/docs/splunk_rest_client.md b/docs/splunk_rest_client.md index b4eb6ade..86893ff8 100644 --- a/docs/splunk_rest_client.md +++ b/docs/splunk_rest_client.md @@ -1 +1,3 @@ +# splunk_rest_client.py + ::: solnlib.splunk_rest_client \ No newline at end of file diff --git a/docs/splunkenv.md b/docs/splunkenv.md index 1ef4f75b..c8b8d2ba 100644 --- a/docs/splunkenv.md +++ b/docs/splunkenv.md @@ -1 +1,3 @@ +# splunkenv.py + ::: solnlib.splunkenv \ No newline at end of file diff --git a/docs/theme_overrides/partials/header.html b/docs/theme_overrides/partials/header.html new file mode 100644 index 00000000..ba7f8bcb --- /dev/null +++ b/docs/theme_overrides/partials/header.html @@ -0,0 +1,104 @@ + + +{% set class = "md-header" %} +{% if "navigation.tabs.sticky" in features %} + {% set class = class ~ " md-header--shadow md-header--lifted" %} +{% elif "navigation.tabs" not in features %} + {% set class = class ~ " md-header--shadow" %} +{% endif %} + + +
+ + + + {% if "navigation.tabs.sticky" in features %} + {% if "navigation.tabs" in features %} + {% include "partials/tabs.html" %} + {% endif %} + {% endif %} +
diff --git a/docs/time_parser.md b/docs/time_parser.md index 872d8699..802d1263 100644 --- a/docs/time_parser.md +++ b/docs/time_parser.md @@ -1 +1,3 @@ +# time_parser.py + ::: solnlib.time_parser \ No newline at end of file diff --git a/docs/timer_queue.md b/docs/timer_queue.md index 2d8e8c73..717e8723 100644 --- a/docs/timer_queue.md +++ b/docs/timer_queue.md @@ -1 +1,3 @@ +# timer_queue.py + ::: solnlib.timer_queue \ No newline at end of file diff --git a/docs/user_access.md b/docs/user_access.md index 1b9eb265..4d6e215a 100644 --- a/docs/user_access.md +++ b/docs/user_access.md @@ -1 +1,3 @@ +# user_access.py + ::: solnlib.user_access \ No newline at end of file diff --git a/docs/utils.md b/docs/utils.md index ff19c387..86a50254 100644 --- a/docs/utils.md +++ b/docs/utils.md @@ -1 +1,3 @@ +# utils.py + ::: solnlib.utils \ No newline at end of file diff --git a/mkdocs.yml b/mkdocs.yml index 04e27ab8..5aa2bfaa 100644 --- a/mkdocs.yml +++ b/mkdocs.yml @@ -2,9 +2,13 @@ site_name: Splunk Solutions SDK theme: name: "material" + custom_dir: docs/theme_overrides palette: primary: "black" accent: "orange" + features: + - content.code.copy + - navigation.indexes markdown_extensions: - toc: @@ -15,12 +19,14 @@ markdown_extensions: - codehilite plugins: - - search - mkdocstrings: handlers: python: options: show_if_no_docstring: true + - autorefs + - search + - print-site # should be at the end nav: - Home: index.md diff --git a/poetry.lock b/poetry.lock index edbd1274..2edcf927 100644 --- a/poetry.lock +++ b/poetry.lock @@ -41,101 +41,116 @@ files = [ [[package]] name = "charset-normalizer" -version = "3.3.2" +version = "3.4.0" description = "The Real First Universal Charset Detector. Open, modern and actively maintained alternative to Chardet." optional = false python-versions = ">=3.7.0" files = [ - {file = "charset-normalizer-3.3.2.tar.gz", hash = "sha256:f30c3cb33b24454a82faecaf01b19c18562b1e89558fb6c56de4d9118a032fd5"}, - {file = "charset_normalizer-3.3.2-cp310-cp310-macosx_10_9_universal2.whl", hash = "sha256:25baf083bf6f6b341f4121c2f3c548875ee6f5339300e08be3f2b2ba1721cdd3"}, - {file = "charset_normalizer-3.3.2-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:06435b539f889b1f6f4ac1758871aae42dc3a8c0e24ac9e60c2384973ad73027"}, - {file = "charset_normalizer-3.3.2-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:9063e24fdb1e498ab71cb7419e24622516c4a04476b17a2dab57e8baa30d6e03"}, - {file = "charset_normalizer-3.3.2-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:6897af51655e3691ff853668779c7bad41579facacf5fd7253b0133308cf000d"}, - {file = "charset_normalizer-3.3.2-cp310-cp310-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:1d3193f4a680c64b4b6a9115943538edb896edc190f0b222e73761716519268e"}, - {file = "charset_normalizer-3.3.2-cp310-cp310-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:cd70574b12bb8a4d2aaa0094515df2463cb429d8536cfb6c7ce983246983e5a6"}, - {file = "charset_normalizer-3.3.2-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:8465322196c8b4d7ab6d1e049e4c5cb460d0394da4a27d23cc242fbf0034b6b5"}, - {file = "charset_normalizer-3.3.2-cp310-cp310-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:a9a8e9031d613fd2009c182b69c7b2c1ef8239a0efb1df3f7c8da66d5dd3d537"}, - {file = "charset_normalizer-3.3.2-cp310-cp310-musllinux_1_1_aarch64.whl", hash = "sha256:beb58fe5cdb101e3a055192ac291b7a21e3b7ef4f67fa1d74e331a7f2124341c"}, - {file = "charset_normalizer-3.3.2-cp310-cp310-musllinux_1_1_i686.whl", hash = "sha256:e06ed3eb3218bc64786f7db41917d4e686cc4856944f53d5bdf83a6884432e12"}, - {file = "charset_normalizer-3.3.2-cp310-cp310-musllinux_1_1_ppc64le.whl", hash = "sha256:2e81c7b9c8979ce92ed306c249d46894776a909505d8f5a4ba55b14206e3222f"}, - {file = "charset_normalizer-3.3.2-cp310-cp310-musllinux_1_1_s390x.whl", hash = "sha256:572c3763a264ba47b3cf708a44ce965d98555f618ca42c926a9c1616d8f34269"}, - {file = "charset_normalizer-3.3.2-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:fd1abc0d89e30cc4e02e4064dc67fcc51bd941eb395c502aac3ec19fab46b519"}, - {file = "charset_normalizer-3.3.2-cp310-cp310-win32.whl", hash = "sha256:3d47fa203a7bd9c5b6cee4736ee84ca03b8ef23193c0d1ca99b5089f72645c73"}, - {file = "charset_normalizer-3.3.2-cp310-cp310-win_amd64.whl", hash = "sha256:10955842570876604d404661fbccbc9c7e684caf432c09c715ec38fbae45ae09"}, - {file = "charset_normalizer-3.3.2-cp311-cp311-macosx_10_9_universal2.whl", hash = "sha256:802fe99cca7457642125a8a88a084cef28ff0cf9407060f7b93dca5aa25480db"}, - {file = "charset_normalizer-3.3.2-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:573f6eac48f4769d667c4442081b1794f52919e7edada77495aaed9236d13a96"}, - {file = "charset_normalizer-3.3.2-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:549a3a73da901d5bc3ce8d24e0600d1fa85524c10287f6004fbab87672bf3e1e"}, - {file = "charset_normalizer-3.3.2-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:f27273b60488abe721a075bcca6d7f3964f9f6f067c8c4c605743023d7d3944f"}, - {file = "charset_normalizer-3.3.2-cp311-cp311-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:1ceae2f17a9c33cb48e3263960dc5fc8005351ee19db217e9b1bb15d28c02574"}, - {file = "charset_normalizer-3.3.2-cp311-cp311-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:65f6f63034100ead094b8744b3b97965785388f308a64cf8d7c34f2f2e5be0c4"}, - {file = "charset_normalizer-3.3.2-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:753f10e867343b4511128c6ed8c82f7bec3bd026875576dfd88483c5c73b2fd8"}, - {file = "charset_normalizer-3.3.2-cp311-cp311-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:4a78b2b446bd7c934f5dcedc588903fb2f5eec172f3d29e52a9096a43722adfc"}, - {file = "charset_normalizer-3.3.2-cp311-cp311-musllinux_1_1_aarch64.whl", hash = "sha256:e537484df0d8f426ce2afb2d0f8e1c3d0b114b83f8850e5f2fbea0e797bd82ae"}, - {file = "charset_normalizer-3.3.2-cp311-cp311-musllinux_1_1_i686.whl", hash = "sha256:eb6904c354526e758fda7167b33005998fb68c46fbc10e013ca97f21ca5c8887"}, - {file = "charset_normalizer-3.3.2-cp311-cp311-musllinux_1_1_ppc64le.whl", hash = "sha256:deb6be0ac38ece9ba87dea880e438f25ca3eddfac8b002a2ec3d9183a454e8ae"}, - {file = "charset_normalizer-3.3.2-cp311-cp311-musllinux_1_1_s390x.whl", hash = "sha256:4ab2fe47fae9e0f9dee8c04187ce5d09f48eabe611be8259444906793ab7cbce"}, - {file = "charset_normalizer-3.3.2-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:80402cd6ee291dcb72644d6eac93785fe2c8b9cb30893c1af5b8fdd753b9d40f"}, - {file = "charset_normalizer-3.3.2-cp311-cp311-win32.whl", hash = "sha256:7cd13a2e3ddeed6913a65e66e94b51d80a041145a026c27e6bb76c31a853c6ab"}, - {file = "charset_normalizer-3.3.2-cp311-cp311-win_amd64.whl", hash = "sha256:663946639d296df6a2bb2aa51b60a2454ca1cb29835324c640dafb5ff2131a77"}, - {file = "charset_normalizer-3.3.2-cp312-cp312-macosx_10_9_universal2.whl", hash = "sha256:0b2b64d2bb6d3fb9112bafa732def486049e63de9618b5843bcdd081d8144cd8"}, - {file = "charset_normalizer-3.3.2-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:ddbb2551d7e0102e7252db79ba445cdab71b26640817ab1e3e3648dad515003b"}, - {file = "charset_normalizer-3.3.2-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:55086ee1064215781fff39a1af09518bc9255b50d6333f2e4c74ca09fac6a8f6"}, - {file = "charset_normalizer-3.3.2-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:8f4a014bc36d3c57402e2977dada34f9c12300af536839dc38c0beab8878f38a"}, - {file = "charset_normalizer-3.3.2-cp312-cp312-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:a10af20b82360ab00827f916a6058451b723b4e65030c5a18577c8b2de5b3389"}, - {file = "charset_normalizer-3.3.2-cp312-cp312-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:8d756e44e94489e49571086ef83b2bb8ce311e730092d2c34ca8f7d925cb20aa"}, - {file = "charset_normalizer-3.3.2-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:90d558489962fd4918143277a773316e56c72da56ec7aa3dc3dbbe20fdfed15b"}, - {file = "charset_normalizer-3.3.2-cp312-cp312-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:6ac7ffc7ad6d040517be39eb591cac5ff87416c2537df6ba3cba3bae290c0fed"}, - {file = "charset_normalizer-3.3.2-cp312-cp312-musllinux_1_1_aarch64.whl", hash = "sha256:7ed9e526742851e8d5cc9e6cf41427dfc6068d4f5a3bb03659444b4cabf6bc26"}, - {file = "charset_normalizer-3.3.2-cp312-cp312-musllinux_1_1_i686.whl", hash = "sha256:8bdb58ff7ba23002a4c5808d608e4e6c687175724f54a5dade5fa8c67b604e4d"}, - {file = "charset_normalizer-3.3.2-cp312-cp312-musllinux_1_1_ppc64le.whl", hash = "sha256:6b3251890fff30ee142c44144871185dbe13b11bab478a88887a639655be1068"}, - {file = "charset_normalizer-3.3.2-cp312-cp312-musllinux_1_1_s390x.whl", hash = "sha256:b4a23f61ce87adf89be746c8a8974fe1c823c891d8f86eb218bb957c924bb143"}, - {file = "charset_normalizer-3.3.2-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:efcb3f6676480691518c177e3b465bcddf57cea040302f9f4e6e191af91174d4"}, - {file = "charset_normalizer-3.3.2-cp312-cp312-win32.whl", hash = "sha256:d965bba47ddeec8cd560687584e88cf699fd28f192ceb452d1d7ee807c5597b7"}, - {file = "charset_normalizer-3.3.2-cp312-cp312-win_amd64.whl", hash = "sha256:96b02a3dc4381e5494fad39be677abcb5e6634bf7b4fa83a6dd3112607547001"}, - {file = "charset_normalizer-3.3.2-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:95f2a5796329323b8f0512e09dbb7a1860c46a39da62ecb2324f116fa8fdc85c"}, - {file = "charset_normalizer-3.3.2-cp37-cp37m-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:c002b4ffc0be611f0d9da932eb0f704fe2602a9a949d1f738e4c34c75b0863d5"}, - {file = "charset_normalizer-3.3.2-cp37-cp37m-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:a981a536974bbc7a512cf44ed14938cf01030a99e9b3a06dd59578882f06f985"}, - {file = "charset_normalizer-3.3.2-cp37-cp37m-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:3287761bc4ee9e33561a7e058c72ac0938c4f57fe49a09eae428fd88aafe7bb6"}, - {file = "charset_normalizer-3.3.2-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:42cb296636fcc8b0644486d15c12376cb9fa75443e00fb25de0b8602e64c1714"}, - {file = "charset_normalizer-3.3.2-cp37-cp37m-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:0a55554a2fa0d408816b3b5cedf0045f4b8e1a6065aec45849de2d6f3f8e9786"}, - {file = "charset_normalizer-3.3.2-cp37-cp37m-musllinux_1_1_aarch64.whl", hash = "sha256:c083af607d2515612056a31f0a8d9e0fcb5876b7bfc0abad3ecd275bc4ebc2d5"}, - {file = "charset_normalizer-3.3.2-cp37-cp37m-musllinux_1_1_i686.whl", hash = "sha256:87d1351268731db79e0f8e745d92493ee2841c974128ef629dc518b937d9194c"}, - {file = "charset_normalizer-3.3.2-cp37-cp37m-musllinux_1_1_ppc64le.whl", hash = "sha256:bd8f7df7d12c2db9fab40bdd87a7c09b1530128315d047a086fa3ae3435cb3a8"}, - {file = "charset_normalizer-3.3.2-cp37-cp37m-musllinux_1_1_s390x.whl", hash = "sha256:c180f51afb394e165eafe4ac2936a14bee3eb10debc9d9e4db8958fe36afe711"}, - {file = "charset_normalizer-3.3.2-cp37-cp37m-musllinux_1_1_x86_64.whl", hash = "sha256:8c622a5fe39a48f78944a87d4fb8a53ee07344641b0562c540d840748571b811"}, - {file = "charset_normalizer-3.3.2-cp37-cp37m-win32.whl", hash = "sha256:db364eca23f876da6f9e16c9da0df51aa4f104a972735574842618b8c6d999d4"}, - {file = "charset_normalizer-3.3.2-cp37-cp37m-win_amd64.whl", hash = "sha256:86216b5cee4b06df986d214f664305142d9c76df9b6512be2738aa72a2048f99"}, - {file = "charset_normalizer-3.3.2-cp38-cp38-macosx_10_9_universal2.whl", hash = "sha256:6463effa3186ea09411d50efc7d85360b38d5f09b870c48e4600f63af490e56a"}, - {file = "charset_normalizer-3.3.2-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:6c4caeef8fa63d06bd437cd4bdcf3ffefe6738fb1b25951440d80dc7df8c03ac"}, - {file = "charset_normalizer-3.3.2-cp38-cp38-macosx_11_0_arm64.whl", hash = "sha256:37e55c8e51c236f95b033f6fb391d7d7970ba5fe7ff453dad675e88cf303377a"}, - {file = "charset_normalizer-3.3.2-cp38-cp38-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:fb69256e180cb6c8a894fee62b3afebae785babc1ee98b81cdf68bbca1987f33"}, - {file = "charset_normalizer-3.3.2-cp38-cp38-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:ae5f4161f18c61806f411a13b0310bea87f987c7d2ecdbdaad0e94eb2e404238"}, - {file = "charset_normalizer-3.3.2-cp38-cp38-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:b2b0a0c0517616b6869869f8c581d4eb2dd83a4d79e0ebcb7d373ef9956aeb0a"}, - {file = "charset_normalizer-3.3.2-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:45485e01ff4d3630ec0d9617310448a8702f70e9c01906b0d0118bdf9d124cf2"}, - {file = "charset_normalizer-3.3.2-cp38-cp38-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:eb00ed941194665c332bf8e078baf037d6c35d7c4f3102ea2d4f16ca94a26dc8"}, - {file = "charset_normalizer-3.3.2-cp38-cp38-musllinux_1_1_aarch64.whl", hash = "sha256:2127566c664442652f024c837091890cb1942c30937add288223dc895793f898"}, - {file = "charset_normalizer-3.3.2-cp38-cp38-musllinux_1_1_i686.whl", hash = "sha256:a50aebfa173e157099939b17f18600f72f84eed3049e743b68ad15bd69b6bf99"}, - {file = "charset_normalizer-3.3.2-cp38-cp38-musllinux_1_1_ppc64le.whl", hash = "sha256:4d0d1650369165a14e14e1e47b372cfcb31d6ab44e6e33cb2d4e57265290044d"}, - {file = "charset_normalizer-3.3.2-cp38-cp38-musllinux_1_1_s390x.whl", hash = "sha256:923c0c831b7cfcb071580d3f46c4baf50f174be571576556269530f4bbd79d04"}, - {file = "charset_normalizer-3.3.2-cp38-cp38-musllinux_1_1_x86_64.whl", hash = "sha256:06a81e93cd441c56a9b65d8e1d043daeb97a3d0856d177d5c90ba85acb3db087"}, - {file = "charset_normalizer-3.3.2-cp38-cp38-win32.whl", hash = "sha256:6ef1d82a3af9d3eecdba2321dc1b3c238245d890843e040e41e470ffa64c3e25"}, - {file = "charset_normalizer-3.3.2-cp38-cp38-win_amd64.whl", hash = "sha256:eb8821e09e916165e160797a6c17edda0679379a4be5c716c260e836e122f54b"}, - {file = "charset_normalizer-3.3.2-cp39-cp39-macosx_10_9_universal2.whl", hash = "sha256:c235ebd9baae02f1b77bcea61bce332cb4331dc3617d254df3323aa01ab47bd4"}, - {file = "charset_normalizer-3.3.2-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:5b4c145409bef602a690e7cfad0a15a55c13320ff7a3ad7ca59c13bb8ba4d45d"}, - {file = "charset_normalizer-3.3.2-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:68d1f8a9e9e37c1223b656399be5d6b448dea850bed7d0f87a8311f1ff3dabb0"}, - {file = "charset_normalizer-3.3.2-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:22afcb9f253dac0696b5a4be4a1c0f8762f8239e21b99680099abd9b2b1b2269"}, - {file = "charset_normalizer-3.3.2-cp39-cp39-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:e27ad930a842b4c5eb8ac0016b0a54f5aebbe679340c26101df33424142c143c"}, - {file = "charset_normalizer-3.3.2-cp39-cp39-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:1f79682fbe303db92bc2b1136016a38a42e835d932bab5b3b1bfcfbf0640e519"}, - {file = "charset_normalizer-3.3.2-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:b261ccdec7821281dade748d088bb6e9b69e6d15b30652b74cbbac25e280b796"}, - {file = "charset_normalizer-3.3.2-cp39-cp39-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:122c7fa62b130ed55f8f285bfd56d5f4b4a5b503609d181f9ad85e55c89f4185"}, - {file = "charset_normalizer-3.3.2-cp39-cp39-musllinux_1_1_aarch64.whl", hash = "sha256:d0eccceffcb53201b5bfebb52600a5fb483a20b61da9dbc885f8b103cbe7598c"}, - {file = "charset_normalizer-3.3.2-cp39-cp39-musllinux_1_1_i686.whl", hash = "sha256:9f96df6923e21816da7e0ad3fd47dd8f94b2a5ce594e00677c0013018b813458"}, - {file = "charset_normalizer-3.3.2-cp39-cp39-musllinux_1_1_ppc64le.whl", hash = "sha256:7f04c839ed0b6b98b1a7501a002144b76c18fb1c1850c8b98d458ac269e26ed2"}, - {file = "charset_normalizer-3.3.2-cp39-cp39-musllinux_1_1_s390x.whl", hash = "sha256:34d1c8da1e78d2e001f363791c98a272bb734000fcef47a491c1e3b0505657a8"}, - {file = "charset_normalizer-3.3.2-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:ff8fa367d09b717b2a17a052544193ad76cd49979c805768879cb63d9ca50561"}, - {file = "charset_normalizer-3.3.2-cp39-cp39-win32.whl", hash = "sha256:aed38f6e4fb3f5d6bf81bfa990a07806be9d83cf7bacef998ab1a9bd660a581f"}, - {file = "charset_normalizer-3.3.2-cp39-cp39-win_amd64.whl", hash = "sha256:b01b88d45a6fcb69667cd6d2f7a9aeb4bf53760d7fc536bf679ec94fe9f3ff3d"}, - {file = "charset_normalizer-3.3.2-py3-none-any.whl", hash = "sha256:3e4d1f6587322d2788836a99c69062fbb091331ec940e02d12d179c1d53e25fc"}, + {file = "charset_normalizer-3.4.0-cp310-cp310-macosx_10_9_universal2.whl", hash = "sha256:4f9fc98dad6c2eaa32fc3af1417d95b5e3d08aff968df0cd320066def971f9a6"}, + {file = "charset_normalizer-3.4.0-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:0de7b687289d3c1b3e8660d0741874abe7888100efe14bd0f9fd7141bcbda92b"}, + {file = "charset_normalizer-3.4.0-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:5ed2e36c3e9b4f21dd9422f6893dec0abf2cca553af509b10cd630f878d3eb99"}, + {file = "charset_normalizer-3.4.0-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:40d3ff7fc90b98c637bda91c89d51264a3dcf210cade3a2c6f838c7268d7a4ca"}, + {file = "charset_normalizer-3.4.0-cp310-cp310-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:1110e22af8ca26b90bd6364fe4c763329b0ebf1ee213ba32b68c73de5752323d"}, + {file = "charset_normalizer-3.4.0-cp310-cp310-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:86f4e8cca779080f66ff4f191a685ced73d2f72d50216f7112185dc02b90b9b7"}, + {file = "charset_normalizer-3.4.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:7f683ddc7eedd742e2889d2bfb96d69573fde1d92fcb811979cdb7165bb9c7d3"}, + {file = "charset_normalizer-3.4.0-cp310-cp310-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:27623ba66c183eca01bf9ff833875b459cad267aeeb044477fedac35e19ba907"}, + {file = "charset_normalizer-3.4.0-cp310-cp310-musllinux_1_2_aarch64.whl", hash = "sha256:f606a1881d2663630ea5b8ce2efe2111740df4b687bd78b34a8131baa007f79b"}, + {file = "charset_normalizer-3.4.0-cp310-cp310-musllinux_1_2_i686.whl", hash = "sha256:0b309d1747110feb25d7ed6b01afdec269c647d382c857ef4663bbe6ad95a912"}, + {file = "charset_normalizer-3.4.0-cp310-cp310-musllinux_1_2_ppc64le.whl", hash = "sha256:136815f06a3ae311fae551c3df1f998a1ebd01ddd424aa5603a4336997629e95"}, + {file = "charset_normalizer-3.4.0-cp310-cp310-musllinux_1_2_s390x.whl", hash = "sha256:14215b71a762336254351b00ec720a8e85cada43b987da5a042e4ce3e82bd68e"}, + {file = "charset_normalizer-3.4.0-cp310-cp310-musllinux_1_2_x86_64.whl", hash = "sha256:79983512b108e4a164b9c8d34de3992f76d48cadc9554c9e60b43f308988aabe"}, + {file = "charset_normalizer-3.4.0-cp310-cp310-win32.whl", hash = "sha256:c94057af19bc953643a33581844649a7fdab902624d2eb739738a30e2b3e60fc"}, + {file = "charset_normalizer-3.4.0-cp310-cp310-win_amd64.whl", hash = "sha256:55f56e2ebd4e3bc50442fbc0888c9d8c94e4e06a933804e2af3e89e2f9c1c749"}, + {file = "charset_normalizer-3.4.0-cp311-cp311-macosx_10_9_universal2.whl", hash = "sha256:0d99dd8ff461990f12d6e42c7347fd9ab2532fb70e9621ba520f9e8637161d7c"}, + {file = "charset_normalizer-3.4.0-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:c57516e58fd17d03ebe67e181a4e4e2ccab1168f8c2976c6a334d4f819fe5944"}, + {file = "charset_normalizer-3.4.0-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:6dba5d19c4dfab08e58d5b36304b3f92f3bd5d42c1a3fa37b5ba5cdf6dfcbcee"}, + {file = "charset_normalizer-3.4.0-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:bf4475b82be41b07cc5e5ff94810e6a01f276e37c2d55571e3fe175e467a1a1c"}, + {file = "charset_normalizer-3.4.0-cp311-cp311-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:ce031db0408e487fd2775d745ce30a7cd2923667cf3b69d48d219f1d8f5ddeb6"}, + {file = "charset_normalizer-3.4.0-cp311-cp311-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:8ff4e7cdfdb1ab5698e675ca622e72d58a6fa2a8aa58195de0c0061288e6e3ea"}, + {file = "charset_normalizer-3.4.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:3710a9751938947e6327ea9f3ea6332a09bf0ba0c09cae9cb1f250bd1f1549bc"}, + {file = "charset_normalizer-3.4.0-cp311-cp311-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:82357d85de703176b5587dbe6ade8ff67f9f69a41c0733cf2425378b49954de5"}, + {file = "charset_normalizer-3.4.0-cp311-cp311-musllinux_1_2_aarch64.whl", hash = "sha256:47334db71978b23ebcf3c0f9f5ee98b8d65992b65c9c4f2d34c2eaf5bcaf0594"}, + {file = "charset_normalizer-3.4.0-cp311-cp311-musllinux_1_2_i686.whl", hash = "sha256:8ce7fd6767a1cc5a92a639b391891bf1c268b03ec7e021c7d6d902285259685c"}, + {file = "charset_normalizer-3.4.0-cp311-cp311-musllinux_1_2_ppc64le.whl", hash = "sha256:f1a2f519ae173b5b6a2c9d5fa3116ce16e48b3462c8b96dfdded11055e3d6365"}, + {file = "charset_normalizer-3.4.0-cp311-cp311-musllinux_1_2_s390x.whl", hash = "sha256:63bc5c4ae26e4bc6be6469943b8253c0fd4e4186c43ad46e713ea61a0ba49129"}, + {file = "charset_normalizer-3.4.0-cp311-cp311-musllinux_1_2_x86_64.whl", hash = "sha256:bcb4f8ea87d03bc51ad04add8ceaf9b0f085ac045ab4d74e73bbc2dc033f0236"}, + {file = "charset_normalizer-3.4.0-cp311-cp311-win32.whl", hash = "sha256:9ae4ef0b3f6b41bad6366fb0ea4fc1d7ed051528e113a60fa2a65a9abb5b1d99"}, + {file = "charset_normalizer-3.4.0-cp311-cp311-win_amd64.whl", hash = "sha256:cee4373f4d3ad28f1ab6290684d8e2ebdb9e7a1b74fdc39e4c211995f77bec27"}, + {file = "charset_normalizer-3.4.0-cp312-cp312-macosx_10_13_universal2.whl", hash = "sha256:0713f3adb9d03d49d365b70b84775d0a0d18e4ab08d12bc46baa6132ba78aaf6"}, + {file = "charset_normalizer-3.4.0-cp312-cp312-macosx_10_13_x86_64.whl", hash = "sha256:de7376c29d95d6719048c194a9cf1a1b0393fbe8488a22008610b0361d834ecf"}, + {file = "charset_normalizer-3.4.0-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:4a51b48f42d9358460b78725283f04bddaf44a9358197b889657deba38f329db"}, + {file = "charset_normalizer-3.4.0-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:b295729485b06c1a0683af02a9e42d2caa9db04a373dc38a6a58cdd1e8abddf1"}, + {file = "charset_normalizer-3.4.0-cp312-cp312-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:ee803480535c44e7f5ad00788526da7d85525cfefaf8acf8ab9a310000be4b03"}, + {file = "charset_normalizer-3.4.0-cp312-cp312-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:3d59d125ffbd6d552765510e3f31ed75ebac2c7470c7274195b9161a32350284"}, + {file = "charset_normalizer-3.4.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:8cda06946eac330cbe6598f77bb54e690b4ca93f593dee1568ad22b04f347c15"}, + {file = "charset_normalizer-3.4.0-cp312-cp312-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:07afec21bbbbf8a5cc3651aa96b980afe2526e7f048fdfb7f1014d84acc8b6d8"}, + {file = "charset_normalizer-3.4.0-cp312-cp312-musllinux_1_2_aarch64.whl", hash = "sha256:6b40e8d38afe634559e398cc32b1472f376a4099c75fe6299ae607e404c033b2"}, + {file = "charset_normalizer-3.4.0-cp312-cp312-musllinux_1_2_i686.whl", hash = "sha256:b8dcd239c743aa2f9c22ce674a145e0a25cb1566c495928440a181ca1ccf6719"}, + {file = "charset_normalizer-3.4.0-cp312-cp312-musllinux_1_2_ppc64le.whl", hash = "sha256:84450ba661fb96e9fd67629b93d2941c871ca86fc38d835d19d4225ff946a631"}, + {file = "charset_normalizer-3.4.0-cp312-cp312-musllinux_1_2_s390x.whl", hash = "sha256:44aeb140295a2f0659e113b31cfe92c9061622cadbc9e2a2f7b8ef6b1e29ef4b"}, + {file = "charset_normalizer-3.4.0-cp312-cp312-musllinux_1_2_x86_64.whl", hash = "sha256:1db4e7fefefd0f548d73e2e2e041f9df5c59e178b4c72fbac4cc6f535cfb1565"}, + {file = "charset_normalizer-3.4.0-cp312-cp312-win32.whl", hash = "sha256:5726cf76c982532c1863fb64d8c6dd0e4c90b6ece9feb06c9f202417a31f7dd7"}, + {file = "charset_normalizer-3.4.0-cp312-cp312-win_amd64.whl", hash = "sha256:b197e7094f232959f8f20541ead1d9862ac5ebea1d58e9849c1bf979255dfac9"}, + {file = "charset_normalizer-3.4.0-cp313-cp313-macosx_10_13_universal2.whl", hash = "sha256:dd4eda173a9fcccb5f2e2bd2a9f423d180194b1bf17cf59e3269899235b2a114"}, + {file = "charset_normalizer-3.4.0-cp313-cp313-macosx_10_13_x86_64.whl", hash = "sha256:e9e3c4c9e1ed40ea53acf11e2a386383c3304212c965773704e4603d589343ed"}, + {file = "charset_normalizer-3.4.0-cp313-cp313-macosx_11_0_arm64.whl", hash = "sha256:92a7e36b000bf022ef3dbb9c46bfe2d52c047d5e3f3343f43204263c5addc250"}, + {file = "charset_normalizer-3.4.0-cp313-cp313-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:54b6a92d009cbe2fb11054ba694bc9e284dad30a26757b1e372a1fdddaf21920"}, + {file = "charset_normalizer-3.4.0-cp313-cp313-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:1ffd9493de4c922f2a38c2bf62b831dcec90ac673ed1ca182fe11b4d8e9f2a64"}, + {file = "charset_normalizer-3.4.0-cp313-cp313-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:35c404d74c2926d0287fbd63ed5d27eb911eb9e4a3bb2c6d294f3cfd4a9e0c23"}, + {file = "charset_normalizer-3.4.0-cp313-cp313-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:4796efc4faf6b53a18e3d46343535caed491776a22af773f366534056c4e1fbc"}, + {file = "charset_normalizer-3.4.0-cp313-cp313-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:e7fdd52961feb4c96507aa649550ec2a0d527c086d284749b2f582f2d40a2e0d"}, + {file = "charset_normalizer-3.4.0-cp313-cp313-musllinux_1_2_aarch64.whl", hash = "sha256:92db3c28b5b2a273346bebb24857fda45601aef6ae1c011c0a997106581e8a88"}, + {file = "charset_normalizer-3.4.0-cp313-cp313-musllinux_1_2_i686.whl", hash = "sha256:ab973df98fc99ab39080bfb0eb3a925181454d7c3ac8a1e695fddfae696d9e90"}, + {file = "charset_normalizer-3.4.0-cp313-cp313-musllinux_1_2_ppc64le.whl", hash = "sha256:4b67fdab07fdd3c10bb21edab3cbfe8cf5696f453afce75d815d9d7223fbe88b"}, + {file = "charset_normalizer-3.4.0-cp313-cp313-musllinux_1_2_s390x.whl", hash = "sha256:aa41e526a5d4a9dfcfbab0716c7e8a1b215abd3f3df5a45cf18a12721d31cb5d"}, + {file = "charset_normalizer-3.4.0-cp313-cp313-musllinux_1_2_x86_64.whl", hash = "sha256:ffc519621dce0c767e96b9c53f09c5d215578e10b02c285809f76509a3931482"}, + {file = "charset_normalizer-3.4.0-cp313-cp313-win32.whl", hash = "sha256:f19c1585933c82098c2a520f8ec1227f20e339e33aca8fa6f956f6691b784e67"}, + {file = "charset_normalizer-3.4.0-cp313-cp313-win_amd64.whl", hash = "sha256:707b82d19e65c9bd28b81dde95249b07bf9f5b90ebe1ef17d9b57473f8a64b7b"}, + {file = "charset_normalizer-3.4.0-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:dbe03226baf438ac4fda9e2d0715022fd579cb641c4cf639fa40d53b2fe6f3e2"}, + {file = "charset_normalizer-3.4.0-cp37-cp37m-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:dd9a8bd8900e65504a305bf8ae6fa9fbc66de94178c420791d0293702fce2df7"}, + {file = "charset_normalizer-3.4.0-cp37-cp37m-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:b8831399554b92b72af5932cdbbd4ddc55c55f631bb13ff8fe4e6536a06c5c51"}, + {file = "charset_normalizer-3.4.0-cp37-cp37m-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:a14969b8691f7998e74663b77b4c36c0337cb1df552da83d5c9004a93afdb574"}, + {file = "charset_normalizer-3.4.0-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:dcaf7c1524c0542ee2fc82cc8ec337f7a9f7edee2532421ab200d2b920fc97cf"}, + {file = "charset_normalizer-3.4.0-cp37-cp37m-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:425c5f215d0eecee9a56cdb703203dda90423247421bf0d67125add85d0c4455"}, + {file = "charset_normalizer-3.4.0-cp37-cp37m-musllinux_1_2_aarch64.whl", hash = "sha256:d5b054862739d276e09928de37c79ddeec42a6e1bfc55863be96a36ba22926f6"}, + {file = "charset_normalizer-3.4.0-cp37-cp37m-musllinux_1_2_i686.whl", hash = "sha256:f3e73a4255342d4eb26ef6df01e3962e73aa29baa3124a8e824c5d3364a65748"}, + {file = "charset_normalizer-3.4.0-cp37-cp37m-musllinux_1_2_ppc64le.whl", hash = "sha256:2f6c34da58ea9c1a9515621f4d9ac379871a8f21168ba1b5e09d74250de5ad62"}, + {file = "charset_normalizer-3.4.0-cp37-cp37m-musllinux_1_2_s390x.whl", hash = "sha256:f09cb5a7bbe1ecae6e87901a2eb23e0256bb524a79ccc53eb0b7629fbe7677c4"}, + {file = "charset_normalizer-3.4.0-cp37-cp37m-musllinux_1_2_x86_64.whl", hash = "sha256:0099d79bdfcf5c1f0c2c72f91516702ebf8b0b8ddd8905f97a8aecf49712c621"}, + {file = "charset_normalizer-3.4.0-cp37-cp37m-win32.whl", hash = "sha256:9c98230f5042f4945f957d006edccc2af1e03ed5e37ce7c373f00a5a4daa6149"}, + {file = "charset_normalizer-3.4.0-cp37-cp37m-win_amd64.whl", hash = "sha256:62f60aebecfc7f4b82e3f639a7d1433a20ec32824db2199a11ad4f5e146ef5ee"}, + {file = "charset_normalizer-3.4.0-cp38-cp38-macosx_10_9_universal2.whl", hash = "sha256:af73657b7a68211996527dbfeffbb0864e043d270580c5aef06dc4b659a4b578"}, + {file = "charset_normalizer-3.4.0-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:cab5d0b79d987c67f3b9e9c53f54a61360422a5a0bc075f43cab5621d530c3b6"}, + {file = "charset_normalizer-3.4.0-cp38-cp38-macosx_11_0_arm64.whl", hash = "sha256:9289fd5dddcf57bab41d044f1756550f9e7cf0c8e373b8cdf0ce8773dc4bd417"}, + {file = "charset_normalizer-3.4.0-cp38-cp38-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:6b493a043635eb376e50eedf7818f2f322eabbaa974e948bd8bdd29eb7ef2a51"}, + {file = "charset_normalizer-3.4.0-cp38-cp38-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:9fa2566ca27d67c86569e8c85297aaf413ffab85a8960500f12ea34ff98e4c41"}, + {file = "charset_normalizer-3.4.0-cp38-cp38-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:a8e538f46104c815be19c975572d74afb53f29650ea2025bbfaef359d2de2f7f"}, + {file = "charset_normalizer-3.4.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:6fd30dc99682dc2c603c2b315bded2799019cea829f8bf57dc6b61efde6611c8"}, + {file = "charset_normalizer-3.4.0-cp38-cp38-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:2006769bd1640bdf4d5641c69a3d63b71b81445473cac5ded39740a226fa88ab"}, + {file = "charset_normalizer-3.4.0-cp38-cp38-musllinux_1_2_aarch64.whl", hash = "sha256:dc15e99b2d8a656f8e666854404f1ba54765871104e50c8e9813af8a7db07f12"}, + {file = "charset_normalizer-3.4.0-cp38-cp38-musllinux_1_2_i686.whl", hash = "sha256:ab2e5bef076f5a235c3774b4f4028a680432cded7cad37bba0fd90d64b187d19"}, + {file = "charset_normalizer-3.4.0-cp38-cp38-musllinux_1_2_ppc64le.whl", hash = "sha256:4ec9dd88a5b71abfc74e9df5ebe7921c35cbb3b641181a531ca65cdb5e8e4dea"}, + {file = "charset_normalizer-3.4.0-cp38-cp38-musllinux_1_2_s390x.whl", hash = "sha256:43193c5cda5d612f247172016c4bb71251c784d7a4d9314677186a838ad34858"}, + {file = "charset_normalizer-3.4.0-cp38-cp38-musllinux_1_2_x86_64.whl", hash = "sha256:aa693779a8b50cd97570e5a0f343538a8dbd3e496fa5dcb87e29406ad0299654"}, + {file = "charset_normalizer-3.4.0-cp38-cp38-win32.whl", hash = "sha256:7706f5850360ac01d80c89bcef1640683cc12ed87f42579dab6c5d3ed6888613"}, + {file = "charset_normalizer-3.4.0-cp38-cp38-win_amd64.whl", hash = "sha256:c3e446d253bd88f6377260d07c895816ebf33ffffd56c1c792b13bff9c3e1ade"}, + {file = "charset_normalizer-3.4.0-cp39-cp39-macosx_10_9_universal2.whl", hash = "sha256:980b4f289d1d90ca5efcf07958d3eb38ed9c0b7676bf2831a54d4f66f9c27dfa"}, + {file = "charset_normalizer-3.4.0-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:f28f891ccd15c514a0981f3b9db9aa23d62fe1a99997512b0491d2ed323d229a"}, + {file = "charset_normalizer-3.4.0-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:a8aacce6e2e1edcb6ac625fb0f8c3a9570ccc7bfba1f63419b3769ccf6a00ed0"}, + {file = "charset_normalizer-3.4.0-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:bd7af3717683bea4c87acd8c0d3d5b44d56120b26fd3f8a692bdd2d5260c620a"}, + {file = "charset_normalizer-3.4.0-cp39-cp39-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:5ff2ed8194587faf56555927b3aa10e6fb69d931e33953943bc4f837dfee2242"}, + {file = "charset_normalizer-3.4.0-cp39-cp39-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:e91f541a85298cf35433bf66f3fab2a4a2cff05c127eeca4af174f6d497f0d4b"}, + {file = "charset_normalizer-3.4.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:309a7de0a0ff3040acaebb35ec45d18db4b28232f21998851cfa709eeff49d62"}, + {file = "charset_normalizer-3.4.0-cp39-cp39-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:285e96d9d53422efc0d7a17c60e59f37fbf3dfa942073f666db4ac71e8d726d0"}, + {file = "charset_normalizer-3.4.0-cp39-cp39-musllinux_1_2_aarch64.whl", hash = "sha256:5d447056e2ca60382d460a604b6302d8db69476fd2015c81e7c35417cfabe4cd"}, + {file = "charset_normalizer-3.4.0-cp39-cp39-musllinux_1_2_i686.whl", hash = "sha256:20587d20f557fe189b7947d8e7ec5afa110ccf72a3128d61a2a387c3313f46be"}, + {file = "charset_normalizer-3.4.0-cp39-cp39-musllinux_1_2_ppc64le.whl", hash = "sha256:130272c698667a982a5d0e626851ceff662565379baf0ff2cc58067b81d4f11d"}, + {file = "charset_normalizer-3.4.0-cp39-cp39-musllinux_1_2_s390x.whl", hash = "sha256:ab22fbd9765e6954bc0bcff24c25ff71dcbfdb185fcdaca49e81bac68fe724d3"}, + {file = "charset_normalizer-3.4.0-cp39-cp39-musllinux_1_2_x86_64.whl", hash = "sha256:7782afc9b6b42200f7362858f9e73b1f8316afb276d316336c0ec3bd73312742"}, + {file = "charset_normalizer-3.4.0-cp39-cp39-win32.whl", hash = "sha256:2de62e8801ddfff069cd5c504ce3bc9672b23266597d4e4f50eda28846c322f2"}, + {file = "charset_normalizer-3.4.0-cp39-cp39-win_amd64.whl", hash = "sha256:95c3c157765b031331dd4db3c775e58deaee050a3042fcad72cbc4189d7c8dca"}, + {file = "charset_normalizer-3.4.0-py3-none-any.whl", hash = "sha256:fe9f97feb71aa9896b81973a7bbada8c49501dc73e58a10fcef6663af95e5079"}, + {file = "charset_normalizer-3.4.0.tar.gz", hash = "sha256:223217c3d4f82c3ac5e29032b3f1c2eb0fb591b72161f86d93f5719079dae93e"}, ] [[package]] @@ -237,15 +252,18 @@ colorama = ">=0.4" [[package]] name = "idna" -version = "3.8" +version = "3.10" description = "Internationalized Domain Names in Applications (IDNA)" optional = false python-versions = ">=3.6" files = [ - {file = "idna-3.8-py3-none-any.whl", hash = "sha256:050b4e5baadcd44d760cedbd2b8e639f2ff89bbc7a5730fcc662954303377aac"}, - {file = "idna-3.8.tar.gz", hash = "sha256:d838c2c0ed6fced7693d5e8ab8e734d5f8fda53a039c0164afb0b82e771e3603"}, + {file = "idna-3.10-py3-none-any.whl", hash = "sha256:946d195a0d259cbba61165e88e65941f16e9b36ea6ddb97f00452bae8b1287d3"}, + {file = "idna-3.10.tar.gz", hash = "sha256:12f65c9b470abda6dc35cf8e63cc574b1c52b11df2c86030af0ac09b01b13ea9"}, ] +[package.extras] +all = ["flake8 (>=7.1.1)", "mypy (>=1.11.2)", "pytest (>=8.3.2)", "ruff (>=0.6.2)"] + [[package]] name = "importlib-metadata" version = "6.7.0" @@ -474,6 +492,20 @@ files = [ {file = "mkdocs_material_extensions-1.2.tar.gz", hash = "sha256:27e2d1ed2d031426a6e10d5ea06989d67e90bb02acd588bc5673106b5ee5eedf"}, ] +[[package]] +name = "mkdocs-print-site-plugin" +version = "2.3.6" +description = "MkDocs plugin that combines all pages into one, allowing for easy export to PDF and standalone HTML." +optional = false +python-versions = ">=3.6" +files = [ + {file = "mkdocs-print-site-plugin-2.3.6.tar.gz", hash = "sha256:82e5cabcfb7fe3074daecea018f28ccb4bff086f965e3103fe91019a76752f22"}, + {file = "mkdocs_print_site_plugin-2.3.6-py3-none-any.whl", hash = "sha256:01ccb1ceccc87f29e1612bebb77c3bf9980809fbce750fc2113f9d6acea589d4"}, +] + +[package.dependencies] +mkdocs-material = ">=7.3.0" + [[package]] name = "mkdocstrings" version = "0.22.0" @@ -886,12 +918,12 @@ files = [ [[package]] name = "splunk-sdk" -version = "2.0.2" +version = "2.1.0" description = "The Splunk Software Development Kit for Python." optional = false python-versions = "*" files = [ - {file = "splunk-sdk-2.0.2.tar.gz", hash = "sha256:d5ccf6e1b96e493b1399e071ef10f8337e0a39ac2b2acc73fdd375b87b4104cb"}, + {file = "splunk-sdk-2.1.0.tar.gz", hash = "sha256:63f9a259a7c84d0c3b0b32cae652365b03f0f926acdb894b51456005df74ae21"}, ] [package.dependencies] @@ -992,4 +1024,4 @@ testing = ["big-O", "flake8 (<5)", "jaraco.functools", "jaraco.itertools", "more [metadata] lock-version = "2.0" python-versions = "^3.7" -content-hash = "cc7429f4b20b51e8c6148a9ba7a851d7f823bccf0a2e1aae58b761e159d4021b" +content-hash = "c151c1b7f3351e347d7d6207228cf0ddad7c7d82a7ef2df2d80e03e15bd93902" diff --git a/pyproject.toml b/pyproject.toml index aa08cdc7..78042db3 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -35,6 +35,7 @@ pytest = ">=7" mkdocs = ">=1" mkdocs-material = ">=9" mkdocstrings = {version=">=0", extras=["python"]} +mkdocs-print-site-plugin = "^2.3.6" [build-system] requires = ["poetry>=1.0.0"] diff --git a/solnlib/log.py b/solnlib/log.py index 7c5cf11a..4d6316df 100644 --- a/solnlib/log.py +++ b/solnlib/log.py @@ -292,8 +292,8 @@ def events_ingested( Arguments: logger: Add-on logger. - modular_input_name: Full name of the modular input. It needs to be in a format ://. - In case of invalid format ValueError is raised. + modular_input_name: Full name of the modular input. It needs to be in a format `://`. + In case of invalid format ValueError is raised. sourcetype: Source type used to write event. n_events: Number of ingested events. index: Index used to write event. From c9e1f7350620963422747d90cfde529d3bb17511 Mon Sep 17 00:00:00 2001 From: Hetang Modi <62056057+hetangmodi-crest@users.noreply.github.com> Date: Mon, 25 Nov 2024 15:59:49 +0530 Subject: [PATCH 2/3] feat: add function to get the proxy details (#406) [ADDON-72372](https://splunk.atlassian.net/browse/ADDON-72372) - Add function to get the proxy details as a dictionary. --- solnlib/conf_manager.py | 88 +++++++-- solnlib/soln_exceptions.py | 37 ++++ .../default/splunk_ta_addon_settings.conf | 9 + .../splunk_ta_addon_settings_invalid.conf | 9 + tests/integration/test_conf_manager.py | 86 ++++++++- tests/unit/test_conf_manager.py | 172 +++++++++++++++++- 6 files changed, 377 insertions(+), 24 deletions(-) create mode 100644 solnlib/soln_exceptions.py create mode 100644 tests/integration/data/solnlib_demo/default/splunk_ta_addon_settings_invalid.conf diff --git a/solnlib/conf_manager.py b/solnlib/conf_manager.py index 141e871e..d572f4de 100644 --- a/solnlib/conf_manager.py +++ b/solnlib/conf_manager.py @@ -21,28 +21,27 @@ import json import logging import traceback -from typing import List +from typing import List, Union, Dict, NoReturn from splunklib import binding, client from . import splunk_rest_client as rest_client from .credentials import CredentialManager, CredentialNotExistException from .utils import retry +from .net_utils import is_valid_port, is_valid_hostname +from .soln_exceptions import ( + ConfManagerException, + ConfStanzaNotExistException, + InvalidPortError, + InvalidHostnameError, +) __all__ = [ - "ConfStanzaNotExistException", "ConfFile", - "ConfManagerException", "ConfManager", ] -class ConfStanzaNotExistException(Exception): - """Exception raised by ConfFile class.""" - - pass - - class ConfFile: """Configuration file.""" @@ -361,12 +360,6 @@ def reload(self): self._conf.get("_reload") -class ConfManagerException(Exception): - """Exception raised by ConfManager class.""" - - pass - - class ConfManager: """Configuration file manager. @@ -557,3 +550,68 @@ def get_log_level( f"taking {default_log_level} as log level." ) return default_log_level + + +def get_proxy_dict( + logger: logging.Logger, + session_key: str, + app_name: str, + conf_name: str, + proxy_stanza: str = "proxy", + **kwargs, +) -> Union[Dict[str, str], NoReturn]: + """This function returns the proxy settings for the addon from + configuration file. + + Arguments: + logger: Logger. + session_key: Splunk access token. + app_name: Add-on name. + conf_name: Configuration file name where logging stanza is. + proxy_stanza: Proxy stanza that would contain the Proxy details + Returns: + A dictionary is returned with stanza details present in the file. + The keys related to `eai` are removed before returning. + + Examples: + >>> from solnlib import conf_manager + >>> proxy_details = conf_manager.get_proxy_dict( + >>> logger, + >>> "session_key", + >>> "ADDON_NAME", + >>> "splunk_ta_addon_settings", + >>> ) + """ + proxy_dict = {} + try: + cfm = ConfManager( + session_key, + app_name, + realm=f"__REST_CREDENTIAL__#{app_name}#configs/conf-{conf_name}", + ) + conf = cfm.get_conf(conf_name) + except Exception: + raise ConfManagerException(f"Failed to fetch configuration file '{conf_name}'.") + else: + try: + proxy_dict = conf.get(proxy_stanza) + except Exception: + raise ConfStanzaNotExistException( + f"Failed to fetch '{proxy_stanza}' from the configuration file '{conf_name}'. " + ) + else: + # remove the other fields that are added by ConfFile class + proxy_dict.pop("disabled", None) + proxy_dict.pop("eai:access", None) + proxy_dict.pop("eai:appName", None) + proxy_dict.pop("eai:userName", None) + + if "proxy_port" in kwargs: + if not is_valid_port(proxy_dict.get(kwargs["proxy_port"])): + logger.error("Invalid proxy port provided.") + raise InvalidPortError("The provided port is not valid.") + if "proxy_host" in kwargs: + if not is_valid_hostname(proxy_dict.get(kwargs["proxy_host"])): + logger.error("Invalid proxy host provided.") + raise InvalidHostnameError("The provided hostname is not valid.") + return proxy_dict diff --git a/solnlib/soln_exceptions.py b/solnlib/soln_exceptions.py new file mode 100644 index 00000000..7322cc54 --- /dev/null +++ b/solnlib/soln_exceptions.py @@ -0,0 +1,37 @@ +# +# Copyright 2024 Splunk Inc. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# +class ConfManagerException(Exception): + """Exception raised by ConfManager class.""" + + pass + + +class ConfStanzaNotExistException(Exception): + """Exception raised by ConfFile class.""" + + pass + + +class InvalidPortError(ValueError): + """Exception raised when an invalid proxy port is provided.""" + + pass + + +class InvalidHostnameError(ValueError): + """Exception raised when an invalid proxy hostname is provided.""" + + pass diff --git a/tests/integration/data/solnlib_demo/default/splunk_ta_addon_settings.conf b/tests/integration/data/solnlib_demo/default/splunk_ta_addon_settings.conf index a22f5348..62c7551a 100644 --- a/tests/integration/data/solnlib_demo/default/splunk_ta_addon_settings.conf +++ b/tests/integration/data/solnlib_demo/default/splunk_ta_addon_settings.conf @@ -1,2 +1,11 @@ [logging] log_level = DEBUG + +[proxy] +proxy_enabled = +proxy_type = http +proxy_url = remote_host +proxy_port = 3128 +proxy_username = +proxy_password = +proxy_rdns = diff --git a/tests/integration/data/solnlib_demo/default/splunk_ta_addon_settings_invalid.conf b/tests/integration/data/solnlib_demo/default/splunk_ta_addon_settings_invalid.conf new file mode 100644 index 00000000..bfcf02b6 --- /dev/null +++ b/tests/integration/data/solnlib_demo/default/splunk_ta_addon_settings_invalid.conf @@ -0,0 +1,9 @@ + +[invalid_proxy] +proxy_enabled = +proxy_type = http3 +proxy_url = remote:host:invalid +proxy_port = 99999 +proxy_username = +proxy_password = +proxy_rdns = \ No newline at end of file diff --git a/tests/integration/test_conf_manager.py b/tests/integration/test_conf_manager.py index ae28fe7e..54907bd7 100644 --- a/tests/integration/test_conf_manager.py +++ b/tests/integration/test_conf_manager.py @@ -15,14 +15,20 @@ # import context -import os.path as op -import sys import pytest -from solnlib import conf_manager +from solnlib import conf_manager, soln_exceptions from unittest import mock -sys.path.insert(0, op.dirname(op.dirname(op.abspath(__file__)))) +VALID_PROXY_DICT = { + "proxy_enabled": None, + "proxy_type": "http", + "proxy_url": "remote_host", + "proxy_port": "3128", + "proxy_username": None, + "proxy_password": None, + "proxy_rdns": None, +} def _build_conf_manager(session_key: str) -> conf_manager.ConfManager: @@ -40,7 +46,7 @@ def test_conf_manager_when_no_conf_then_throw_exception(): session_key = context.get_session_key() cfm = _build_conf_manager(session_key) - with pytest.raises(conf_manager.ConfManagerException): + with pytest.raises(soln_exceptions.ConfManagerException): cfm.get_conf("non_existent_configuration_file") @@ -50,7 +56,7 @@ def test_conf_manager_when_conf_file_exists_but_no_specific_stanza_then_throw_ex splunk_ta_addon_settings_conf_file = cfm.get_conf("splunk_ta_addon_settings") - with pytest.raises(conf_manager.ConfStanzaNotExistException): + with pytest.raises(soln_exceptions.ConfStanzaNotExistException): splunk_ta_addon_settings_conf_file.get( "non_existent_stanza_under_existing_conf_file" ) @@ -60,6 +66,7 @@ def test_conf_manager_when_conf_file_exists_but_no_specific_stanza_then_throw_ex "stanza_name,expected_result", [ ("logging", True), + ("proxy", True), ("non_existent_stanza_under_existing_conf_file", False), ], ) @@ -109,7 +116,7 @@ def test_conf_manager_delete_non_existent_stanza_then_throw_exception(): splunk_ta_addon_settings_conf_file = cfm.get_conf("splunk_ta_addon_settings") - with pytest.raises(conf_manager.ConfStanzaNotExistException): + with pytest.raises(soln_exceptions.ConfStanzaNotExistException): splunk_ta_addon_settings_conf_file.delete( "non_existent_stanza_under_existing_conf_file" ) @@ -164,3 +171,68 @@ def test_get_log_level_incorrect_log_level_field(): ) assert expected_log_level == log_level + + +def test_get_proxy_dict(): + session_key = context.get_session_key() + expected_proxy_dict = VALID_PROXY_DICT + proxy_dict = conf_manager.get_proxy_dict( + logger=mock.MagicMock(), + session_key=session_key, + app_name="solnlib_demo", + conf_name="splunk_ta_addon_settings", + ) + assert expected_proxy_dict == proxy_dict + + +def test_invalid_proxy_port(): + session_key = context.get_session_key() + + with pytest.raises(soln_exceptions.InvalidPortError): + conf_manager.get_proxy_dict( + logger=mock.MagicMock(), + session_key=session_key, + app_name="solnlib_demo", + conf_name="splunk_ta_addon_settings_invalid", + proxy_stanza="invalid_proxy", + proxy_port="proxy_port", + ) + + +def test_invalid_proxy_host(): + session_key = context.get_session_key() + + with pytest.raises(soln_exceptions.InvalidHostnameError): + conf_manager.get_proxy_dict( + logger=mock.MagicMock(), + session_key=session_key, + app_name="solnlib_demo", + conf_name="splunk_ta_addon_settings_invalid", + proxy_stanza="invalid_proxy", + proxy_host="proxy_url", + ) + + +def test_conf_manager_exception(): + session_key = context.get_session_key() + + with pytest.raises(soln_exceptions.ConfManagerException): + conf_manager.get_proxy_dict( + logger=mock.MagicMock(), + session_key=session_key, + app_name="solnlib_demo", + conf_name="splunk_ta_addon_settings_not_valid", + ) + + +def test_conf_stanza_not_exist_exception(): + session_key = context.get_session_key() + + with pytest.raises(soln_exceptions.ConfStanzaNotExistException): + conf_manager.get_proxy_dict( + logger=mock.MagicMock(), + session_key=session_key, + app_name="solnlib_demo", + conf_name="splunk_ta_addon_settings", + proxy_stanza="invalid_proxy", + ) diff --git a/tests/unit/test_conf_manager.py b/tests/unit/test_conf_manager.py index bb06ca9c..ddba0424 100644 --- a/tests/unit/test_conf_manager.py +++ b/tests/unit/test_conf_manager.py @@ -16,12 +16,19 @@ from unittest import mock from solnlib import conf_manager +from solnlib.soln_exceptions import ( + InvalidHostnameError, + InvalidPortError, + ConfManagerException, + ConfStanzaNotExistException, +) +import pytest @mock.patch.object(conf_manager, "ConfManager") def test_get_log_level_when_error_getting_conf(mock_conf_manager_class): mock_conf_manager = mock_conf_manager_class.return_value - mock_conf_manager.get_conf.side_effect = conf_manager.ConfManagerException + mock_conf_manager.get_conf.side_effect = ConfManagerException expected_log_level = "INFO" log_level = conf_manager.get_log_level( @@ -57,7 +64,7 @@ def test_get_log_level_with_no_logging_stanza(mock_conf_manager_class): mock_conf_manager = mock_conf_manager_class.return_value mock_conf_manager.get_conf.return_value = mock.MagicMock() mock_conf_manager.get_conf.return_value.get.side_effect = ( - conf_manager.ConfStanzaNotExistException + ConfStanzaNotExistException ) logger = mock.MagicMock() expected_log_level = "INFO" @@ -89,3 +96,164 @@ def test_get_log_level_with_default_fields(mock_conf_manager_class): ) assert log_level == expected_log_level + + +@mock.patch.object(conf_manager, "ConfManager") +def test_get_proxy_dict_with_default_fields(mock_conf_manager_class): + mock_conf_manager = mock_conf_manager_class.return_value + mock_conf_manager.get_conf.return_value = { + "proxy": { + "proxy_enabled": "", + "proxy_type": "http", + "proxy_url": "", + "proxy_port": "", + "proxy_username": "", + "proxy_password": "", + "proxy_rdns": "", + } + } + + expected_proxy_dict = { + "proxy_enabled": "", + "proxy_type": "http", + "proxy_url": "", + "proxy_port": "", + "proxy_username": "", + "proxy_password": "", + "proxy_rdns": "", + } + + proxy_dict = conf_manager.get_proxy_dict( + logger=mock.MagicMock(), + session_key="session_key", + app_name="app_name", + conf_name="conf_name", + ) + + assert proxy_dict == expected_proxy_dict + + +@mock.patch.object(conf_manager, "ConfManager") +def test_get_proxy_dict_with_custom_stanza_name(mock_conf_manager_class): + mock_conf_manager = mock_conf_manager_class.return_value + # Mock configuration with a different stanza name, e.g., "custom_stanza" + mock_conf_manager.get_conf.return_value = { + "custom_stanza": { + "proxy_enabled": "", + "proxy_type": "http", + "proxy_url": "", + "proxy_port": "", + "proxy_username": "", + "proxy_password": "", + "proxy_rdns": "", + } + } + + expected_proxy_dict = { + "proxy_enabled": "", + "proxy_type": "http", + "proxy_url": "", + "proxy_port": "", + "proxy_username": "", + "proxy_password": "", + "proxy_rdns": "", + } + + proxy_dict = conf_manager.get_proxy_dict( + logger=mock.MagicMock(), + session_key="session_key", + app_name="app_name", + conf_name="conf_name", + proxy_stanza="custom_stanza", # passed different stanza name + ) + + assert proxy_dict == expected_proxy_dict + + +@mock.patch.object(conf_manager, "ConfManager") +def test_get_proxy_dict_invalid_port(mock_conf_manager_class): + mock_conf_manager = mock_conf_manager_class.return_value + # Mock return value for the "proxy" stanza + mock_conf_manager.get_conf.return_value = { + "proxy": { + "proxy_enabled": "", + "proxy_type": "http", + "proxy_url": "example.com", + "proxy_port": "invalid_port", # Invalid port + "proxy_username": "", + "proxy_password": "", + "proxy_rdns": "", + } + } + + with pytest.raises(InvalidPortError, match="The provided port is not valid."): + conf_manager.get_proxy_dict( + logger=mock.MagicMock(), + session_key="session_key", + app_name="app_name", + conf_name="conf_name", + proxy_port="proxy_port", # Check for invalid port + ) + + +@mock.patch.object(conf_manager, "ConfManager") +def test_get_proxy_dict_invalid_hostname(mock_conf_manager_class): + mock_conf_manager = mock_conf_manager_class.return_value + # Mock return value for the "proxy" stanza + mock_conf_manager.get_conf.return_value = { + "proxy": { + "proxy_enabled": "", + "proxy_type": "http", + "proxy_url": "invalid_host", # Invalid hostname + "proxy_port": "8080", + "proxy_username": "", + "proxy_password": "", + "proxy_rdns": "", + } + } + + with pytest.raises( + InvalidHostnameError, match="The provided hostname is not valid." + ): + conf_manager.get_proxy_dict( + logger=mock.MagicMock(), + session_key="session_key", + app_name="app_name", + conf_name="conf_name", + proxy_host="proxy_url", # Check for invalid hostname + ) + + +@mock.patch.object(conf_manager, "ConfManager") +def test_get_proxy_dict_conf_manager_exception(mock_conf_manager_class): + mock_conf_manager = mock_conf_manager_class.return_value + mock_conf_manager.get_conf.side_effect = ConfManagerException + + with pytest.raises( + ConfManagerException, match="Failed to fetch configuration file 'conf_name'." + ): + conf_manager.get_proxy_dict( + logger=mock.MagicMock(), + session_key="session_key", + app_name="app_name", + conf_name="conf_name", + ) + + +@mock.patch.object(conf_manager, "ConfManager") +def test_get_proxy_dict_conf_stanza_exception(mock_conf_manager_class): + mock_conf_manager = mock_conf_manager_class.return_value + mock_conf_manager.get_conf.return_value.get.side_effect = ( + ConfStanzaNotExistException + ) + with pytest.raises( + ConfStanzaNotExistException, + match="Failed to fetch 'custom_stanza' from the configuration file 'conf_name'. ", + ): + conf_manager.get_proxy_dict( + logger=mock.MagicMock(), + session_key="session_key", + app_name="app_name", + conf_name="conf_name", + proxy_stanza="custom_stanza", + ) From ca9b48b5536a1161986777754e68c7b9c0c3607a Mon Sep 17 00:00:00 2001 From: srv-rr-github-token <94607705+srv-rr-github-token@users.noreply.github.com> Date: Mon, 25 Nov 2024 10:35:10 +0000 Subject: [PATCH 3/3] chore(release): 5.5.0-beta.1 # [5.5.0-beta.1](https://github.com/splunk/addonfactory-solutions-library-python/compare/v5.4.0...v5.5.0-beta.1) (2024-11-25) ### Features * add function to get the proxy details ([#406](https://github.com/splunk/addonfactory-solutions-library-python/issues/406)) ([c9e1f73](https://github.com/splunk/addonfactory-solutions-library-python/commit/c9e1f7350620963422747d90cfde529d3bb17511)) --- pyproject.toml | 2 +- solnlib/__init__.py | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index 78042db3..f27e4522 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -16,7 +16,7 @@ [tool.poetry] name = "solnlib" -version = "5.4.0" +version = "5.5.0-beta.1" description = "The Splunk Software Development Kit for Splunk Solutions" authors = ["Splunk "] license = "Apache-2.0" diff --git a/solnlib/__init__.py b/solnlib/__init__.py index 3b2b2bda..2f45611c 100644 --- a/solnlib/__init__.py +++ b/solnlib/__init__.py @@ -56,4 +56,4 @@ "utils", ] -__version__ = "5.4.0" +__version__ = "5.5.0-beta.1"