stackit-mongodbflex 1.2.2__tar.gz → 1.3.0__tar.gz

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 (65) hide show
  1. stackit_mongodbflex-1.3.0/.gitignore +267 -0
  2. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/PKG-INFO +10 -11
  3. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/pyproject.toml +48 -36
  4. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/api_client.py +36 -25
  5. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/exceptions.py +1 -1
  6. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/__init__.py +0 -1
  7. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/acl.py +4 -3
  8. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/backup.py +4 -3
  9. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/backup_schedule.py +4 -3
  10. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/clone_instance_payload.py +4 -3
  11. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/clone_instance_response.py +4 -3
  12. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/create_instance_payload.py +4 -3
  13. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/create_instance_response.py +4 -3
  14. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/create_user_payload.py +4 -3
  15. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/create_user_response.py +4 -3
  16. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/data_point.py +4 -3
  17. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/error.py +4 -3
  18. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/flavor.py +4 -3
  19. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/get_backup_response.py +4 -3
  20. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/get_user_response.py +4 -3
  21. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/handlers_instances_slow_queries_response.py +7 -6
  22. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/handlers_instances_suggested_indexes_response.py +10 -9
  23. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/host.py +7 -6
  24. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/host_metric.py +7 -6
  25. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/instance.py +4 -3
  26. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/instance_flavor.py +4 -3
  27. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/instance_list_instance.py +4 -3
  28. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/instance_response.py +4 -3
  29. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/instance_response_user.py +4 -3
  30. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/list_backups_response.py +7 -6
  31. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/list_flavors_response.py +7 -6
  32. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/list_instances_response.py +7 -6
  33. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/list_metrics_response.py +7 -6
  34. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/list_restore_jobs_response.py +7 -6
  35. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/list_storages_response.py +4 -3
  36. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/list_user.py +4 -3
  37. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/list_users_response.py +7 -6
  38. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/list_versions_response.py +4 -3
  39. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/mongodbatlas_operation.py +4 -3
  40. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/mongodbatlas_stats.py +4 -3
  41. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/partial_update_instance_payload.py +4 -3
  42. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/partial_update_user_payload.py +4 -3
  43. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/restore_instance_payload.py +4 -3
  44. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/restore_instance_response.py +4 -3
  45. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/restore_instance_status.py +4 -3
  46. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/shape.py +7 -6
  47. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/slow_query.py +4 -3
  48. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/storage.py +4 -3
  49. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/storage_range.py +4 -3
  50. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/suggested_index.py +4 -3
  51. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/update_backup_schedule_payload.py +4 -3
  52. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/update_instance_payload.py +4 -3
  53. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/update_instance_response.py +4 -3
  54. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/update_user_payload.py +4 -3
  55. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/models/user.py +4 -3
  56. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/rest.py +19 -3
  57. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/LICENSE.md +0 -0
  58. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/NOTICE.txt +0 -0
  59. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/README.md +0 -0
  60. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/__init__.py +0 -0
  61. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/api/__init__.py +0 -0
  62. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/api/default_api.py +0 -0
  63. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/api_response.py +0 -0
  64. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/configuration.py +0 -0
  65. {stackit_mongodbflex-1.2.2 → stackit_mongodbflex-1.3.0}/src/stackit/mongodbflex/py.typed +0 -0
