Improve MatrixError.from_nio, use it for upload()
This commit is contained in:
		
							
								
								
									
										2
									
								
								TODO.md
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								TODO.md
									
									
									
									
									
								
							| @@ -15,7 +15,7 @@ | |||||||
|   - Video: missing buttons and small size problems |   - Video: missing buttons and small size problems | ||||||
|   - Audio: online playback is buggy, must download+play file |   - Audio: online playback is buggy, must download+play file | ||||||
|   - EventLink |   - EventLink | ||||||
|   - Downloading (right click on media > save as...) |   - EventFile & Downloading (right click on media > save as...) | ||||||
|  |  | ||||||
| - RoomMessageNotice | - RoomMessageNotice | ||||||
|  |  | ||||||
|   | |||||||
| @@ -36,7 +36,8 @@ CryptDict = Dict[str, Any] | |||||||
|  |  | ||||||
| @dataclass | @dataclass | ||||||
| class MatrixError(Exception): | class MatrixError(Exception): | ||||||
|     m_code: str = "M_UNKNOWN" |     http_code: int = 400 | ||||||
|  |     m_code:    str = "M_UNKNOWN" | ||||||
|  |  | ||||||
|     @classmethod |     @classmethod | ||||||
|     def from_nio(cls, response: nio.ErrorResponse) -> "MatrixError": |     def from_nio(cls, response: nio.ErrorResponse) -> "MatrixError": | ||||||
| @@ -44,17 +45,29 @@ class MatrixError(Exception): | |||||||
|             if subcls.m_code == response.status_code: |             if subcls.m_code == response.status_code: | ||||||
|                 return subcls() |                 return subcls() | ||||||
|  |  | ||||||
|         return cls(response.status_code) |         for subcls in cls.__subclasses__(): | ||||||
|  |             if subcls.http_code == response.transport_response.status: | ||||||
|  |                 return subcls() | ||||||
|  |  | ||||||
|  |         return cls(response.transport_response.status, response.status_code) | ||||||
| @dataclass |  | ||||||
| class MatrixNotFound(MatrixError): |  | ||||||
|     m_code: str = "M_NOT_FOUND" |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @dataclass | @dataclass | ||||||
| class MatrixForbidden(MatrixError): | class MatrixForbidden(MatrixError): | ||||||
|     m_code: str = "M_FORBIDDEN" |     http_code: int = 403 | ||||||
|  |     m_code:    str = "M_FORBIDDEN" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @dataclass | ||||||
|  | class MatrixNotFound(MatrixError): | ||||||
|  |     http_code: int = 404 | ||||||
|  |     m_code:    str = "M_NOT_FOUND" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @dataclass | ||||||
|  | class MatrixTooLarge(MatrixError): | ||||||
|  |     http_code: int = 413 | ||||||
|  |     m_code:    str = "M_TOO_LARGE" | ||||||
|  |  | ||||||
|  |  | ||||||
| @dataclass | @dataclass | ||||||
| @@ -66,19 +79,6 @@ class UserNotFound(Exception): | |||||||
| class InvalidUserInContext(Exception): | class InvalidUserInContext(Exception): | ||||||
|     user_id: str = field() |     user_id: str = field() | ||||||
|  |  | ||||||
| @dataclass |  | ||||||
| class UploadError(Exception): |  | ||||||
|     http_code: Optional[int] = None |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @dataclass |  | ||||||
| class UploadForbidden(UploadError): |  | ||||||
|     http_code: Optional[int] = 403 |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @dataclass |  | ||||||
| class UploadTooLarge(UploadError): |  | ||||||
|     http_code: Optional[int] = 413 |  | ||||||
|  |  | ||||||
| @dataclass | @dataclass | ||||||
| class UneededThumbnail(Exception): | class UneededThumbnail(Exception): | ||||||
| @@ -656,16 +656,10 @@ class MatrixClient(nio.AsyncClient): | |||||||
|                     ) -> str: |                     ) -> str: | ||||||
|         response = await super().upload(data, mime, filename) |         response = await super().upload(data, mime, filename) | ||||||
|  |  | ||||||
|         if not isinstance(response, nio.ErrorResponse): |         if isinstance(response, nio.UploadError): | ||||||
|             return response.content_uri |             raise MatrixError.from_nio(response) | ||||||
|  |  | ||||||
|         if response.status_code == 403: |         return response.content_uri | ||||||
|             raise UploadForbidden() |  | ||||||
|  |  | ||||||
|         if response.status_code == 413: |  | ||||||
|             raise UploadTooLarge() |  | ||||||
|  |  | ||||||
|         raise UploadError(response.status_code) |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     async def set_avatar_from_file(self, path: Union[Path, str]) -> None: |     async def set_avatar_from_file(self, path: Union[Path, str]) -> None: | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	