From 98e82b0b3dbc240be79dabfd9994c9b08a67cbdc Mon Sep 17 00:00:00 2001 From: Ondrej Pesek Date: Fri, 16 Aug 2024 14:14:36 +0200 Subject: [PATCH] support updating service's options --- geo/Geoserver.py | 43 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) diff --git a/geo/Geoserver.py b/geo/Geoserver.py index 905f7fe..b198c12 100644 --- a/geo/Geoserver.py +++ b/geo/Geoserver.py @@ -3141,3 +3141,46 @@ def delete_usergroup(self, group: str, service=None) -> str: return "Group deleted successfully" else: raise GeoserverException(r.status_code, r.content) + + # _______________________________________________________________________________________________ + # + # SERVICES + # _______________________________________________________________________________________________ + # + + def update_service(self, service: str, **kwargs): + """ + Update selected service's options. + + Parameters + ---------- + service : str + Type of service (e.g., wms, wfs) + kwargs : dict + Options to be modified (e.g., maxRenderingTime=600) + + Returns + ------- + str + A success message indicating that the options were updated. + + Raises + ------ + GeoserverException + If there is an issue updating the service's options. + """ + url = "{}/rest/services/{}/settings".format(self.service_url, service) + headers = {"content-type": "text/xml"} + + data = "" + for key, value in kwargs.items(): + data += "<{}><{}>{}".format( + service, key, value, key, service + ) + + r = self._requests("put", url, data=data, headers=headers) + + if r.status_code == 200: + return "Service's option updated successfully" + else: + raise GeoserverException(r.status_code, r.content)