@@ -0,0 +1,267 @@
1
+ ### VisualStudioCode template
2
+ .vscode/*
3
+ !.vscode/settings.json
4
+ !.vscode/tasks.json
5
+ !.vscode/launch.json
6
+ !.vscode/extensions.json
7
+ !.vscode/*.code-snippets
8
+
9
+ # Local History for Visual Studio Code
10
+ .history/
11
+
12
+ # Built Visual Studio Code Extensions
13
+ *.vsix
14
+
15
+ ### JetBrains template
16
+ # Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm, CLion, Android Studio, WebStorm and Rider
17
+ # Reference: https://intellij-support.jetbrains.com/hc/en-us/articles/206544839
18
+
19
+ # User-specific stuff
20
+ .idea/**/workspace.xml
21
+ .idea/**/tasks.xml
22
+ .idea/**/usage.statistics.xml
23
+ .idea/**/dictionaries
24
+ .idea/**/shelf
25
+
26
+ # AWS User-specific
27
+ .idea/**/aws.xml
28
+
29
+ # Generated files
30
+ .idea/**/contentModel.xml
31
+
32
+ # Sensitive or high-churn files
33
+ .idea/**/dataSources/
34
+ .idea/**/dataSources.ids
35
+ .idea/**/dataSources.local.xml
36
+ .idea/**/sqlDataSources.xml
37
+ .idea/**/dynamic.xml
38
+ .idea/**/uiDesigner.xml
39
+ .idea/**/dbnavigator.xml
40
+
41
+ # Gradle
42
+ .idea/**/gradle.xml
43
+ .idea/**/libraries
44
+
45
+ # Gradle and Maven with auto-import
46
+ # When using Gradle or Maven with auto-import, you should exclude module files,
47
+ # since they will be recreated, and may cause churn. Uncomment if using
48
+ # auto-import.
49
+ # .idea/artifacts
50
+ # .idea/compiler.xml
51
+ # .idea/jarRepositories.xml
52
+ # .idea/modules.xml
53
+ # .idea/*.iml
54
+ # .idea/modules
55
+ # *.iml
56
+ # *.ipr
57
+
58
+ # CMake
59
+ cmake-build-*/
60
+
61
+ # Mongo Explorer plugin
62
+ .idea/**/mongoSettings.xml
63
+
64
+ # File-based project format
65
+ *.iws
66
+
67
+ # IntelliJ
68
+ out/
69
+
70
+ # mpeltonen/sbt-idea plugin
71
+ .idea_modules/
72
+
73
+ # JIRA plugin
74
+ atlassian-ide-plugin.xml
75
+
76
+ # Cursive Clojure plugin
77
+ .idea/replstate.xml
78
+
79
+ # SonarLint plugin
80
+ .idea/sonarlint/
81
+
82
+ # Crashlytics plugin (for Android Studio and IntelliJ)
83
+ com_crashlytics_export_strings.xml
84
+ crashlytics.properties
85
+ crashlytics-build.properties
86
+ fabric.properties
87
+
88
+ # Editor-based Rest Client
89
+ .idea/httpRequests
90
+
91
+ # Android studio 3.1+ serialized cache file
92
+ .idea/caches/build_file_checksums.ser
93
+
94
+ ### VirtualEnv template
95
+ # Virtualenv
96
+ # http://iamzed.com/2009/05/07/a-primer-on-virtualenv/
97
+ .Python
98
+ [Bb]in
99
+ [Ii]nclude
100
+ [Ll]ib
101
+ [Ll]ib64
102
+ [Ll]ocal
103
+ [Ss]cripts
104
+ pyvenv.cfg
105
+ .venv
106
+ pip-selfcheck.json
107
+
108
+ ### Python template
109
+ # Byte-compiled / optimized / DLL files
110
+ __pycache__/
111
+ *.py[cod]
112
+ *$py.class
113
+
114
+ # C extensions
115
+ *.so
116
+
117
+ # Distribution / packaging
118
+ build/
119
+ develop-eggs/
120
+ dist/
121
+ downloads/
122
+ eggs/
123
+ .eggs/
124
+ lib/
125
+ lib64/
126
+ parts/
127
+ sdist/
128
+ var/
129
+ wheels/
130
+ share/python-wheels/
131
+ *.egg-info/
132
+ .installed.cfg
133
+ *.egg
134
+ MANIFEST
135
+
136
+ # PyInstaller
137
+ # Usually these files are written by a python script from a template
138
+ # before PyInstaller builds the exe, so as to inject date/other infos into it.
139
+ *.manifest
140
+ *.spec
141
+
142
+ # Installer logs
143
+ pip-log.txt
144
+ pip-delete-this-directory.txt
145
+
146
+ # Unit test / coverage reports
147
+ htmlcov/
148
+ .tox/
149
+ .nox/
150
+ .coverage
151
+ .coverage.*
152
+ .cache
153
+ nosetests.xml
154
+ coverage.xml
155
+ *.cover
156
+ *.py,cover
157
+ .hypothesis/
158
+ .pytest_cache/
159
+ cover/
160
+
161
+ # Translations
162
+ *.mo
163
+ *.pot
164
+
165
+ # Django stuff:
166
+ *.log
167
+ local_settings.py
168
+ db.sqlite3
169
+ db.sqlite3-journal
170
+
171
+ # Flask stuff:
172
+ instance/
173
+ .webassets-cache
174
+
175
+ # Scrapy stuff:
176
+ .scrapy
177
+
178
+ # Sphinx documentation
179
+ docs/_build/
180
+
181
+ # PyBuilder
182
+ .pybuilder/
183
+ target/
184
+
185
+ # Jupyter Notebook
186
+ .ipynb_checkpoints
187
+
188
+ # IPython
189
+ profile_default/
190
+ ipython_config.py
191
+
192
+ # pyenv
193
+ # For a library or package, you might want to ignore these files since the code is
194
+ # intended to run in multiple environments; otherwise, check them in:
195
+ # .python-version
196
+
197
+ # pipenv
198
+ # According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control.
199
+ # However, in case of collaboration, if having platform-specific dependencies or dependencies
200
+ # having no cross-platform support, pipenv may install dependencies that don't work, or not
201
+ # install all needed dependencies.
202
+ #Pipfile.lock
203
+
204
+ # poetry
205
+ # Similar to Pipfile.lock, it is generally recommended to include poetry.lock in version control.
206
+ # This is especially recommended for binary packages to ensure reproducibility, and is more
207
+ # commonly ignored for libraries.
208
+ # https://python-poetry.org/docs/basic-usage/#commit-your-poetrylock-file-to-version-control
209
+ #poetry.lock
210
+
211
+ # pdm
212
+ # Similar to Pipfile.lock, it is generally recommended to include pdm.lock in version control.
213
+ #pdm.lock
214
+ # pdm stores project-wide configurations in .pdm.toml, but it is recommended to not include it
215
+ # in version control.
216
+ # https://pdm.fming.dev/#use-with-ide
217
+ .pdm.toml
218
+
219
+ # PEP 582; used by e.g. github.com/David-OConnor/pyflow and github.com/pdm-project/pdm
220
+ __pypackages__/
221
+
222
+ # Celery stuff
223
+ celerybeat-schedule
224
+ celerybeat.pid
225
+
226
+ # SageMath parsed files
227
+ *.sage.py
228
+
229
+ # Environments
230
+ .env
231
+ env/
232
+ venv/
233
+ ENV/
234
+ env.bak/
235
+ venv.bak/
236
+
237
+ # Spyder project settings
238
+ .spyderproject
239
+ .spyproject
240
+
241
+ # Rope project settings
242
+ .ropeproject
243
+
244
+ # mkdocs documentation
245
+ /site
246
+
247
+ # mypy
248
+ .mypy_cache/
249
+ .dmypy.json
250
+ dmypy.json
251
+
252
+ # Pyre type checker
253
+ .pyre/
254
+
255
+ # pytype static type analyzer
256
+ .pytype/
257
+
258
+ # Cython debug symbols
259
+ cython_debug/
260
+
261
+ # PyCharm
262
+ # JetBrains specific template is maintained in a separate JetBrains.gitignore that can
263
+ # be found at https://github.com/github/gitignore/blob/main/Global/JetBrains.gitignore
264
+ # and can be added to the global gitignore or merged into this file. For a more nuclear
265
+ # option (not recommended) you can uncomment the following to ignore the entire idea folder.
266
+ .idea/
267
+
@@ -1,12 +1,12 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: stackit-mongodbflex
3
- Version: 1.2.2
3
+ Version: 1.3.0
4
4
  Summary: STACKIT MongoDB Service API
