mirror of
				https://git.sr.ht/~tsileo/microblog.pub
				synced 2025-06-05 21:59:23 +02:00 
			
		
		
		
	Improve fetch
This commit is contained in:
		| @@ -61,6 +61,10 @@ class ObjectNotFoundError(Exception): | ||||
|     pass | ||||
|  | ||||
|  | ||||
| class ObjectUnavailableError(Exception): | ||||
|     pass | ||||
|  | ||||
|  | ||||
| class FetchErrorTypeEnum(str, enum.Enum): | ||||
|     TIMEOUT = "TIMEOUT" | ||||
|     NOT_FOUND = "NOT_FOUND" | ||||
| @@ -167,6 +171,8 @@ async def fetch( | ||||
|     # Special handling for deleted object | ||||
|     if resp.status_code == 410: | ||||
|         raise ObjectIsGoneError(f"{url} is gone") | ||||
|     elif resp.status_code in [401, 403]: | ||||
|         raise ObjectUnavailableError(f"not allowed to fetch {url}") | ||||
|     elif resp.status_code == 404: | ||||
|         raise ObjectNotFoundError(f"{url} not found") | ||||
|  | ||||
|   | ||||
| @@ -85,6 +85,8 @@ async def get_lookup( | ||||
|             error = ap.FetchErrorTypeEnum.TIMEOUT | ||||
|         except (ap.ObjectNotFoundError, ap.ObjectIsGoneError): | ||||
|             error = ap.FetchErrorTypeEnum.NOT_FOUND | ||||
|         except (ap.ObjectUnavailableError): | ||||
|             error = ap.FetchErrorTypeEnum.UNAUHTORIZED | ||||
|         except Exception: | ||||
|             logger.exception(f"Failed to lookup {query}") | ||||
|             error = ap.FetchErrorTypeEnum.INTERNAL_ERROR | ||||
|   | ||||
| @@ -115,11 +115,8 @@ async def _get_public_key(db_session: AsyncSession, key_id: str) -> Key: | ||||
|     # might race to fetch each other key | ||||
|     try: | ||||
|         actor = await ap.fetch(key_id, disable_httpsig=True) | ||||
|     except httpx.HTTPStatusError as http_err: | ||||
|         if http_err.response.status_code in [401, 403]: | ||||
|             actor = await ap.fetch(key_id, disable_httpsig=False) | ||||
|         else: | ||||
|             raise | ||||
|     except ap.ObjectUnavailableError: | ||||
|         actor = await ap.fetch(key_id, disable_httpsig=False) | ||||
|  | ||||
|     if actor["type"] == "Key": | ||||
|         # The Key is not embedded in the Person | ||||
|   | ||||
| @@ -20,6 +20,8 @@ | ||||
|     <div class="box error-box"> | ||||
|         {% if error.value == "NOT_FOUND" %} | ||||
|         <p>The remote object is unavailable.</p> | ||||
|         {% elif error.value == "UNAUTHORIZED" %} | ||||
|         <p>Missing permissions to fetch the remote object.</p> | ||||
|         {% elif error.value == "TIMEOUT" %} | ||||
|         <p>Lookup timed out, please try refreshing the page.</p> | ||||
|         {% else %} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user