You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					166 lines
				
				4.6 KiB
			
		
		
			
		
	
	
					166 lines
				
				4.6 KiB
			| 
											6 years ago
										 | class OverPyException(BaseException):
 | ||
|  |     """OverPy base exception"""
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | 
 | ||
|  | class DataIncomplete(OverPyException):
 | ||
|  |     """
 | ||
|  |     Raised if the requested data isn't available in the result.
 | ||
|  |     Try to improve the query or to resolve the missing data.
 | ||
|  |     """
 | ||
|  |     def __init__(self, *args, **kwargs):
 | ||
|  |         OverPyException.__init__(
 | ||
|  |             self,
 | ||
|  |             "Data incomplete try to improve the query to resolve the missing data",
 | ||
|  |             *args,
 | ||
|  |             **kwargs
 | ||
|  |         )
 | ||
|  | 
 | ||
|  | 
 | ||
|  | class ElementDataWrongType(OverPyException):
 | ||
|  |     """
 | ||
|  |     Raised if the provided element does not match the expected type.
 | ||
|  | 
 | ||
|  |     :param type_expected: The expected element type
 | ||
|  |     :type type_expected: String
 | ||
|  |     :param type_provided: The provided element type
 | ||
|  |     :type type_provided: String|None
 | ||
|  |     """
 | ||
|  |     def __init__(self, type_expected, type_provided=None):
 | ||
|  |         self.type_expected = type_expected
 | ||
|  |         self.type_provided = type_provided
 | ||
|  | 
 | ||
|  |     def __str__(self):
 | ||
|  |         return "Type expected '%s' but '%s' provided" % (
 | ||
|  |             self.type_expected,
 | ||
|  |             str(self.type_provided)
 | ||
|  |         )
 | ||
|  | 
 | ||
|  | 
 | ||
|  | class MaxRetriesReached(OverPyException):
 | ||
|  |     """
 | ||
|  |     Raised if max retries reached and the Overpass server didn't respond with a result.
 | ||
|  |     """
 | ||
|  |     def __init__(self, retry_count, exceptions):
 | ||
|  |         self.exceptions = exceptions
 | ||
|  |         self.retry_count = retry_count
 | ||
|  | 
 | ||
|  |     def __str__(self):
 | ||
|  |         return "Unable get any result from the Overpass API server after %d retries." % self.retry_count
 | ||
|  | 
 | ||
|  | 
 | ||
|  | class OverpassBadRequest(OverPyException):
 | ||
|  |     """
 | ||
|  |     Raised if the Overpass API service returns a syntax error.
 | ||
|  | 
 | ||
|  |     :param query: The encoded query how it was send to the server
 | ||
|  |     :type query: Bytes
 | ||
|  |     :param msgs: List of error messages
 | ||
|  |     :type msgs: List
 | ||
|  |     """
 | ||
|  |     def __init__(self, query, msgs=None):
 | ||
|  |         self.query = query
 | ||
|  |         if msgs is None:
 | ||
|  |             msgs = []
 | ||
|  |         self.msgs = msgs
 | ||
|  | 
 | ||
|  |     def __str__(self):
 | ||
|  |         tmp_msgs = []
 | ||
|  |         for tmp_msg in self.msgs:
 | ||
|  |             if not isinstance(tmp_msg, str):
 | ||
|  |                 tmp_msg = str(tmp_msg)
 | ||
|  |             tmp_msgs.append(tmp_msg)
 | ||
|  | 
 | ||
|  |         return "\n".join(tmp_msgs)
 | ||
|  | 
 | ||
|  | 
 | ||
|  | class OverpassError(OverPyException):
 | ||
|  |     """
 | ||
|  |     Base exception to report errors if the response returns a remark tag or element.
 | ||
|  |     
 | ||
|  |     .. note::
 | ||
|  |         If you are not sure which of the subexceptions you should use, use this one and try to parse the message.
 | ||
|  | 
 | ||
|  |         For more information have a look at https://github.com/DinoTools/python-overpy/issues/62
 | ||
|  |     
 | ||
|  |     :param str msg: The message from the remark tag or element
 | ||
|  |     """
 | ||
|  |     def __init__(self, msg=None):
 | ||
|  |         #: The message from the remark tag or element
 | ||
|  |         self.msg = msg
 | ||
|  | 
 | ||
|  |     def __str__(self):
 | ||
|  |         if self.msg is None:
 | ||
|  |             return "No error message provided"
 | ||
|  |         if not isinstance(self.msg, str):
 | ||
|  |             return str(self.msg)
 | ||
|  |         return self.msg
 | ||
|  | 
 | ||
|  | 
 | ||
|  | class OverpassGatewayTimeout(OverPyException):
 | ||
|  |     """
 | ||
|  |     Raised if load of the Overpass API service is too high and it can't handle the request.
 | ||
|  |     """
 | ||
|  |     def __init__(self):
 | ||
|  |         OverPyException.__init__(self, "Server load too high")
 | ||
|  | 
 | ||
|  | 
 | ||
|  | class OverpassRuntimeError(OverpassError):
 | ||
|  |     """
 | ||
|  |     Raised if the server returns a remark-tag(xml) or remark element(json) with a message starting with
 | ||
|  |     'runtime error:'.
 | ||
|  |     """
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | 
 | ||
|  | class OverpassRuntimeRemark(OverpassError):
 | ||
|  |     """
 | ||
|  |     Raised if the server returns a remark-tag(xml) or remark element(json) with a message starting with
 | ||
|  |     'runtime remark:'.
 | ||
|  |     """
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | 
 | ||
|  | class OverpassTooManyRequests(OverPyException):
 | ||
|  |     """
 | ||
|  |     Raised if the Overpass API service returns a 429 status code.
 | ||
|  |     """
 | ||
|  |     def __init__(self):
 | ||
|  |         OverPyException.__init__(self, "Too many requests")
 | ||
|  | 
 | ||
|  | 
 | ||
|  | class OverpassUnknownContentType(OverPyException):
 | ||
|  |     """
 | ||
|  |     Raised if the reported content type isn't handled by OverPy.
 | ||
|  | 
 | ||
|  |     :param content_type: The reported content type
 | ||
|  |     :type content_type: None or String
 | ||
|  |     """
 | ||
|  |     def __init__(self, content_type):
 | ||
|  |         self.content_type = content_type
 | ||
|  | 
 | ||
|  |     def __str__(self):
 | ||
|  |         if self.content_type is None:
 | ||
|  |             return "No content type returned"
 | ||
|  |         return "Unknown content type: %s" % self.content_type
 | ||
|  | 
 | ||
|  | 
 | ||
|  | class OverpassUnknownError(OverpassError):
 | ||
|  |     """
 | ||
|  |     Raised if the server returns a remark-tag(xml) or remark element(json) and we are unable to find any reason.
 | ||
|  |     """
 | ||
|  |     pass
 | ||
|  | 
 | ||
|  | 
 | ||
|  | class OverpassUnknownHTTPStatusCode(OverPyException):
 | ||
|  |     """
 | ||
|  |     Raised if the returned HTTP status code isn't handled by OverPy.
 | ||
|  | 
 | ||
|  |     :param code: The HTTP status code
 | ||
|  |     :type code: Integer
 | ||
|  |     """
 | ||
|  |     def __init__(self, code):
 | ||
|  |         self.code = code
 | ||
|  | 
 | ||
|  |     def __str__(self):
 | ||
|  |         return "Unknown/Unhandled status code: %d" % self.code
 |