5
+ Project-URL: Homepage, https://github.com/stackitcloud/stackit-sdk-python
6
+ Project-URL: Issues, https://github.com/stackitcloud/stackit-sdk-python/issues
7
+ Author-email: STACKIT Developer Tools <developer-tools@stackit.cloud>
5
8
  License-File: LICENSE.md
6
9
  License-File: NOTICE.txt
7
- Author: STACKIT Developer Tools
8
- Author-email: developer-tools@stackit.cloud
9
- Requires-Python: >=3.9,<4.0
10
10
  Classifier: License :: OSI Approved :: Apache Software License
11
11
  Classifier: Operating System :: OS Independent
12
12
  Classifier: Programming Language :: Python :: 3
@@ -16,12 +16,11 @@ Classifier: Programming Language :: Python :: 3.11
16
16
  Classifier: Programming Language :: Python :: 3.12
17
17
  Classifier: Programming Language :: Python :: 3.13
18
18
  Classifier: Programming Language :: Python :: 3.14
19
- Requires-Dist: pydantic (>=2.9.2)
20
- Requires-Dist: python-dateutil (>=2.9.0.post0)
21
- Requires-Dist: requests (>=2.32.3)
22
- Requires-Dist: stackit-core (>=0.0.1a)
23
- Project-URL: Homepage, https://github.com/stackitcloud/stackit-sdk-python
24
- Project-URL: Issues, https://github.com/stackitcloud/stackit-sdk-python/issues
19
+ Requires-Python: <4.0,>=3.9
20
+ Requires-Dist: pydantic>=2.9.2
21
+ Requires-Dist: python-dateutil>=2.9.0.post0
22
+ Requires-Dist: requests>=2.32.3
23
+ Requires-Dist: stackit-core>=0.0.1a
25
24
  Description-Content-Type: text/markdown
