Skip to content

Commit 3d920e9

Browse files
Generator: Update SDK /services/observability (#3447)
* Generate observability * chore(observability) write changelog, bump version --------- Co-authored-by: cgoetz-inovex <carlo.goetz@inovex.de>
1 parent 3e2fed3 commit 3d920e9

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

53 files changed

+293
-255
lines changed

CHANGELOG.md

Lines changed: 52 additions & 48 deletions
Original file line numberDiff line numberDiff line change
@@ -71,54 +71,58 @@
7171
- `sqlserverflex`: [v1.1.2](services/sqlserverflex/CHANGELOG.md#v112)
7272
- **Feature:** client now supports UUID and decimal types
7373
- **Bugfix:** timeouts now passed to requests library
74-
- `observability`: [v0.13.0](services/observability/CHANGELOG.md#v0130)
75-
- **Feature:** manage alert records
76-
- New API client methods: `create_alert_record`, `delete_alert_record`, `delete_alert_records`, `get_alert_record`, `list_alert_records`, `update_alert_record`, `partial_update_alert_records`
77-
- New model classes: `AlertRecord`, `AlertRecordResponse`, `AlertRecordsResponse`, `CreateAlertRecordPayload`, `UpdateAlertRecordPayload`, `PartialUpdateAlertRecordsRequestInner`
78-
- **Feature:** manage alert rules
79-
- New API client methods: `get_alertrule`, `update_alertrule`, `delete_alertrule`
80-
- New model classes: `AlertRuleResponse`, `UpdateAlertrulePayload`
81-
- **Feature:** manage backups
82-
- New API client methods: `create_backup`,`create_backup_schedule`, `list_backup_retentions`, `list_backup_schedules`, `list_backups`, `restore_backup`
83-
- New model classes: `BackupResponse`, `BackupRetentionResponse`, `BackupSchedule`, `BackupSchedulePostResponse`, `BackupScheduleResponse`, `CreateBackupSchedulePayload`
84-
- **Feature:** to manage checks
85-
- MongoDB
86-
- New API client methods: `create_mongodb_check`, `delete_mongodb_check`, `list_mongodb_checks`
87-
- New model classes: `CreateMongodbCheckPayload`, `MongodbCheckChildResponse`, `MongodbCheckResponse`
88-
- RabbitMQ
89-
- New API client methods: `create_rabbitmq_check`, `delete_rabbitmq_check`, `list_rabbitmq_checks`
90-
- New model classes: `CreateRabbitmqCheckPayload`, `RabbitMQCheckChildResponse`, `RabbitmqCheckResponse`
91-
- Network
92-
- New API client methods: `list_network_checks`, `delete_network_check`, `create_network_check`
93-
- New model classes: `CreateNetworkCheckPayload`, `NetworkCheckChildResponse`, `NetworkCheckResponse`
94-
- Redis
95-
- New API client methods: `create_redis_check`, `list_redis_checks`, `delete_redis_check`
96-
- New model classes: `CreateRedisCheckPayload`, `RedisCheckChildResponse`, `RedisCheckResponse`
97-
- MySQL
98-
- New API client methods: `create_mysql_check`, `delete_mysql_check`, `list_mysql_checks`
99-
- New model classes: `CreateMysqlCheckPayload`, `MysqlCheckChildResponse`, `MysqlCheckResponse`
100-
- Ping
101-
- New API client methods: `create_ping_check`, `delete_ping_check`, `list_ping_checks`
102-
- New model classes: `CreatePingCheckPayload`, `PingCheckChildResponse`, `PingCheckResponse`
103-
- Elasticsearch
104-
- New API client methods: `create_elasticsearch_check`, `delete_elasticsearch_check`, `list_elasticsearch_checks`
105-
- New model classes: `CreateElasticsearchCheckPayload`, `ElasticsearchCheckChildResponse`, `ElasticsearchCheckResponse`
106-
- PostgreSQL
107-
- New API client methods: `create_postgresql_check`, `delete_postgresql_check`, `list_postgresql_checks`
108-
- New model classes: `CreatePostgresqlCheckPayload`, `PostgresqlCheckChildResponse`, `PostgresqlCheckResponse`
109-
- **Feature:** List offerings
110-
- New API client method: `list_offerings`
111-
- New model struct: `Offerings`
112-
- **Feature:** Manage scrape configs
113-
- New API client method: `delete_scrape_configs`, `partial_update_scrape_configs`
114-
- New model struct: `PartialUpdateScrapeConfigsRequestInner`
115-
- **Breaking changes**:
116-
- rename `CreateScrapeConfigPayloadBasicAuth` to `PartialUpdateScrapeConfigsRequestInnerBasicAuth`
117-
- rename `CreateScrapeConfigPayloadHttpSdConfigsInner` to `PartialUpdateScrapeConfigsRequestInnerHttpSdConfigsInner`
118-
- rename `CreateScrapeConfigPayloadHttpSdConfigsInnerOauth2` to `PartialUpdateScrapeConfigsRequestInnerHttpSdConfigsInnerOauth2`
119-
- rename `CreateScrapeConfigPayloadHttpSdConfigsInnerOauth2TlsConfig` to `PartialUpdateScrapeConfigsRequestInnerHttpSdConfigsInnerOauth2TlsConfig`
120-
- rename `CreateScrapeConfigPayloadMetricsRelabelConfigsInner` to `PartialUpdateScrapeConfigsRequestInnerMetricsRelabelConfigsInner`
121-
- rename `CreateScrapeConfigPayloadStaticConfigsInner` to `PartialUpdateScrapeConfigsRequestInnerStaticConfigsInner`
74+
- `observability`:
75+
- [v0.13.1](services/observability/CHANGELOG.md#v0131)
76+
- **Feature:** client now supports UUID and decimal types
77+
- **Bugfix:** timeouts now passed to requests library
78+
- [v0.13.0](services/observability/CHANGELOG.md#v0130)
79+
- **Feature:** manage alert records
80+
- New API client methods: `create_alert_record`, `delete_alert_record`, `delete_alert_records`, `get_alert_record`, `list_alert_records`, `update_alert_record`, `partial_update_alert_records`
81+
- New model classes: `AlertRecord`, `AlertRecordResponse`, `AlertRecordsResponse`, `CreateAlertRecordPayload`, `UpdateAlertRecordPayload`, `PartialUpdateAlertRecordsRequestInner`
82+
- **Feature:** manage alert rules
83+
- New API client methods: `get_alertrule`, `update_alertrule`, `delete_alertrule`
84+
- New model classes: `AlertRuleResponse`, `UpdateAlertrulePayload`
85+
- **Feature:** manage backups
86+
- New API client methods: `create_backup`,`create_backup_schedule`, `list_backup_retentions`, `list_backup_schedules`, `list_backups`, `restore_backup`
87+
- New model classes: `BackupResponse`, `BackupRetentionResponse`, `BackupSchedule`, `BackupSchedulePostResponse`, `BackupScheduleResponse`, `CreateBackupSchedulePayload`
88+
- **Feature:** to manage checks
89+
- MongoDB
90+
- New API client methods: `create_mongodb_check`, `delete_mongodb_check`, `list_mongodb_checks`
91+
- New model classes: `CreateMongodbCheckPayload`, `MongodbCheckChildResponse`, `MongodbCheckResponse`
92+
- RabbitMQ
93+
- New API client methods: `create_rabbitmq_check`, `delete_rabbitmq_check`, `list_rabbitmq_checks`
94+
- New model classes: `CreateRabbitmqCheckPayload`, `RabbitMQCheckChildResponse`, `RabbitmqCheckResponse`
95+
- Network
96+
- New API client methods: `list_network_checks`, `delete_network_check`, `create_network_check`
97+
- New model classes: `CreateNetworkCheckPayload`, `NetworkCheckChildResponse`, `NetworkCheckResponse`
98+
- Redis
99+
- New API client methods: `create_redis_check`, `list_redis_checks`, `delete_redis_check`
100+
- New model classes: `CreateRedisCheckPayload`, `RedisCheckChildResponse`, `RedisCheckResponse`
101+
- MySQL
102+
- New API client methods: `create_mysql_check`, `delete_mysql_check`, `list_mysql_checks`
103+
- New model classes: `CreateMysqlCheckPayload`, `MysqlCheckChildResponse`, `MysqlCheckResponse`
104+
- Ping
105+
- New API client methods: `create_ping_check`, `delete_ping_check`, `list_ping_checks`
106+
- New model classes: `CreatePingCheckPayload`, `PingCheckChildResponse`, `PingCheckResponse`
107+
- Elasticsearch
108+
- New API client methods: `create_elasticsearch_check`, `delete_elasticsearch_check`, `list_elasticsearch_checks`
109+
- New model classes: `CreateElasticsearchCheckPayload`, `ElasticsearchCheckChildResponse`, `ElasticsearchCheckResponse`
110+
- PostgreSQL
111+
- New API client methods: `create_postgresql_check`, `delete_postgresql_check`, `list_postgresql_checks`
112+
- New model classes: `CreatePostgresqlCheckPayload`, `PostgresqlCheckChildResponse`, `PostgresqlCheckResponse`
113+
- **Feature:** List offerings
114+
- New API client method: `list_offerings`
115+
- New model struct: `Offerings`
116+
- **Feature:** Manage scrape configs
117+
- New API client method: `delete_scrape_configs`, `partial_update_scrape_configs`
118+
- New model struct: `PartialUpdateScrapeConfigsRequestInner`
119+
- **Breaking changes**:
120+
- rename `CreateScrapeConfigPayloadBasicAuth` to `PartialUpdateScrapeConfigsRequestInnerBasicAuth`
121+
- rename `CreateScrapeConfigPayloadHttpSdConfigsInner` to `PartialUpdateScrapeConfigsRequestInnerHttpSdConfigsInner`
122+
- rename `CreateScrapeConfigPayloadHttpSdConfigsInnerOauth2` to `PartialUpdateScrapeConfigsRequestInnerHttpSdConfigsInnerOauth2`
123+
- rename `CreateScrapeConfigPayloadHttpSdConfigsInnerOauth2TlsConfig` to `PartialUpdateScrapeConfigsRequestInnerHttpSdConfigsInnerOauth2TlsConfig`
124+
- rename `CreateScrapeConfigPayloadMetricsRelabelConfigsInner` to `PartialUpdateScrapeConfigsRequestInnerMetricsRelabelConfigsInner`
125+
- rename `CreateScrapeConfigPayloadStaticConfigsInner` to `PartialUpdateScrapeConfigsRequestInnerStaticConfigsInner`
122126

123127
## Release (2026-02-18)
124128

services/observability/CHANGELOG.md

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,7 @@
1+
## v0.13.1
2+
- **Feature:** client now supports UUID and decimal types
3+
- **Bugfix:** timeouts now passed to requests library
4+
15
## v0.13.0
26
- **Feature:** manage alert records
37
- New API client methods: `create_alert_record`, `delete_alert_record`, `delete_alert_records`, `get_alert_record`, `list_alert_records`, `update_alert_record`, `partial_update_alert_records`

services/observability/oas_commit

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1 +1 @@
1-
10774896634990c655a523f5f0fabd6e2be9e216
1+
0e64886dd0847341800d7191ed193b75413be998

services/observability/pyproject.toml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
[project]
22
name = "stackit-observability"
3-
version = "v0.13.0"
3+
version = "v0.13.1"
44
description = "STACKIT Observability API"
55
authors = [{ name = "STACKIT Developer Tools", email = "developer-tools@stackit.cloud" }]
66
requires-python = ">=3.9,<4.0"

services/observability/src/stackit/observability/api_client.py

Lines changed: 22 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -13,11 +13,13 @@
1313
""" # noqa: E501
1414

1515
import datetime
16+
import decimal
1617
import json
1718
import mimetypes
1819
import os
1920
import re
2021
import tempfile
22+
import uuid
2123
from enum import Enum
2224
from typing import Dict, List, Optional, Tuple, Union
2325
from urllib.parse import quote
@@ -64,8 +66,10 @@ class ApiClient:
6466
"bool": bool,
6567
"date": datetime.date,
6668
"datetime": datetime.datetime,
69+
"decimal": decimal.Decimal,
6770
"object": object,
6871
}
72+
_pool = None
6973

7074
def __init__(self, configuration, header_name=None, header_value=None, cookie=None) -> None:
7175
self.config: Configuration = configuration
@@ -268,7 +272,7 @@ def response_deserialize(
268272
return_data = self.__deserialize_file(response_data)
269273
elif response_type is not None:
270274
match = None
271-
content_type = response_data.getheader("content-type")
275+
content_type = response_data.headers.get("content-type")
272276
if content_type is not None:
273277
match = re.search(r"charset=([a-zA-Z\-\d]+)[\s;]?", content_type)
274278
encoding = match.group(1) if match else "utf-8"
@@ -285,7 +289,7 @@ def response_deserialize(
285289
return ApiResponse(
286290
status_code=response_data.status,
287291
data=return_data,
288-
headers=response_data.getheaders(),
292+
headers=response_data.headers,
289293
raw_data=response_data.data,
290294
)
291295

@@ -297,6 +301,7 @@ def sanitize_for_serialization(self, obj):
297301
If obj is str, int, long, float, bool, return directly.
298302
If obj is datetime.datetime, datetime.date
299303
convert to string in iso8601 format.
304+
If obj is decimal.Decimal return string representation.
300305
If obj is list, sanitize each element in the list.
301306
If obj is dict, return the dict.
302307
If obj is OpenAPI model, return the properties dict.
@@ -312,12 +317,16 @@ def sanitize_for_serialization(self, obj):
312317
return obj.get_secret_value()
313318
elif isinstance(obj, self.PRIMITIVE_TYPES):
314319
return obj
320+
elif isinstance(obj, uuid.UUID):
321+
return str(obj)
315322
elif isinstance(obj, list):
316323
return [self.sanitize_for_serialization(sub_obj) for sub_obj in obj]
317324
elif isinstance(obj, tuple):
318325
return tuple(self.sanitize_for_serialization(sub_obj) for sub_obj in obj)
319326
elif isinstance(obj, (datetime.datetime, datetime.date)):
320327
return obj.isoformat()
328+
elif isinstance(obj, decimal.Decimal):
329+
return str(obj)
321330

322331
elif isinstance(obj, dict):
323332
obj_dict = obj
@@ -327,7 +336,7 @@ def sanitize_for_serialization(self, obj):
327336
# and attributes which value is not None.
328337
# Convert attribute name to json key in
329338
# model definition for request.
330-
if hasattr(obj, "to_dict") and callable(obj.to_dict):
339+
if hasattr(obj, "to_dict") and callable(getattr(obj, "to_dict")): # noqa: B009
331340
obj_dict = obj.to_dict()
332341
else:
333342
obj_dict = obj.__dict__
@@ -355,7 +364,7 @@ def deserialize(self, response_text: str, response_type: str, content_type: Opti
355364
data = json.loads(response_text)
356365
except ValueError:
357366
data = response_text
358-
elif re.match(r"^application/(json|[\w!#$&.+-^_]+\+json)\s*(;|$)", content_type, re.IGNORECASE):
367+
elif re.match(r"^application/(json|[\w!#$&.+\-^_]+\+json)\s*(;|$)", content_type, re.IGNORECASE):
359368
if response_text == "":
360369
data = ""
361370
else:
@@ -401,12 +410,14 @@ def __deserialize(self, data, klass):
401410

402411
if klass in self.PRIMITIVE_TYPES:
403412
return self.__deserialize_primitive(data, klass)
404-
elif klass == object:
413+
elif klass is object:
405414
return self.__deserialize_object(data)
406-
elif klass == datetime.date:
415+
elif klass is datetime.date:
407416
return self.__deserialize_date(data)
408-
elif klass == datetime.datetime:
417+
elif klass is datetime.datetime:
409418
return self.__deserialize_datetime(data)
419+
elif klass is decimal.Decimal:
420+
return decimal.Decimal(data)
410421
elif issubclass(klass, Enum):
411422
return self.__deserialize_enum(data, klass)
412423
else:
@@ -554,12 +565,14 @@ def __deserialize_file(self, response):
554565
os.close(fd)
555566
os.remove(path)
556567

557-
content_disposition = response.getheader("Content-Disposition")
568+
content_disposition = response.headers.get("Content-Disposition")
558569
if content_disposition:
559570
m = re.search(r'filename=[\'"]?([^\'"\s]+)[\'"]?', content_disposition)
560571
if m is None:
561572
raise ValueError("Unexpected 'content-disposition' header value")
562-
filename = m.group(1)
573+
filename = os.path.basename(m.group(1)) # Strip any directory traversal
574+
if filename in ("", ".", ".."): # fall back to tmp filename
575+
filename = os.path.basename(path)
563576
path = os.path.join(os.path.dirname(path), filename)
564577

565578
with open(path, "wb") as f:

services/observability/src/stackit/observability/exceptions.py

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -130,7 +130,7 @@ def __init__(
130130
self.body = http_resp.data.decode("utf-8")
131131
except Exception: # noqa: S110
132132
pass
133-
self.headers = http_resp.getheaders()
133+
self.headers = http_resp.headers
134134

135135
@classmethod
136136
def from_response(

services/observability/src/stackit/observability/models/__init__.py

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,6 @@
1313
Do not edit the class manually.
1414
""" # noqa: E501
1515

16-
1716
# import models into model package
1817
from stackit.observability.models.alert import Alert
1918
from stackit.observability.models.alert_config_receivers_response import (

services/observability/src/stackit/observability/models/alert.py

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -81,16 +81,16 @@ def to_dict(self) -> Dict[str, Any]:
8181
# override the default output from pydantic by calling `to_dict()` of each item in inhibit_rules (list)
8282
_items = []
8383
if self.inhibit_rules:
84-
for _item in self.inhibit_rules:
85-
if _item:
86-
_items.append(_item.to_dict())
84+
for _item_inhibit_rules in self.inhibit_rules:
85+
if _item_inhibit_rules:
86+
_items.append(_item_inhibit_rules.to_dict())
8787
_dict["inhibitRules"] = _items
8888
# override the default output from pydantic by calling `to_dict()` of each item in receivers (list)
8989
_items = []
9090
if self.receivers:
91-
for _item in self.receivers:
92-
if _item:
93-
_items.append(_item.to_dict())
91+
for _item_receivers in self.receivers:
92+
if _item_receivers:
93+
_items.append(_item_receivers.to_dict())
9494
_dict["receivers"] = _items
9595
# override the default output from pydantic by calling `to_dict()` of route
9696
if self.route:

services/observability/src/stackit/observability/models/alert_config_receivers_response.py

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -73,9 +73,9 @@ def to_dict(self) -> Dict[str, Any]:
7373
# override the default output from pydantic by calling `to_dict()` of each item in data (list)
7474
_items = []
7575
if self.data:
76-
for _item in self.data:
77-
if _item:
78-
_items.append(_item.to_dict())
76+
for _item_data in self.data:
77+
if _item_data:
78+
_items.append(_item_data.to_dict())
7979
_dict["data"] = _items
8080
return _dict
8181

services/observability/src/stackit/observability/models/alert_group.py

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -74,9 +74,9 @@ def to_dict(self) -> Dict[str, Any]:
7474
# override the default output from pydantic by calling `to_dict()` of each item in rules (list)
7575
_items = []
7676
if self.rules:
77-
for _item in self.rules:
78-
if _item:
79-
_items.append(_item.to_dict())
77+
for _item_rules in self.rules:
78+
if _item_rules:
79+
_items.append(_item_rules.to_dict())
8080
_dict["rules"] = _items
8181
return _dict
8282

0 commit comments

Comments
 (0)