stackit-auditlog 0.1.0__tar.gz → 0.1.2__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.
- stackit_auditlog-0.1.2/.gitignore +267 -0
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/PKG-INFO +14 -12
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/pyproject.toml +49 -37
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/__init__.py +1 -1
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/api/default_api.py +20 -19
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/api_client.py +23 -10
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/configuration.py +1 -1
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/exceptions.py +2 -2
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/models/__init__.py +1 -2
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/models/audit_log_entry_context_response.py +1 -1
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/models/audit_log_entry_initiator_response.py +1 -1
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/models/audit_log_entry_request_response.py +1 -1
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/models/audit_log_entry_response.py +28 -1
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/models/audit_log_entry_service_account_delegation_info_response.py +4 -4
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/models/error_response.py +24 -2
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/models/gateway_error_response.py +9 -2
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/models/list_audit_log_entries_response.py +12 -5
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/models/service_account_delegation_info_principal_response.py +1 -1
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/rest.py +20 -4
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/LICENSE.md +0 -0
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/NOTICE.txt +0 -0
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/README.md +0 -0
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/api/__init__.py +0 -0
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/api_response.py +0 -0
- {stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/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,10 +1,12 @@
|
|
|
1
|
-
Metadata-Version: 2.
|
|
1
|
+
Metadata-Version: 2.4
|
|
2
2
|
Name: stackit-auditlog
|
|
3
|
-
Version: 0.1.
|
|
3
|
+
Version: 0.1.2
|
|
4
4
|
Summary: Audit Log API
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
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>
|
|
8
|
+
License-File: LICENSE.md
|
|
9
|
+
License-File: NOTICE.txt
|
|
8
10
|
Classifier: License :: OSI Approved :: Apache Software License
|
|
9
11
|
Classifier: Operating System :: OS Independent
|
|
10
12
|
Classifier: Programming Language :: Python :: 3
|
|
@@ -13,12 +15,12 @@ Classifier: Programming Language :: Python :: 3.10
|
|
|
13
15
|
Classifier: Programming Language :: Python :: 3.11
|
|
14
16
|
Classifier: Programming Language :: Python :: 3.12
|
|
15
17
|
Classifier: Programming Language :: Python :: 3.13
|
|
16
|
-
|
|
17
|
-
Requires-
|
|
18
|
-
Requires-Dist:
|
|
19
|
-
Requires-Dist:
|
|
20
|
-
|
|
21
|
-
|
|
18
|
+
Classifier: Programming Language :: Python :: 3.14
|
|
19
|
+
Requires-Python: <4,>=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
|
|
22
24
|
Description-Content-Type: text/markdown
|
|
23
25
|
|
|
24
26
|
# stackit.auditlog
|
|
@@ -55,4 +57,4 @@ import stackit.auditlog
|
|
|
55
57
|
|
|
56
58
|
## Getting Started
|
|
57
59
|
|
|
58
|
-
[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.
|
|
60
|
+
[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-auditlog"
|
|
3
|
-
|
|
4
|
-
[tool.poetry]
|
|
5
|
-
name = "stackit-auditlog"
|
|
6
|
-
version = "v0.1.0"
|
|
7
|
-
authors = [
|
|
8
|
-
"STACKIT Developer Tools <developer-tools@stackit.cloud>",
|
|
9
|
-
]
|
|
3
|
+
version = "v0.1.2"
|
|
10
4
|
description = "Audit Log API"
|
|
5
|
+
authors = [{ name = "STACKIT Developer Tools", email = "developer-tools@stackit.cloud" }]
|
|
6
|
+
requires-python = ">=3.9,<4"
|
|
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
|
-
|
|
19
|
-
|
|
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"
|
|
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 = ["
|
|
52
|
-
build-backend = "
|
|
63
|
+
requires = ["hatchling"]
|
|
64
|
+
build-backend = "hatchling.build"
|
|
53
65
|
|
|
54
66
|
[tool.pytest.ini_options]
|
|
55
67
|
pythonpath = [
|
|
@@ -96,4 +108,4 @@ docstring-quotes = '"""'
|
|
|
96
108
|
multiline-quotes = '"""'
|
|
97
109
|
ban-relative-imports = true
|
|
98
110
|
# Exclude generated code
|
|
99
|
-
extend-exclude = [ "src/stackit/*/models/*", "src/stackit/*/api/*", "src/stackit/*/*.py" ]
|
|
111
|
+
extend-exclude = [ "src/stackit/*/models/*", "src/stackit/*/api/*", "src/stackit/*/*.py" ]
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
# flake8: noqa
|
|
4
4
|
|
|
5
5
|
"""
|
|
6
|
-
Audit Log API
|
|
6
|
+
STACKIT Audit Log API
|
|
7
7
|
|
|
8
8
|
API Endpoints to retrieve recorded actions and resulting changes in the system. ### Documentation The user documentation with explanations how to use the api can be found [here](https://docs.stackit.cloud/stackit/en/retrieve-audit-log-per-api-request-134415907.html). ### Audit Logging Changes on organizations, folders and projects and respective cloud resources are logged and collected in the audit log. ### API Constraints The audit log API allows to download messages from the last 90 days. The maximum duration that can be queried at once is 24 hours. Requests are rate limited - the current maximum is 60 requests per minute.
|
|
9
9
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
# coding: utf-8
|
|
2
2
|
|
|
3
3
|
"""
|
|
4
|
-
Audit Log API
|
|
4
|
+
STACKIT Audit Log API
|
|
5
5
|
|
|
6
6
|
API Endpoints to retrieve recorded actions and resulting changes in the system. ### Documentation The user documentation with explanations how to use the api can be found [here](https://docs.stackit.cloud/stackit/en/retrieve-audit-log-per-api-request-134415907.html). ### Audit Logging Changes on organizations, folders and projects and respective cloud resources are logged and collected in the audit log. ### API Constraints The audit log API allows to download messages from the last 90 days. The maximum duration that can be queried at once is 24 hours. Requests are rate limited - the current maximum is 60 requests per minute.
|
|
7
7
|
|
|
@@ -13,6 +13,7 @@
|
|
|
13
13
|
|
|
14
14
|
from datetime import datetime
|
|
15
15
|
from typing import Any, Dict, List, Optional, Tuple, Union
|
|
16
|
+
from uuid import UUID
|
|
16
17
|
|
|
17
18
|
from pydantic import Field, StrictFloat, StrictInt, StrictStr, validate_call
|
|
18
19
|
from stackit.core.configuration import Configuration
|
|
@@ -42,7 +43,7 @@ class DefaultApi:
|
|
|
42
43
|
@validate_call
|
|
43
44
|
def list_folder_audit_log_entries(
|
|
44
45
|
self,
|
|
45
|
-
folder_id: Annotated[
|
|
46
|
+
folder_id: Annotated[UUID, Field(description="ID of the folder for which entries should be returned.")],
|
|
46
47
|
start_time_range: Annotated[
|
|
47
48
|
datetime,
|
|
48
49
|
Field(
|
|
@@ -86,7 +87,7 @@ class DefaultApi:
|
|
|
86
87
|
Returns all audit log entries of the folder for the specified period. \\ Period must not be longer than 24 hours within the last 90 days.
|
|
87
88
|
|
|
88
89
|
:param folder_id: ID of the folder for which entries should be returned. (required)
|
|
89
|
-
:type folder_id:
|
|
90
|
+
:type folder_id: UUID
|
|
90
91
|
:param start_time_range: An ISO timestamp to specify the beginning of the time range from which entries should be returned, based on the eventTimeStamp. If not given, defaults to the beginning of time. (required)
|
|
91
92
|
:type start_time_range: datetime
|
|
92
93
|
:param end_time_range: An ISO timestamp to specify the end of the time range up until which entries should be returned, based on the eventTimeStamp. If not given, defaults to the time this request was received. (required)
|
|
@@ -146,7 +147,7 @@ class DefaultApi:
|
|
|
146
147
|
@validate_call
|
|
147
148
|
def list_folder_audit_log_entries_with_http_info(
|
|
148
149
|
self,
|
|
149
|
-
folder_id: Annotated[
|
|
150
|
+
folder_id: Annotated[UUID, Field(description="ID of the folder for which entries should be returned.")],
|
|
150
151
|
start_time_range: Annotated[
|
|
151
152
|
datetime,
|
|
152
153
|
Field(
|
|
@@ -190,7 +191,7 @@ class DefaultApi:
|
|
|
190
191
|
Returns all audit log entries of the folder for the specified period. \\ Period must not be longer than 24 hours within the last 90 days.
|
|
191
192
|
|
|
192
193
|
:param folder_id: ID of the folder for which entries should be returned. (required)
|
|
193
|
-
:type folder_id:
|
|
194
|
+
:type folder_id: UUID
|
|
194
195
|
:param start_time_range: An ISO timestamp to specify the beginning of the time range from which entries should be returned, based on the eventTimeStamp. If not given, defaults to the beginning of time. (required)
|
|
195
196
|
:type start_time_range: datetime
|
|
196
197
|
:param end_time_range: An ISO timestamp to specify the end of the time range up until which entries should be returned, based on the eventTimeStamp. If not given, defaults to the time this request was received. (required)
|
|
@@ -250,7 +251,7 @@ class DefaultApi:
|
|
|
250
251
|
@validate_call
|
|
251
252
|
def list_folder_audit_log_entries_without_preload_content(
|
|
252
253
|
self,
|
|
253
|
-
folder_id: Annotated[
|
|
254
|
+
folder_id: Annotated[UUID, Field(description="ID of the folder for which entries should be returned.")],
|
|
254
255
|
start_time_range: Annotated[
|
|
255
256
|
datetime,
|
|
256
257
|
Field(
|
|
@@ -294,7 +295,7 @@ class DefaultApi:
|
|
|
294
295
|
Returns all audit log entries of the folder for the specified period. \\ Period must not be longer than 24 hours within the last 90 days.
|
|
295
296
|
|
|
296
297
|
:param folder_id: ID of the folder for which entries should be returned. (required)
|
|
297
|
-
:type folder_id:
|
|
298
|
+
:type folder_id: UUID
|
|
298
299
|
:param start_time_range: An ISO timestamp to specify the beginning of the time range from which entries should be returned, based on the eventTimeStamp. If not given, defaults to the beginning of time. (required)
|
|
299
300
|
:type start_time_range: datetime
|
|
300
301
|
:param end_time_range: An ISO timestamp to specify the end of the time range up until which entries should be returned, based on the eventTimeStamp. If not given, defaults to the time this request was received. (required)
|
|
@@ -429,7 +430,7 @@ class DefaultApi:
|
|
|
429
430
|
def list_organization_audit_log_entries(
|
|
430
431
|
self,
|
|
431
432
|
organization_id: Annotated[
|
|
432
|
-
|
|
433
|
+
UUID, Field(description="ID of the organization for which entries should be returned.")
|
|
433
434
|
],
|
|
434
435
|
start_time_range: Annotated[
|
|
435
436
|
datetime,
|
|
@@ -474,7 +475,7 @@ class DefaultApi:
|
|
|
474
475
|
Returns all audit log entries of the organization for the specified period. \\ Period must not be longer than 24 hours within the last 90 days.
|
|
475
476
|
|
|
476
477
|
:param organization_id: ID of the organization for which entries should be returned. (required)
|
|
477
|
-
:type organization_id:
|
|
478
|
+
:type organization_id: UUID
|
|
478
479
|
:param start_time_range: An ISO timestamp to specify the beginning of the time range from which entries should be returned, based on the eventTimeStamp. If not given, defaults to the beginning of time. (required)
|
|
479
480
|
:type start_time_range: datetime
|
|
480
481
|
:param end_time_range: An ISO timestamp to specify the end of the time range up until which entries should be returned, based on the eventTimeStamp. If not given, defaults to the time this request was received. (required)
|
|
@@ -535,7 +536,7 @@ class DefaultApi:
|
|
|
535
536
|
def list_organization_audit_log_entries_with_http_info(
|
|
536
537
|
self,
|
|
537
538
|
organization_id: Annotated[
|
|
538
|
-
|
|
539
|
+
UUID, Field(description="ID of the organization for which entries should be returned.")
|
|
539
540
|
],
|
|
540
541
|
start_time_range: Annotated[
|
|
541
542
|
datetime,
|
|
@@ -580,7 +581,7 @@ class DefaultApi:
|
|
|
580
581
|
Returns all audit log entries of the organization for the specified period. \\ Period must not be longer than 24 hours within the last 90 days.
|
|
581
582
|
|
|
582
583
|
:param organization_id: ID of the organization for which entries should be returned. (required)
|
|
583
|
-
:type organization_id:
|
|
584
|
+
:type organization_id: UUID
|
|
584
585
|
:param start_time_range: An ISO timestamp to specify the beginning of the time range from which entries should be returned, based on the eventTimeStamp. If not given, defaults to the beginning of time. (required)
|
|
585
586
|
:type start_time_range: datetime
|
|
586
587
|
:param end_time_range: An ISO timestamp to specify the end of the time range up until which entries should be returned, based on the eventTimeStamp. If not given, defaults to the time this request was received. (required)
|
|
@@ -641,7 +642,7 @@ class DefaultApi:
|
|
|
641
642
|
def list_organization_audit_log_entries_without_preload_content(
|
|
642
643
|
self,
|
|
643
644
|
organization_id: Annotated[
|
|
644
|
-
|
|
645
|
+
UUID, Field(description="ID of the organization for which entries should be returned.")
|
|
645
646
|
],
|
|
646
647
|
start_time_range: Annotated[
|
|
647
648
|
datetime,
|
|
@@ -686,7 +687,7 @@ class DefaultApi:
|
|
|
686
687
|
Returns all audit log entries of the organization for the specified period. \\ Period must not be longer than 24 hours within the last 90 days.
|
|
687
688
|
|
|
688
689
|
:param organization_id: ID of the organization for which entries should be returned. (required)
|
|
689
|
-
:type organization_id:
|
|
690
|
+
:type organization_id: UUID
|
|
690
691
|
:param start_time_range: An ISO timestamp to specify the beginning of the time range from which entries should be returned, based on the eventTimeStamp. If not given, defaults to the beginning of time. (required)
|
|
691
692
|
:type start_time_range: datetime
|
|
692
693
|
:param end_time_range: An ISO timestamp to specify the end of the time range up until which entries should be returned, based on the eventTimeStamp. If not given, defaults to the time this request was received. (required)
|
|
@@ -820,7 +821,7 @@ class DefaultApi:
|
|
|
820
821
|
@validate_call
|
|
821
822
|
def list_project_audit_log_entries(
|
|
822
823
|
self,
|
|
823
|
-
project_id: Annotated[
|
|
824
|
+
project_id: Annotated[UUID, Field(description="ID of the project for which entries should be returned.")],
|
|
824
825
|
start_time_range: Annotated[
|
|
825
826
|
datetime,
|
|
826
827
|
Field(
|
|
@@ -864,7 +865,7 @@ class DefaultApi:
|
|
|
864
865
|
Returns all audit log entries of the project for the specified period. \\ Period must not be longer than 24 hours within the last 90 days.
|
|
865
866
|
|
|
866
867
|
:param project_id: ID of the project for which entries should be returned. (required)
|
|
867
|
-
:type project_id:
|
|
868
|
+
:type project_id: UUID
|
|
868
869
|
:param start_time_range: An ISO timestamp to specify the beginning of the time range from which entries should be returned, based on the eventTimeStamp. If not given, defaults to the beginning of time. (required)
|
|
869
870
|
:type start_time_range: datetime
|
|
870
871
|
:param end_time_range: An ISO timestamp to specify the end of the time range up until which entries should be returned, based on the eventTimeStamp. If not given, defaults to the time this request was received. (required)
|
|
@@ -924,7 +925,7 @@ class DefaultApi:
|
|
|
924
925
|
@validate_call
|
|
925
926
|
def list_project_audit_log_entries_with_http_info(
|
|
926
927
|
self,
|
|
927
|
-
project_id: Annotated[
|
|
928
|
+
project_id: Annotated[UUID, Field(description="ID of the project for which entries should be returned.")],
|
|
928
929
|
start_time_range: Annotated[
|
|
929
930
|
datetime,
|
|
930
931
|
Field(
|
|
@@ -968,7 +969,7 @@ class DefaultApi:
|
|
|
968
969
|
Returns all audit log entries of the project for the specified period. \\ Period must not be longer than 24 hours within the last 90 days.
|
|
969
970
|
|
|
970
971
|
:param project_id: ID of the project for which entries should be returned. (required)
|
|
971
|
-
:type project_id:
|
|
972
|
+
:type project_id: UUID
|
|
972
973
|
:param start_time_range: An ISO timestamp to specify the beginning of the time range from which entries should be returned, based on the eventTimeStamp. If not given, defaults to the beginning of time. (required)
|
|
973
974
|
:type start_time_range: datetime
|
|
974
975
|
:param end_time_range: An ISO timestamp to specify the end of the time range up until which entries should be returned, based on the eventTimeStamp. If not given, defaults to the time this request was received. (required)
|
|
@@ -1028,7 +1029,7 @@ class DefaultApi:
|
|
|
1028
1029
|
@validate_call
|
|
1029
1030
|
def list_project_audit_log_entries_without_preload_content(
|
|
1030
1031
|
self,
|
|
1031
|
-
project_id: Annotated[
|
|
1032
|
+
project_id: Annotated[UUID, Field(description="ID of the project for which entries should be returned.")],
|
|
1032
1033
|
start_time_range: Annotated[
|
|
1033
1034
|
datetime,
|
|
1034
1035
|
Field(
|
|
@@ -1072,7 +1073,7 @@ class DefaultApi:
|
|
|
1072
1073
|
Returns all audit log entries of the project for the specified period. \\ Period must not be longer than 24 hours within the last 90 days.
|
|
1073
1074
|
|
|
1074
1075
|
:param project_id: ID of the project for which entries should be returned. (required)
|
|
1075
|
-
:type project_id:
|
|
1076
|
+
:type project_id: UUID
|
|
1076
1077
|
:param start_time_range: An ISO timestamp to specify the beginning of the time range from which entries should be returned, based on the eventTimeStamp. If not given, defaults to the beginning of time. (required)
|
|
1077
1078
|
:type start_time_range: datetime
|
|
1078
1079
|
:param end_time_range: An ISO timestamp to specify the end of the time range up until which entries should be returned, based on the eventTimeStamp. If not given, defaults to the time this request was received. (required)
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
# coding: utf-8
|
|
2
2
|
|
|
3
3
|
"""
|
|
4
|
-
Audit Log API
|
|
4
|
+
STACKIT Audit Log API
|
|
5
5
|
|
|
6
6
|
API Endpoints to retrieve recorded actions and resulting changes in the system. ### Documentation The user documentation with explanations how to use the api can be found [here](https://docs.stackit.cloud/stackit/en/retrieve-audit-log-per-api-request-134415907.html). ### Audit Logging Changes on organizations, folders and projects and respective cloud resources are logged and collected in the audit log. ### API Constraints The audit log API allows to download messages from the last 90 days. The maximum duration that can be queried at once is 24 hours. Requests are rate limited - the current maximum is 60 requests per minute.
|
|
7
7
|
|
|
@@ -12,11 +12,13 @@
|
|
|
12
12
|
""" # noqa: E501
|
|
13
13
|
|
|
14
14
|
import datetime
|
|
15
|
+
import decimal
|
|
15
16
|
import json
|
|
16
17
|
import mimetypes
|
|
17
18
|
import os
|
|
18
19
|
import re
|
|
19
20
|
import tempfile
|
|
21
|
+
import uuid
|
|
20
22
|
from enum import Enum
|
|
21
23
|
from typing import Dict, List, Optional, Tuple, Union
|
|
22
24
|
from urllib.parse import quote
|
|
@@ -63,8 +65,10 @@ class ApiClient:
|
|
|
63
65
|
"bool": bool,
|
|
64
66
|
"date": datetime.date,
|
|
65
67
|
"datetime": datetime.datetime,
|
|
68
|
+
"decimal": decimal.Decimal,
|
|
66
69
|
"object": object,
|
|
67
70
|
}
|
|
71
|
+
_pool = None
|
|
68
72
|
|
|
69
73
|
def __init__(self, configuration, header_name=None, header_value=None, cookie=None) -> None:
|
|
70
74
|
self.config: Configuration = configuration
|
|
@@ -267,7 +271,7 @@ class ApiClient:
|
|
|
267
271
|
return_data = self.__deserialize_file(response_data)
|
|
268
272
|
elif response_type is not None:
|
|
269
273
|
match = None
|
|
270
|
-
content_type = response_data.
|
|
274
|
+
content_type = response_data.headers.get("content-type")
|
|
271
275
|
if content_type is not None:
|
|
272
276
|
match = re.search(r"charset=([a-zA-Z\-\d]+)[\s;]?", content_type)
|
|
273
277
|
encoding = match.group(1) if match else "utf-8"
|
|
@@ -284,7 +288,7 @@ class ApiClient:
|
|
|
284
288
|
return ApiResponse(
|
|
285
289
|
status_code=response_data.status,
|
|
286
290
|
data=return_data,
|
|
287
|
-
headers=response_data.
|
|
291
|
+
headers=response_data.headers,
|
|
288
292
|
raw_data=response_data.data,
|
|
289
293
|
)
|
|
290
294
|
|
|
@@ -296,6 +300,7 @@ class ApiClient:
|
|
|
296
300
|
If obj is str, int, long, float, bool, return directly.
|
|
297
301
|
If obj is datetime.datetime, datetime.date
|
|
298
302
|
convert to string in iso8601 format.
|
|
303
|
+
If obj is decimal.Decimal return string representation.
|
|
299
304
|
If obj is list, sanitize each element in the list.
|
|
300
305
|
If obj is dict, return the dict.
|
|
301
306
|
If obj is OpenAPI model, return the properties dict.
|
|
@@ -311,12 +316,16 @@ class ApiClient:
|
|
|
311
316
|
return obj.get_secret_value()
|
|
312
317
|
elif isinstance(obj, self.PRIMITIVE_TYPES):
|
|
313
318
|
return obj
|
|
319
|
+
elif isinstance(obj, uuid.UUID):
|
|
320
|
+
return str(obj)
|
|
314
321
|
elif isinstance(obj, list):
|
|
315
322
|
return [self.sanitize_for_serialization(sub_obj) for sub_obj in obj]
|
|
316
323
|
elif isinstance(obj, tuple):
|
|
317
324
|
return tuple(self.sanitize_for_serialization(sub_obj) for sub_obj in obj)
|
|
318
325
|
elif isinstance(obj, (datetime.datetime, datetime.date)):
|
|
319
326
|
return obj.isoformat()
|
|
327
|
+
elif isinstance(obj, decimal.Decimal):
|
|
328
|
+
return str(obj)
|
|
320
329
|
|
|
321
330
|
elif isinstance(obj, dict):
|
|
322
331
|
obj_dict = obj
|
|
@@ -326,7 +335,7 @@ class ApiClient:
|
|
|
326
335
|
# and attributes which value is not None.
|
|
327
336
|
# Convert attribute name to json key in
|
|
328
337
|
# model definition for request.
|
|
329
|
-
if hasattr(obj, "to_dict") and callable(obj
|
|
338
|
+
if hasattr(obj, "to_dict") and callable(getattr(obj, "to_dict")): # noqa: B009
|
|
330
339
|
obj_dict = obj.to_dict()
|
|
331
340
|
else:
|
|
332
341
|
obj_dict = obj.__dict__
|
|
@@ -354,7 +363,7 @@ class ApiClient:
|
|
|
354
363
|
data = json.loads(response_text)
|
|
355
364
|
except ValueError:
|
|
356
365
|
data = response_text
|
|
357
|
-
elif re.match(r"^application/(json|[\w
|
|
366
|
+
elif re.match(r"^application/(json|[\w!#$&.+\-^_]+\+json)\s*(;|$)", content_type, re.IGNORECASE):
|
|
358
367
|
if response_text == "":
|
|
359
368
|
data = ""
|
|
360
369
|
else:
|
|
@@ -400,12 +409,14 @@ class ApiClient:
|
|
|
400
409
|
|
|
401
410
|
if klass in self.PRIMITIVE_TYPES:
|
|
402
411
|
return self.__deserialize_primitive(data, klass)
|
|
403
|
-
elif klass
|
|
412
|
+
elif klass is object:
|
|
404
413
|
return self.__deserialize_object(data)
|
|
405
|
-
elif klass
|
|
414
|
+
elif klass is datetime.date:
|
|
406
415
|
return self.__deserialize_date(data)
|
|
407
|
-
elif klass
|
|
416
|
+
elif klass is datetime.datetime:
|
|
408
417
|
return self.__deserialize_datetime(data)
|
|
418
|
+
elif klass is decimal.Decimal:
|
|
419
|
+
return decimal.Decimal(data)
|
|
409
420
|
elif issubclass(klass, Enum):
|
|
410
421
|
return self.__deserialize_enum(data, klass)
|
|
411
422
|
else:
|
|
@@ -553,12 +564,14 @@ class ApiClient:
|
|
|
553
564
|
os.close(fd)
|
|
554
565
|
os.remove(path)
|
|
555
566
|
|
|
556
|
-
content_disposition = response.
|
|
567
|
+
content_disposition = response.headers.get("Content-Disposition")
|
|
557
568
|
if content_disposition:
|
|
558
569
|
m = re.search(r'filename=[\'"]?([^\'"\s]+)[\'"]?', content_disposition)
|
|
559
570
|
if m is None:
|
|
560
571
|
raise ValueError("Unexpected 'content-disposition' header value")
|
|
561
|
-
filename = m.group(1)
|
|
572
|
+
filename = os.path.basename(m.group(1)) # Strip any directory traversal
|
|
573
|
+
if filename in ("", ".", ".."): # fall back to tmp filename
|
|
574
|
+
filename = os.path.basename(path)
|
|
562
575
|
path = os.path.join(os.path.dirname(path), filename)
|
|
563
576
|
|
|
564
577
|
with open(path, "wb") as f:
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
# coding: utf-8
|
|
2
2
|
|
|
3
3
|
"""
|
|
4
|
-
Audit Log API
|
|
4
|
+
STACKIT Audit Log API
|
|
5
5
|
|
|
6
6
|
API Endpoints to retrieve recorded actions and resulting changes in the system. ### Documentation The user documentation with explanations how to use the api can be found [here](https://docs.stackit.cloud/stackit/en/retrieve-audit-log-per-api-request-134415907.html). ### Audit Logging Changes on organizations, folders and projects and respective cloud resources are logged and collected in the audit log. ### API Constraints The audit log API allows to download messages from the last 90 days. The maximum duration that can be queried at once is 24 hours. Requests are rate limited - the current maximum is 60 requests per minute.
|
|
7
7
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
# coding: utf-8
|
|
2
2
|
|
|
3
3
|
"""
|
|
4
|
-
Audit Log API
|
|
4
|
+
STACKIT Audit Log API
|
|
5
5
|
|
|
6
6
|
API Endpoints to retrieve recorded actions and resulting changes in the system. ### Documentation The user documentation with explanations how to use the api can be found [here](https://docs.stackit.cloud/stackit/en/retrieve-audit-log-per-api-request-134415907.html). ### Audit Logging Changes on organizations, folders and projects and respective cloud resources are logged and collected in the audit log. ### API Constraints The audit log API allows to download messages from the last 90 days. The maximum duration that can be queried at once is 24 hours. Requests are rate limited - the current maximum is 60 requests per minute.
|
|
7
7
|
|
|
@@ -129,7 +129,7 @@ class ApiException(OpenApiException):
|
|
|
129
129
|
self.body = http_resp.data.decode("utf-8")
|
|
130
130
|
except Exception: # noqa: S110
|
|
131
131
|
pass
|
|
132
|
-
self.headers = http_resp.
|
|
132
|
+
self.headers = http_resp.headers
|
|
133
133
|
|
|
134
134
|
@classmethod
|
|
135
135
|
def from_response(
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
# flake8: noqa
|
|
4
4
|
"""
|
|
5
|
-
Audit Log API
|
|
5
|
+
STACKIT Audit Log API
|
|
6
6
|
|
|
7
7
|
API Endpoints to retrieve recorded actions and resulting changes in the system. ### Documentation The user documentation with explanations how to use the api can be found [here](https://docs.stackit.cloud/stackit/en/retrieve-audit-log-per-api-request-134415907.html). ### Audit Logging Changes on organizations, folders and projects and respective cloud resources are logged and collected in the audit log. ### API Constraints The audit log API allows to download messages from the last 90 days. The maximum duration that can be queried at once is 24 hours. Requests are rate limited - the current maximum is 60 requests per minute.
|
|
8
8
|
|
|
@@ -12,7 +12,6 @@
|
|
|
12
12
|
Do not edit the class manually.
|
|
13
13
|
""" # noqa: E501
|
|
14
14
|
|
|
15
|
-
|
|
16
15
|
# import models into model package
|
|
17
16
|
from stackit.auditlog.models.audit_log_entry_context_response import (
|
|
18
17
|
AuditLogEntryContextResponse,
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
# coding: utf-8
|
|
2
2
|
|
|
3
3
|
"""
|
|
4
|
-
Audit Log API
|
|
4
|
+
STACKIT Audit Log API
|
|
5
5
|
|
|
6
6
|
API Endpoints to retrieve recorded actions and resulting changes in the system. ### Documentation The user documentation with explanations how to use the api can be found [here](https://docs.stackit.cloud/stackit/en/retrieve-audit-log-per-api-request-134415907.html). ### Audit Logging Changes on organizations, folders and projects and respective cloud resources are logged and collected in the audit log. ### API Constraints The audit log API allows to download messages from the last 90 days. The maximum duration that can be queried at once is 24 hours. Requests are rate limited - the current maximum is 60 requests per minute.
|
|
7
7
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
# coding: utf-8
|
|
2
2
|
|
|
3
3
|
"""
|
|
4
|
-
Audit Log API
|
|
4
|
+
STACKIT Audit Log API
|
|
5
5
|
|
|
6
6
|
API Endpoints to retrieve recorded actions and resulting changes in the system. ### Documentation The user documentation with explanations how to use the api can be found [here](https://docs.stackit.cloud/stackit/en/retrieve-audit-log-per-api-request-134415907.html). ### Audit Logging Changes on organizations, folders and projects and respective cloud resources are logged and collected in the audit log. ### API Constraints The audit log API allows to download messages from the last 90 days. The maximum duration that can be queried at once is 24 hours. Requests are rate limited - the current maximum is 60 requests per minute.
|
|
7
7
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
# coding: utf-8
|
|
2
2
|
|
|
3
3
|
"""
|
|
4
|
-
Audit Log API
|
|
4
|
+
STACKIT Audit Log API
|
|
5
5
|
|
|
6
6
|
API Endpoints to retrieve recorded actions and resulting changes in the system. ### Documentation The user documentation with explanations how to use the api can be found [here](https://docs.stackit.cloud/stackit/en/retrieve-audit-log-per-api-request-134415907.html). ### Audit Logging Changes on organizations, folders and projects and respective cloud resources are logged and collected in the audit log. ### API Constraints The audit log API allows to download messages from the last 90 days. The maximum duration that can be queried at once is 24 hours. Requests are rate limited - the current maximum is 60 requests per minute.
|
|
7
7
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
# coding: utf-8
|
|
2
2
|
|
|
3
3
|
"""
|
|
4
|
-
Audit Log API
|
|
4
|
+
STACKIT Audit Log API
|
|
5
5
|
|
|
6
6
|
API Endpoints to retrieve recorded actions and resulting changes in the system. ### Documentation The user documentation with explanations how to use the api can be found [here](https://docs.stackit.cloud/stackit/en/retrieve-audit-log-per-api-request-134415907.html). ### Audit Logging Changes on organizations, folders and projects and respective cloud resources are logged and collected in the audit log. ### API Constraints The audit log API allows to download messages from the last 90 days. The maximum duration that can be queried at once is 24 hours. Requests are rate limited - the current maximum is 60 requests per minute.
|
|
7
7
|
|
|
@@ -15,6 +15,7 @@ from __future__ import annotations
|
|
|
15
15
|
|
|
16
16
|
import json
|
|
17
17
|
import pprint
|
|
18
|
+
import re # noqa: F401
|
|
18
19
|
from datetime import datetime
|
|
19
20
|
from typing import Any, ClassVar, Dict, List, Optional, Set
|
|
20
21
|
|
|
@@ -118,6 +119,19 @@ class AuditLogEntryResponse(BaseModel):
|
|
|
118
119
|
"visibility",
|
|
119
120
|
]
|
|
120
121
|
|
|
122
|
+
@field_validator("event_time_stamp", mode="before")
|
|
123
|
+
def event_time_stamp_change_year_zero_to_one(cls, value):
|
|
124
|
+
"""Workaround which prevents year 0 issue"""
|
|
125
|
+
if isinstance(value, str):
|
|
126
|
+
# Check for year "0000" at the beginning of the string
|
|
127
|
+
# This assumes common date formats like YYYY-MM-DDTHH:MM:SS+00:00 or YYYY-MM-DDTHH:MM:SSZ
|
|
128
|
+
if value.startswith("0000-01-01T") and re.match(
|
|
129
|
+
r"^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(\+\d{2}:\d{2}|Z)$", value
|
|
130
|
+
):
|
|
131
|
+
# Workaround: Replace "0000" with "0001"
|
|
132
|
+
return "0001" + value[4:] # Take "0001" and append the rest of the string
|
|
133
|
+
return value
|
|
134
|
+
|
|
121
135
|
@field_validator("event_type")
|
|
122
136
|
def event_type_validate_enum(cls, value):
|
|
123
137
|
"""Validates the enum"""
|
|
@@ -125,6 +139,19 @@ class AuditLogEntryResponse(BaseModel):
|
|
|
125
139
|
raise ValueError("must be one of enum values ('ADMIN_ACTIVITY', 'SYSTEM_EVENT', 'POLICY_DENIED')")
|
|
126
140
|
return value
|
|
127
141
|
|
|
142
|
+
@field_validator("received_time_stamp", mode="before")
|
|
143
|
+
def received_time_stamp_change_year_zero_to_one(cls, value):
|
|
144
|
+
"""Workaround which prevents year 0 issue"""
|
|
145
|
+
if isinstance(value, str):
|
|
146
|
+
# Check for year "0000" at the beginning of the string
|
|
147
|
+
# This assumes common date formats like YYYY-MM-DDTHH:MM:SS+00:00 or YYYY-MM-DDTHH:MM:SSZ
|
|
148
|
+
if value.startswith("0000-01-01T") and re.match(
|
|
149
|
+
r"^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(\+\d{2}:\d{2}|Z)$", value
|
|
150
|
+
):
|
|
151
|
+
# Workaround: Replace "0000" with "0001"
|
|
152
|
+
return "0001" + value[4:] # Take "0001" and append the rest of the string
|
|
153
|
+
return value
|
|
154
|
+
|
|
128
155
|
@field_validator("severity")
|
|
129
156
|
def severity_validate_enum(cls, value):
|
|
130
157
|
"""Validates the enum"""
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
# coding: utf-8
|
|
2
2
|
|
|
3
3
|
"""
|
|
4
|
-
Audit Log API
|
|
4
|
+
STACKIT Audit Log API
|
|
5
5
|
|
|
6
6
|
API Endpoints to retrieve recorded actions and resulting changes in the system. ### Documentation The user documentation with explanations how to use the api can be found [here](https://docs.stackit.cloud/stackit/en/retrieve-audit-log-per-api-request-134415907.html). ### Audit Logging Changes on organizations, folders and projects and respective cloud resources are logged and collected in the audit log. ### API Constraints The audit log API allows to download messages from the last 90 days. The maximum duration that can be queried at once is 24 hours. Requests are rate limited - the current maximum is 60 requests per minute.
|
|
7
7
|
|
|
@@ -75,9 +75,9 @@ class AuditLogEntryServiceAccountDelegationInfoResponse(BaseModel):
|
|
|
75
75
|
# override the default output from pydantic by calling `to_dict()` of each item in principals (list)
|
|
76
76
|
_items = []
|
|
77
77
|
if self.principals:
|
|
78
|
-
for
|
|
79
|
-
if
|
|
80
|
-
_items.append(
|
|
78
|
+
for _item_principals in self.principals:
|
|
79
|
+
if _item_principals:
|
|
80
|
+
_items.append(_item_principals.to_dict())
|
|
81
81
|
_dict["principals"] = _items
|
|
82
82
|
return _dict
|
|
83
83
|
|
{stackit_auditlog-0.1.0 → stackit_auditlog-0.1.2}/src/stackit/auditlog/models/error_response.py
RENAMED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
# coding: utf-8
|
|
2
2
|
|
|
3
3
|
"""
|
|
4
|
-
Audit Log API
|
|
4
|
+
STACKIT Audit Log API
|
|
5
5
|
|
|
6
6
|
API Endpoints to retrieve recorded actions and resulting changes in the system. ### Documentation The user documentation with explanations how to use the api can be found [here](https://docs.stackit.cloud/stackit/en/retrieve-audit-log-per-api-request-134415907.html). ### Audit Logging Changes on organizations, folders and projects and respective cloud resources are logged and collected in the audit log. ### API Constraints The audit log API allows to download messages from the last 90 days. The maximum duration that can be queried at once is 24 hours. Requests are rate limited - the current maximum is 60 requests per minute.
|
|
7
7
|
|
|
@@ -15,10 +15,19 @@ from __future__ import annotations
|
|
|
15
15
|
|
|
16
16
|
import json
|
|
17
17
|
import pprint
|
|
18
|
+
import re # noqa: F401
|
|
18
19
|
from datetime import datetime
|
|
19
20
|
from typing import Any, ClassVar, Dict, List, Optional, Set, Union
|
|
20
21
|
|
|
21
|
-
from pydantic import
|
|
22
|
+
from pydantic import (
|
|
23
|
+
BaseModel,
|
|
24
|
+
ConfigDict,
|
|
25
|
+
Field,
|
|
26
|
+
StrictFloat,
|
|
27
|
+
StrictInt,
|
|
28
|
+
StrictStr,
|
|
29
|
+
field_validator,
|
|
30
|
+
)
|
|
22
31
|
from typing_extensions import Self
|
|
23
32
|
|
|
24
33
|
|
|
@@ -33,6 +42,19 @@ class ErrorResponse(BaseModel):
|
|
|
33
42
|
timestamp: Optional[datetime] = Field(default=None, description="Timestamp at which the error occurred.")
|
|
34
43
|
__properties: ClassVar[List[str]] = ["message", "path", "status", "timestamp"]
|
|
35
44
|
|
|
45
|
+
@field_validator("timestamp", mode="before")
|
|
46
|
+
def timestamp_change_year_zero_to_one(cls, value):
|
|
47
|
+
"""Workaround which prevents year 0 issue"""
|
|
48
|
+
if isinstance(value, str):
|
|
49
|
+
# Check for year "0000" at the beginning of the string
|
|
50
|
+
# This assumes common date formats like YYYY-MM-DDTHH:MM:SS+00:00 or YYYY-MM-DDTHH:MM:SSZ
|
|
51
|
+
if value.startswith("0000-01-01T") and re.match(
|
|
52
|
+
r"^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(\+\d{2}:\d{2}|Z)$", value
|
|
53
|
+
):
|
|
54
|
+
# Workaround: Replace "0000" with "0001"
|
|
55
|
+
return "0001" + value[4:] # Take "0001" and append the rest of the string
|
|
56
|
+
return value
|
|
57
|
+
|
|
36
58
|
model_config = ConfigDict(
|
|
37
59
|
populate_by_name=True,
|
|
38
60
|
validate_assignment=True,
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
# coding: utf-8
|
|
2
2
|
|
|
3
3
|
"""
|
|
4
|
-
Audit Log API
|
|
4
|
+
STACKIT Audit Log API
|
|
5
5
|
|
|
6
6
|
API Endpoints to retrieve recorded actions and resulting changes in the system. ### Documentation The user documentation with explanations how to use the api can be found [here](https://docs.stackit.cloud/stackit/en/retrieve-audit-log-per-api-request-134415907.html). ### Audit Logging Changes on organizations, folders and projects and respective cloud resources are logged and collected in the audit log. ### API Constraints The audit log API allows to download messages from the last 90 days. The maximum duration that can be queried at once is 24 hours. Requests are rate limited - the current maximum is 60 requests per minute.
|
|
7
7
|
|
|
@@ -17,7 +17,14 @@ import json
|
|
|
17
17
|
import pprint
|
|
18
18
|
from typing import Any, ClassVar, Dict, List, Optional, Set, Union
|
|
19
19
|
|
|
20
|
-
from pydantic import
|
|
20
|
+
from pydantic import (
|
|
21
|
+
BaseModel,
|
|
22
|
+
ConfigDict,
|
|
23
|
+
Field,
|
|
24
|
+
StrictFloat,
|
|
25
|
+
StrictInt,
|
|
26
|
+
StrictStr,
|
|
27
|
+
)
|
|
21
28
|
from typing_extensions import Self
|
|
22
29
|
|
|
23
30
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
# coding: utf-8
|
|
2
2
|
|
|
3
3
|
"""
|
|
4
|
-
Audit Log API
|
|
4
|
+
STACKIT Audit Log API
|
|
5
5
|
|
|
6
6
|
API Endpoints to retrieve recorded actions and resulting changes in the system. ### Documentation The user documentation with explanations how to use the api can be found [here](https://docs.stackit.cloud/stackit/en/retrieve-audit-log-per-api-request-134415907.html). ### Audit Logging Changes on organizations, folders and projects and respective cloud resources are logged and collected in the audit log. ### API Constraints The audit log API allows to download messages from the last 90 days. The maximum duration that can be queried at once is 24 hours. Requests are rate limited - the current maximum is 60 requests per minute.
|
|
7
7
|
|
|
@@ -17,7 +17,14 @@ import json
|
|
|
17
17
|
import pprint
|
|
18
18
|
from typing import Any, ClassVar, Dict, List, Optional, Set, Union
|
|
19
19
|
|
|
20
|
-
from pydantic import
|
|
20
|
+
from pydantic import (
|
|
21
|
+
BaseModel,
|
|
22
|
+
ConfigDict,
|
|
23
|
+
Field,
|
|
24
|
+
StrictFloat,
|
|
25
|
+
StrictInt,
|
|
26
|
+
StrictStr,
|
|
27
|
+
)
|
|
21
28
|
from typing_extensions import Self
|
|
22
29
|
|
|
23
30
|
from stackit.auditlog.models.audit_log_entry_response import AuditLogEntryResponse
|
|
@@ -75,9 +82,9 @@ class ListAuditLogEntriesResponse(BaseModel):
|
|
|
75
82
|
# override the default output from pydantic by calling `to_dict()` of each item in items (list)
|
|
76
83
|
_items = []
|
|
77
84
|
if self.items:
|
|
78
|
-
for
|
|
79
|
-
if
|
|
80
|
-
_items.append(
|
|
85
|
+
for _item_items in self.items:
|
|
86
|
+
if _item_items:
|
|
87
|
+
_items.append(_item_items.to_dict())
|
|
81
88
|
_dict["items"] = _items
|
|
82
89
|
return _dict
|
|
83
90
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
# coding: utf-8
|
|
2
2
|
|
|
3
3
|
"""
|
|
4
|
-
Audit Log API
|
|
4
|
+
STACKIT Audit Log API
|
|
5
5
|
|
|
6
6
|
API Endpoints to retrieve recorded actions and resulting changes in the system. ### Documentation The user documentation with explanations how to use the api can be found [here](https://docs.stackit.cloud/stackit/en/retrieve-audit-log-per-api-request-134415907.html). ### Audit Logging Changes on organizations, folders and projects and respective cloud resources are logged and collected in the audit log. ### API Constraints The audit log API allows to download messages from the last 90 days. The maximum duration that can be queried at once is 24 hours. Requests are rate limited - the current maximum is 60 requests per minute.
|
|
7
7
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
# coding: utf-8
|
|
2
2
|
|
|
3
3
|
"""
|
|
4
|
-
Audit Log API
|
|
4
|
+
STACKIT Audit Log API
|
|
5
5
|
|
|
6
6
|
API Endpoints to retrieve recorded actions and resulting changes in the system. ### Documentation The user documentation with explanations how to use the api can be found [here](https://docs.stackit.cloud/stackit/en/retrieve-audit-log-per-api-request-134415907.html). ### Audit Logging Changes on organizations, folders and projects and respective cloud resources are logged and collected in the audit log. ### API Constraints The audit log API allows to download messages from the last 90 days. The maximum duration that can be queried at once is 24 hours. Requests are rate limited - the current maximum is 60 requests per minute.
|
|
7
7
|
|
|
@@ -38,12 +38,17 @@ class RESTResponse(io.IOBase):
|
|
|
38
38
|
self.data = self.response.content
|
|
39
39
|
return self.data
|
|
40
40
|
|
|
41
|
+
@property
|
|
42
|
+
def headers(self):
|
|
43
|
+
"""Returns a dictionary of response headers."""
|
|
44
|
+
return self.response.headers
|
|
45
|
+
|
|
41
46
|
def getheaders(self):
|
|
42
|
-
"""Returns a dictionary of the response headers."""
|
|
47
|
+
"""Returns a dictionary of the response headers; use ``headers`` instead."""
|
|
43
48
|
return self.response.headers
|
|
44
49
|
|
|
45
50
|
def getheader(self, name, default=None):
|
|
46
|
-
"""Returns a given response header."""
|
|
51
|
+
"""Returns a given response header; use ``headers.get()`` instead."""
|
|
47
52
|
return self.response.headers.get(name, default)
|
|
48
53
|
|
|
49
54
|
|
|
@@ -93,6 +98,7 @@ class RESTClientObject:
|
|
|
93
98
|
url,
|
|
94
99
|
data=request_body,
|
|
95
100
|
headers=headers,
|
|
101
|
+
timeout=_request_timeout,
|
|
96
102
|
)
|
|
97
103
|
elif content_type == "application/x-www-form-urlencoded":
|
|
98
104
|
r = self.session.request(
|
|
@@ -100,6 +106,7 @@ class RESTClientObject:
|
|
|
100
106
|
url,
|
|
101
107
|
params=post_params,
|
|
102
108
|
headers=headers,
|
|
109
|
+
timeout=_request_timeout,
|
|
103
110
|
)
|
|
104
111
|
elif content_type == "multipart/form-data":
|
|
105
112
|
# must del headers['Content-Type'], or the correct
|
|
@@ -113,6 +120,7 @@ class RESTClientObject:
|
|
|
113
120
|
url,
|
|
114
121
|
files=post_params,
|
|
115
122
|
headers=headers,
|
|
123
|
+
timeout=_request_timeout,
|
|
116
124
|
)
|
|
117
125
|
# Pass a `string` parameter directly in the body to support
|
|
118
126
|
# other content types than JSON when `body` argument is
|
|
@@ -123,10 +131,17 @@ class RESTClientObject:
|
|
|
123
131
|
url,
|
|
124
132
|
data=body,
|
|
125
133
|
headers=headers,
|
|
134
|
+
timeout=_request_timeout,
|
|
126
135
|
)
|
|
127
136
|
elif headers["Content-Type"].startswith("text/") and isinstance(body, bool):
|
|
128
137
|
request_body = "true" if body else "false"
|
|
129
|
-
r = self.session.request(
|
|
138
|
+
r = self.session.request(
|
|
139
|
+
method,
|
|
140
|
+
url,
|
|
141
|
+
data=request_body,
|
|
142
|
+
headers=headers,
|
|
143
|
+
timeout=_request_timeout,
|
|
144
|
+
)
|
|
130
145
|
else:
|
|
131
146
|
# Cannot generate the request from given parameters
|
|
132
147
|
msg = """Cannot prepare a request message for provided
|
|
@@ -140,6 +155,7 @@ class RESTClientObject:
|
|
|
140
155
|
url,
|
|
141
156
|
params={},
|
|
142
157
|
headers=headers,
|
|
158
|
+
timeout=_request_timeout,
|
|
143
159
|
)
|
|
144
160
|
except requests.exceptions.SSLError as e:
|
|
145
161
|
msg = "\n".join([type(e).__name__, str(e)])
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|