Module geoengine.error
Package errors and backend mapped error types
Expand source code
'''
Package errors and backend mapped error types
'''
from typing import Any, Dict, Union
import json
import xml.etree.ElementTree as ET
from requests import Response, HTTPError
import geoengine_openapi_client
class GeoEngineException(Exception):
'''
Base class for exceptions from the backend
'''
error: str
message: str
def __init__(self, response: Union[geoengine_openapi_client.ApiException, Dict[str, str]]) -> None:
super().__init__()
if isinstance(response, geoengine_openapi_client.ApiException):
obj = json.loads(response.body)
else:
obj = response
self.error = obj['error'] if 'error' in obj else '?'
self.message = obj['message'] if 'message' in obj else '?'
def __str__(self) -> str:
return f"{self.error}: {self.message}"
class InputException(Exception):
'''
Exception that is thrown on wrong inputs
'''
__message: str
def __init__(self, message: str) -> None:
super().__init__()
self.__message = message
def __str__(self) -> str:
return f"{self.__message}"
class UninitializedException(Exception):
'''
Exception that is thrown when there is no connection to the backend but methods on the backend are called
'''
def __str__(self) -> str:
return "You have to call `initialize` before using other functionality"
class TypeException(Exception):
'''
Exception on wrong types of input
'''
__message: str
def __init__(self, message: str) -> None:
super().__init__()
self.__message = message
def __str__(self) -> str:
return f"{self.__message}"
class ModificationNotOnLayerDbException(Exception):
'''
Exception that is when trying to modify layers that are not part of the layerdb
'''
__message: str
def __init__(self, message: str) -> None:
super().__init__()
self.__message = message
def __str__(self) -> str:
return f"{self.__message}"
# TODO: remove methods and forbid calling methods in the first place
class MethodNotCalledOnRasterException(Exception):
'''
Exception for calling a raster method on a, e.g., vector layer
'''
def __str__(self) -> str:
return "Only allowed to call method on raster result"
# TODO: remove methods and forbid calling methods in the first place
class MethodNotCalledOnVectorException(Exception):
'''
Exception for calling a vector method on a, e.g., raster layer
'''
def __str__(self) -> str:
return "Only allowed to call method on vector result"
# TODO: remove methods and forbid calling methods in the first place
class MethodNotCalledOnPlotException(Exception):
'''
Exception for calling a plot method on a, e.g., vector layer
'''
def __str__(self) -> str:
return "Only allowed to call method on plot result"
class SpatialReferenceMismatchException(Exception):
'''
Exception for calling a method on a workflow with a query rectangle that has a different spatial reference
'''
def __init__(self, spatial_reference_a: str, spatial_reference_b: str) -> None:
super().__init__()
self.__spatial_reference_a = spatial_reference_a
self.__spatial_reference_b = spatial_reference_b
def __str__(self) -> str:
return f"Spatial reference mismatch {self.__spatial_reference_a} != {self.__spatial_reference_b}"
class InvalidUrlException(Exception):
'''
Exception for when no valid url is provided
'''
def __init__(self, msg: str) -> None:
super().__init__()
self.__msg = msg
def __str__(self) -> str:
return f"{self.__msg}"
class MissingFieldInResponseException(Exception):
'''
Exception for when a field is missing in a response
'''
missing_field: str
response: Any
def __init__(self, missing_field: str, response: Any) -> None:
super().__init__()
self.missing_field = missing_field
self.response = response
def __str__(self) -> str:
return f"Missing field '{self.missing_field}' in response: {self.response}"
def check_response_for_error(response: Response) -> None:
'''
Checks a `Response` for an error and raises it if there is one.
'''
try:
response.raise_for_status()
return # no error
except HTTPError as http_error:
exception = http_error
# try to parse it as a Geo Engine error
try:
response_json = response.json()
except Exception: # pylint: disable=broad-except
pass # ignore errors, it seemed not to be JSON
else:
# if parsing was successful, raise the appropriate exception
if 'error' in response_json:
raise GeoEngineException(response_json)
# raise `HTTPError` if `GeoEngineException` or any other was not thrown
raise exception
class MethodOnlyAvailableInGeoEnginePro(Exception):
'''
Exception when trying to use a method that is only available in Geo Engine Pro
'''
__message: str
def __init__(self, message: str) -> None:
super().__init__()
self.__message = message
def __str__(self) -> str:
return f"Method is only available in Geo Engine Pro: {self.__message}"
class OGCXMLError(Exception):
'''
Exception when an OGC XML error is returned
'''
__xml: ET.Element
def __init__(self, xml: bytearray) -> None:
super().__init__()
self.__xml = ET.fromstring(xml[1:])
def __str__(self) -> str:
service_exception = ''
for e in self.__xml:
if 'ServiceException' in e.tag and e.text is not None:
service_exception = e.text
break
return f'OGC API error: {service_exception}'
@classmethod
def is_ogc_error(cls, xml: bytearray) -> bool:
return xml.startswith(b"\n<?xml")
Functions
def check_response_for_error(response: requests.models.Response) ‑> None
-
Checks a
Response
for an error and raises it if there is one.Expand source code
def check_response_for_error(response: Response) -> None: ''' Checks a `Response` for an error and raises it if there is one. ''' try: response.raise_for_status() return # no error except HTTPError as http_error: exception = http_error # try to parse it as a Geo Engine error try: response_json = response.json() except Exception: # pylint: disable=broad-except pass # ignore errors, it seemed not to be JSON else: # if parsing was successful, raise the appropriate exception if 'error' in response_json: raise GeoEngineException(response_json) # raise `HTTPError` if `GeoEngineException` or any other was not thrown raise exception
Classes
class GeoEngineException (response: Union[geoengine_openapi_client.exceptions.ApiException, Dict[str, str]])
-
Base class for exceptions from the backend
Expand source code
class GeoEngineException(Exception): ''' Base class for exceptions from the backend ''' error: str message: str def __init__(self, response: Union[geoengine_openapi_client.ApiException, Dict[str, str]]) -> None: super().__init__() if isinstance(response, geoengine_openapi_client.ApiException): obj = json.loads(response.body) else: obj = response self.error = obj['error'] if 'error' in obj else '?' self.message = obj['message'] if 'message' in obj else '?' def __str__(self) -> str: return f"{self.error}: {self.message}"
Ancestors
- builtins.Exception
- builtins.BaseException
Class variables
var error : str
var message : str
class InputException (message: str)
-
Exception that is thrown on wrong inputs
Expand source code
class InputException(Exception): ''' Exception that is thrown on wrong inputs ''' __message: str def __init__(self, message: str) -> None: super().__init__() self.__message = message def __str__(self) -> str: return f"{self.__message}"
Ancestors
- builtins.Exception
- builtins.BaseException
class InvalidUrlException (msg: str)
-
Exception for when no valid url is provided
Expand source code
class InvalidUrlException(Exception): ''' Exception for when no valid url is provided ''' def __init__(self, msg: str) -> None: super().__init__() self.__msg = msg def __str__(self) -> str: return f"{self.__msg}"
Ancestors
- builtins.Exception
- builtins.BaseException
class MethodNotCalledOnPlotException (*args, **kwargs)
-
Exception for calling a plot method on a, e.g., vector layer
Expand source code
class MethodNotCalledOnPlotException(Exception): ''' Exception for calling a plot method on a, e.g., vector layer ''' def __str__(self) -> str: return "Only allowed to call method on plot result"
Ancestors
- builtins.Exception
- builtins.BaseException
class MethodNotCalledOnRasterException (*args, **kwargs)
-
Exception for calling a raster method on a, e.g., vector layer
Expand source code
class MethodNotCalledOnRasterException(Exception): ''' Exception for calling a raster method on a, e.g., vector layer ''' def __str__(self) -> str: return "Only allowed to call method on raster result"
Ancestors
- builtins.Exception
- builtins.BaseException
class MethodNotCalledOnVectorException (*args, **kwargs)
-
Exception for calling a vector method on a, e.g., raster layer
Expand source code
class MethodNotCalledOnVectorException(Exception): ''' Exception for calling a vector method on a, e.g., raster layer ''' def __str__(self) -> str: return "Only allowed to call method on vector result"
Ancestors
- builtins.Exception
- builtins.BaseException
class MethodOnlyAvailableInGeoEnginePro (message: str)
-
Exception when trying to use a method that is only available in Geo Engine Pro
Expand source code
class MethodOnlyAvailableInGeoEnginePro(Exception): ''' Exception when trying to use a method that is only available in Geo Engine Pro ''' __message: str def __init__(self, message: str) -> None: super().__init__() self.__message = message def __str__(self) -> str: return f"Method is only available in Geo Engine Pro: {self.__message}"
Ancestors
- builtins.Exception
- builtins.BaseException
class MissingFieldInResponseException (missing_field: str, response: Any)
-
Exception for when a field is missing in a response
Expand source code
class MissingFieldInResponseException(Exception): ''' Exception for when a field is missing in a response ''' missing_field: str response: Any def __init__(self, missing_field: str, response: Any) -> None: super().__init__() self.missing_field = missing_field self.response = response def __str__(self) -> str: return f"Missing field '{self.missing_field}' in response: {self.response}"
Ancestors
- builtins.Exception
- builtins.BaseException
Class variables
var missing_field : str
var response : Any
class ModificationNotOnLayerDbException (message: str)
-
Exception that is when trying to modify layers that are not part of the layerdb
Expand source code
class ModificationNotOnLayerDbException(Exception): ''' Exception that is when trying to modify layers that are not part of the layerdb ''' __message: str def __init__(self, message: str) -> None: super().__init__() self.__message = message def __str__(self) -> str: return f"{self.__message}"
Ancestors
- builtins.Exception
- builtins.BaseException
class OGCXMLError (xml: bytearray)
-
Exception when an OGC XML error is returned
Expand source code
class OGCXMLError(Exception): ''' Exception when an OGC XML error is returned ''' __xml: ET.Element def __init__(self, xml: bytearray) -> None: super().__init__() self.__xml = ET.fromstring(xml[1:]) def __str__(self) -> str: service_exception = '' for e in self.__xml: if 'ServiceException' in e.tag and e.text is not None: service_exception = e.text break return f'OGC API error: {service_exception}' @classmethod def is_ogc_error(cls, xml: bytearray) -> bool: return xml.startswith(b"\n<?xml")
Ancestors
- builtins.Exception
- builtins.BaseException
Static methods
def is_ogc_error(xml: bytearray) ‑> bool
-
Expand source code
@classmethod def is_ogc_error(cls, xml: bytearray) -> bool: return xml.startswith(b"\n<?xml")
class SpatialReferenceMismatchException (spatial_reference_a: str, spatial_reference_b: str)
-
Exception for calling a method on a workflow with a query rectangle that has a different spatial reference
Expand source code
class SpatialReferenceMismatchException(Exception): ''' Exception for calling a method on a workflow with a query rectangle that has a different spatial reference ''' def __init__(self, spatial_reference_a: str, spatial_reference_b: str) -> None: super().__init__() self.__spatial_reference_a = spatial_reference_a self.__spatial_reference_b = spatial_reference_b def __str__(self) -> str: return f"Spatial reference mismatch {self.__spatial_reference_a} != {self.__spatial_reference_b}"
Ancestors
- builtins.Exception
- builtins.BaseException
class TypeException (message: str)
-
Exception on wrong types of input
Expand source code
class TypeException(Exception): ''' Exception on wrong types of input ''' __message: str def __init__(self, message: str) -> None: super().__init__() self.__message = message def __str__(self) -> str: return f"{self.__message}"
Ancestors
- builtins.Exception
- builtins.BaseException
class UninitializedException (*args, **kwargs)
-
Exception that is thrown when there is no connection to the backend but methods on the backend are called
Expand source code
class UninitializedException(Exception): ''' Exception that is thrown when there is no connection to the backend but methods on the backend are called ''' def __str__(self) -> str: return "You have to call `initialize` before using other functionality"
Ancestors
- builtins.Exception
- builtins.BaseException