26
25
 
27
26
  # stackit.mongodbflex
@@ -46,4 +45,4 @@ import stackit.mongodbflex
46
45
 
47
46
  ## Getting Started
48
47
 
49
- [Examples](https://github.com/stackitcloud/stackit-sdk-python/tree/main/examples) for the usage of the package can be found in the [GitHub repository](https://github.com/stackitcloud/stackit-sdk-python) of the SDK.
48
+ [Examples](https://github.com/stackitcloud/stackit-sdk-python/tree/main/examples) for the usage of the package can be found in the [GitHub repository](https://github.com/stackitcloud/stackit-sdk-python) of the SDK.
@@ -1,55 +1,67 @@
1
1
  [project]
2
2
  name = "stackit-mongodbflex"
3
-
4
- [tool.poetry]
5
- name = "stackit-mongodbflex"
6
- version = "v1.2.2"
7
- authors = [
8
- "STACKIT Developer Tools <developer-tools@stackit.cloud>",
9
- ]
3
+ version = "v1.3.0"
10
4
  description = "STACKIT MongoDB Service API"
5
+ authors = [{ name = "STACKIT Developer Tools", email = "developer-tools@stackit.cloud" }]
6
+ requires-python = ">=3.9,<4.0"
11
7
  readme = "README.md"
12
- #license = "NoLicense"
13
8
  classifiers = [
14
9
  "Programming Language :: Python :: 3",
15
10
  "License :: OSI Approved :: Apache Software License",
16
11
  "Operating System :: OS Independent",
12
+ "Programming Language :: Python :: 3.9",
13
+ "Programming Language :: Python :: 3.10",
14
+ "Programming Language :: Python :: 3.11",
15
+ "Programming Language :: Python :: 3.12",
16
+ "Programming Language :: Python :: 3.13",
17
+ "Programming Language :: Python :: 3.14",
17
18
  ]
18
- packages = [
19
- { include = "stackit", from="src" }
19
+ dependencies = [
20
+ "stackit-core>=0.0.1a",
21
+ "requests>=2.32.3",
22
+ "pydantic>=2.9.2",
23
+ "python-dateutil>=2.9.0.post0",
20
24
  ]
21
25
 
22
- [tool.poetry.dependencies]
23
- python = ">=3.9,<4.0"
24
- stackit-core = ">=0.0.1a"
25
- requests = ">=2.32.3"
26
- pydantic = ">=2.9.2"
27
- python-dateutil = ">=2.9.0.post0"
28
-
29
- [tool.poetry.group.dev.dependencies]
30
- black = ">=24.8.0"
31
- pytest = ">=8.3.3"
32
- flake8 = [
33
- { version= ">=5.0.3", python="<3.12"},
34
- { version= ">=6.0.1", python=">=3.12"}
35
- ]
36
- flake8-black = ">=0.3.6"
37
- flake8-pyproject = ">=1.2.3"
38
- autoimport = ">=1.6.1"
39
- flake8-eol = ">=0.0.8"
40
- flake8-eradicate = ">=1.5.0"
41
- flake8-bandit = ">=4.1.1"
42
- flake8-bugbear = ">=23.1.14"
43
- flake8-quotes = ">=3.4.0"
44
- isort = ">=5.13.2"
45
-
46
26
  [project.urls]
47
27
  Homepage = "https://github.com/stackitcloud/stackit-sdk-python"
48
28
  Issues = "https://github.com/stackitcloud/stackit-sdk-python/issues"
49
29
 
30
+ [dependency-groups]
31
+ dev = [
32
+ "black>=24.8.0",
33
+ "pytest>=8.3.3",
34
+ "flake8>=5.0.3 ; python_full_version < '3.12'",
35
+ "flake8>=6.0.1 ; python_full_version >= '3.12'",
36
+ "flake8-black>=0.3.6",
37
+ "flake8-pyproject>=1.2.3",
38
+ "autoimport>=1.6.1",
39
+ "flake8-eol>=0.0.8",
40
+ "flake8-eradicate>=1.5.0",
41
+ "flake8-bandit>=4.1.1",
42
+ "flake8-bugbear>=23.1.14",
43
+ "flake8-quotes>=3.4.0",
44
+ "isort>=5.13.2",
45
+ ]
46
+
47
+ [tool.uv]
48
+ default-groups = "all"
49
+
50
+ [tool.uv.sources]
51
+ stackit-core = { path = "../../core" }
52
+
53
+ [tool.hatch.build.targets.sdist]
54
+ include = ["src/stackit"]
55
+
56
+ [tool.hatch.build.targets.wheel]
57
+ include = ["src/stackit"]
58
+
59
+ [tool.hatch.build.targets.wheel.sources]
60
+ "src/stackit" = "stackit"
61
+
50
62
  [build-system]
51
- requires = ["setuptools", "poetry-core"]
52
- build-backend = "poetry.core.masonry.api"
63
+ requires = ["hatchling"]
64
+ build-backend = "hatchling.build"
53
65
 
54
66
  [tool.pytest.ini_options]
55
67
  pythonpath = [
@@ -13,11 +13,13 @@
13
13
  """ # noqa: E501
14
14
 
15
15
  import datetime
16
+ import decimal
16
17
  import json
17
18
  import mimetypes
18
19
  import os
19
20
  import re
20
21
  import tempfile
22
+ import uuid
21
23
  from enum import Enum
22
24
  from typing import Dict, List, Optional, Tuple, Union
23
25
  from urllib.parse import quote
@@ -64,8 +66,11 @@ class ApiClient:
64
66
  "bool": bool,
65
67
  "date": datetime.date,
66
68
  "datetime": datetime.datetime,
69
+ "decimal": decimal.Decimal,
70
+ "UUID": uuid.UUID,
67
71
  "object": object,
68
72
  }
73
+ _pool = None
69
74
 
70
75
  def __init__(self, configuration, header_name=None, header_value=None, cookie=None) -> None:
71
76
  self.config: Configuration = configuration
@@ -262,13 +267,13 @@ class ApiClient:
262
267
  response_text = None
263
268
  return_data = None
264
269
  try:
265
- if response_type == "bytearray":
270
+ if response_type in ("bytearray", "bytes"):
266
271
  return_data = response_data.data
267
272
  elif response_type == "file":
268
273
  return_data = self.__deserialize_file(response_data)
269
274
  elif response_type is not None:
270
275
  match = None
271
- content_type = response_data.getheader("content-type")
276
+ content_type = response_data.headers.get("content-type")
272
277
  if content_type is not None:
273
278
  match = re.search(r"charset=([a-zA-Z\-\d]+)[\s;]?", content_type)
274
279
  encoding = match.group(1) if match else "utf-8"
@@ -285,7 +290,7 @@ class ApiClient:
285
290
  return ApiResponse(
286
291
  status_code=response_data.status,
287
292
  data=return_data,
288
- headers=response_data.getheaders(),
293
+ headers=response_data.headers,
289
294
  raw_data=response_data.data,
290
295
  )
291
296
 
@@ -297,6 +302,7 @@ class ApiClient:
297
302
  If obj is str, int, long, float, bool, return directly.
298
303
  If obj is datetime.datetime, datetime.date
299
304
  convert to string in iso8601 format.
305
+ If obj is decimal.Decimal return string representation.
300
306
  If obj is list, sanitize each element in the list.
301
307
  If obj is dict, return the dict.
302
308
  If obj is OpenAPI model, return the properties dict.
@@ -312,31 +318,30 @@ class ApiClient:
312
318
  return obj.get_secret_value()
313
319
  elif isinstance(obj, self.PRIMITIVE_TYPES):
314
320
  return obj
321
+ elif isinstance(obj, uuid.UUID):
322
+ return str(obj)
315
323
  elif isinstance(obj, list):
316
324
  return [self.sanitize_for_serialization(sub_obj) for sub_obj in obj]
317
325
  elif isinstance(obj, tuple):
318
326
  return tuple(self.sanitize_for_serialization(sub_obj) for sub_obj in obj)
319
327
  elif isinstance(obj, (datetime.datetime, datetime.date)):
320
328
  return obj.isoformat()
321
-
329
+ elif isinstance(obj, decimal.Decimal):
330
+ return str(obj)
322
331
  elif isinstance(obj, dict):
323
- obj_dict = obj
332
+ return {key: self.sanitize_for_serialization(val) for key, val in obj.items()}
333
+
334
+ # Convert model obj to dict except
335
+ # attributes `openapi_types`, `attribute_map`
336
+ # and attributes which value is not None.
337
+ # Convert attribute name to json key in
338
+ # model definition for request.
339
+ if hasattr(obj, "to_dict") and callable(getattr(obj, "to_dict")): # noqa: B009
340
+ obj_dict = obj.to_dict()
324
341
  else:
325
- # Convert model obj to dict except
326
- # attributes `openapi_types`, `attribute_map`
327
- # and attributes which value is not None.
328
- # Convert attribute name to json key in
329
- # model definition for request.
330
- if hasattr(obj, "to_dict") and callable(obj.to_dict):
331
- obj_dict = obj.to_dict()
332
- else:
333
- obj_dict = obj.__dict__
334
-
335
- if isinstance(obj_dict, list):
336
- # here we handle instances that can either be a list or something else, and only became a real list by calling to_dict() # noqa: E501
337
- return self.sanitize_for_serialization(obj_dict)
342
+ obj_dict = obj.__dict__
338
343
 
339
- return {key: self.sanitize_for_serialization(val) for key, val in obj_dict.items()}
344
+ return self.sanitize_for_serialization(obj_dict)
340
345
 
341
346
  def deserialize(self, response_text: str, response_type: str, content_type: Optional[str]):
342
347
  """Deserializes response into an object.
@@ -355,7 +360,7 @@ class ApiClient:
355
360
  data = json.loads(response_text)
356
361
  except ValueError:
357
362
  data = response_text
358
- elif re.match(r"^application/(json|[\w!#$&.+-^_]+\+json)\s*(;|$)", content_type, re.IGNORECASE):
363
+ elif re.match(r"^application/(json|[\w!#$&.+\-^_]+\+json)\s*(;|$)", content_type, re.IGNORECASE):
359
364
  if response_text == "":
360
365
  data = ""
361
366
  else:
@@ -401,12 +406,16 @@ class ApiClient:
401
406
 
402
407
  if klass in self.PRIMITIVE_TYPES:
403
408
  return self.__deserialize_primitive(data, klass)
404
- elif klass == object:
409
+ elif klass is object:
405
410
  return self.__deserialize_object(data)
406
- elif klass == datetime.date:
411
+ elif klass is datetime.date:
407
412
  return self.__deserialize_date(data)
408
- elif klass == datetime.datetime:
413
+ elif klass is datetime.datetime:
409
414
  return self.__deserialize_datetime(data)
415
+ elif klass is decimal.Decimal:
416
+ return decimal.Decimal(data)
417
+ elif klass is uuid.UUID:
418
+ return uuid.UUID(data)
410
419
  elif issubclass(klass, Enum):
411
420
  return self.__deserialize_enum(data, klass)
412
421
  else:
@@ -554,12 +563,14 @@ class ApiClient:
554
563
  os.close(fd)
555
564
  os.remove(path)
556
565
 
557
- content_disposition = response.getheader("Content-Disposition")
566
+ content_disposition = response.headers.get("Content-Disposition")
558
567
  if content_disposition:
559
568
  m = re.search(r'filename=[\'"]?([^\'"\s]+)[\'"]?', content_disposition)
560
569
  if m is None:
561
570
  raise ValueError("Unexpected 'content-disposition' header value")
562
- filename = m.group(1)
571
+ filename = os.path.basename(m.group(1)) # Strip any directory traversal
572
+ if filename in ("", ".", ".."): # fall back to tmp filename
573
+ filename = os.path.basename(path)
563
574
  path = os.path.join(os.path.dirname(path), filename)
564
575
 
565
576
  with open(path, "wb") as f:
@@ -130,7 +130,7 @@ class ApiException(OpenApiException):
130
130
  self.body = http_resp.data.decode("utf-8")
131
131
  except Exception: # noqa: S110
132
132
  pass
133
- self.headers = http_resp.getheaders()
133
+ self.headers = http_resp.headers
134
134
 
135
135
  @classmethod
136
136
  def from_response(
@@ -13,7 +13,6 @@
13
13
  Do not edit the class manually.
14
14
  """ # noqa: E501
15
15
 
16
-
17
16
  # import models into model package
18
17
  from stackit.mongodbflex.models.acl import ACL
19
18
  from stackit.mongodbflex.models.backup import Backup
@@ -19,6 +19,7 @@ import pprint
19
19
  from typing import Any, ClassVar, Dict, List, Optional, Set
20
20
 
21
21
  from pydantic import BaseModel, ConfigDict, StrictStr
22
+ from pydantic_core import to_jsonable_python
22
23
  from typing_extensions import Self
23
24
 
24
25
 
@@ -31,7 +32,8 @@ class ACL(BaseModel):
31
32
  __properties: ClassVar[List[str]] = ["items"]
32
33
 
33
34
  model_config = ConfigDict(
34
- populate_by_name=True,
35
+ validate_by_name=True,
36
+ validate_by_alias=True,
35
37
  validate_assignment=True,
36
38
  protected_namespaces=(),
37
39
  )
@@ -42,8 +44,7 @@ class ACL(BaseModel):
42
44
 
43
45
  def to_json(self) -> str:
44
46
  """Returns the JSON representation of the model using alias"""
45
- # TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
46
- return json.dumps(self.to_dict())
47
+ return json.dumps(to_jsonable_python(self.to_dict()))
47
48
 
48
49
  @classmethod
49
50
  def from_json(cls, json_str: str) -> Optional[Self]:
@@ -19,6 +19,7 @@ import pprint
19
19
  from typing import Any, ClassVar, Dict, List, Optional, Set
20
20
 
21
21
  from pydantic import BaseModel, ConfigDict, Field, StrictInt, StrictStr
22
+ from pydantic_core import to_jsonable_python
22
23
  from typing_extensions import Self
23
24
 
24
25
 
@@ -38,7 +39,8 @@ class Backup(BaseModel):
38
39
  __properties: ClassVar[List[str]] = ["endTime", "error", "id", "labels", "name", "options", "size", "startTime"]
39
40
 
40
41
  model_config = ConfigDict(
41
- populate_by_name=True,
42
+ validate_by_name=True,
43
+ validate_by_alias=True,
42
44
  validate_assignment=True,
43
45
  protected_namespaces=(),
44
46
  )
@@ -49,8 +51,7 @@ class Backup(BaseModel):
49
51
 
50
52
  def to_json(self) -> str:
51
53
  """Returns the JSON representation of the model using alias"""
52
- # TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
53
- return json.dumps(self.to_dict())
54
+ return json.dumps(to_jsonable_python(self.to_dict()))
54
55
 
55
56
  @classmethod
56
57
  def from_json(cls, json_str: str) -> Optional[Self]:
@@ -19,6 +19,7 @@ import pprint
19
19
  from typing import Any, ClassVar, Dict, List, Optional, Set
20
20
 
21
21
  from pydantic import BaseModel, ConfigDict, Field, StrictInt, StrictStr
22
+ from pydantic_core import to_jsonable_python
22
23
  from typing_extensions import Self
23
24
 
24
25
 
@@ -43,7 +44,8 @@ class BackupSchedule(BaseModel):
43
44
  ]
44
45
 
45
46
  model_config = ConfigDict(
46
- populate_by_name=True,
47
+ validate_by_name=True,
48
+ validate_by_alias=True,
47
49
  validate_assignment=True,
48
50
  protected_namespaces=(),
49
51
  )
@@ -54,8 +56,7 @@ class BackupSchedule(BaseModel):
54
56
 
55
57
  def to_json(self) -> str:
56
58
  """Returns the JSON representation of the model using alias"""
57
- # TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
58
- return json.dumps(self.to_dict())
59
+ return json.dumps(to_jsonable_python(self.to_dict()))
59
60
 
60
61
  @classmethod
61
62
  def from_json(cls, json_str: str) -> Optional[Self]:
@@ -19,6 +19,7 @@ import pprint
19
19
  from typing import Any, ClassVar, Dict, List, Optional, Set
20
20
 
21
21
  from pydantic import BaseModel, ConfigDict, Field, StrictStr
22
+ from pydantic_core import to_jsonable_python
22
23
  from typing_extensions import Self
23
24
 
24
25
 
@@ -32,7 +33,8 @@ class CloneInstancePayload(BaseModel):
32
33
  __properties: ClassVar[List[str]] = ["instanceId", "timestamp"]
33
34
 
34
35
  model_config = ConfigDict(
35
- populate_by_name=True,
36
+ validate_by_name=True,
37
+ validate_by_alias=True,
36
38
  validate_assignment=True,
37
39
  protected_namespaces=(),
38
40
  )
@@ -43,8 +45,7 @@ class CloneInstancePayload(BaseModel):
43
45
 
44
46
  def to_json(self) -> str:
45
47
  """Returns the JSON representation of the model using alias"""
46
- # TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
47
- return json.dumps(self.to_dict())
48
+ return json.dumps(to_jsonable_python(self.to_dict()))
48
49
 
49
50
  @classmethod
50
51
  def from_json(cls, json_str: str) -> Optional[Self]: