mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-10-25 02:34:51 +00:00 
			
		
		
		
	handle errors in mastodon search endpoints
This commit is contained in:
		
							parent
							
								
									971bc6fd3e
								
							
						
					
					
						commit
						1fa290c3eb
					
				
					 1 changed files with 33 additions and 0 deletions
				
			
		|  | @ -8,6 +8,7 @@ import { MastodonClientService } from '@/server/api/mastodon/MastodonClientServi | ||||||
| import { attachMinMaxPagination, attachOffsetPagination } from '@/server/api/mastodon/pagination.js'; | import { attachMinMaxPagination, attachOffsetPagination } from '@/server/api/mastodon/pagination.js'; | ||||||
| import { MastodonConverters } from '../MastodonConverters.js'; | import { MastodonConverters } from '../MastodonConverters.js'; | ||||||
| import { parseTimelineArgs, TimelineArgs, toBoolean, toInt } from '../argsUtils.js'; | import { parseTimelineArgs, TimelineArgs, toBoolean, toInt } from '../argsUtils.js'; | ||||||
|  | import { ApiError } from '../../error.js'; | ||||||
| import Account = Entity.Account; | import Account = Entity.Account; | ||||||
| import Status = Entity.Status; | import Status = Entity.Status; | ||||||
| import type { FastifyInstance } from 'fastify'; | import type { FastifyInstance } from 'fastify'; | ||||||
|  | @ -118,6 +119,9 @@ export class ApiSearchMastodon { | ||||||
| 					}, | 					}, | ||||||
| 					body: '{}', | 					body: '{}', | ||||||
| 				}); | 				}); | ||||||
|  | 
 | ||||||
|  | 			await verifyResponse(res); | ||||||
|  | 
 | ||||||
| 			const data = await res.json() as Status[]; | 			const data = await res.json() as Status[]; | ||||||
| 			const me = await this.clientService.getAuth(request); | 			const me = await this.clientService.getAuth(request); | ||||||
| 			const response = await Promise.all(data.map(status => this.mastoConverters.convertStatus(status, me))); | 			const response = await Promise.all(data.map(status => this.mastoConverters.convertStatus(status, me))); | ||||||
|  | @ -143,6 +147,9 @@ export class ApiSearchMastodon { | ||||||
| 						state: 'alive', | 						state: 'alive', | ||||||
| 					}), | 					}), | ||||||
| 				}); | 				}); | ||||||
|  | 
 | ||||||
|  | 			await verifyResponse(res); | ||||||
|  | 
 | ||||||
| 			const data = await res.json() as Account[]; | 			const data = await res.json() as Account[]; | ||||||
| 			const response = await Promise.all(data.map(async entry => { | 			const response = await Promise.all(data.map(async entry => { | ||||||
| 				return { | 				return { | ||||||
|  | @ -156,3 +163,29 @@ export class ApiSearchMastodon { | ||||||
| 		}); | 		}); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | async function verifyResponse(res: Response): Promise<void> { | ||||||
|  | 	if (res.ok) return; | ||||||
|  | 
 | ||||||
|  | 	const text = await res.text(); | ||||||
|  | 
 | ||||||
|  | 	if (res.headers.get('content-type') === 'application/json') { | ||||||
|  | 		try { | ||||||
|  | 			const json = JSON.parse(text); | ||||||
|  | 
 | ||||||
|  | 			if (json && typeof(json) === 'object') { | ||||||
|  | 				json.httpStatusCode = res.status; | ||||||
|  | 				return json; | ||||||
|  | 			} | ||||||
|  | 		} catch { /* ignore */ } | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	// Response is not a JSON object; treat as string
 | ||||||
|  | 	throw new ApiError({ | ||||||
|  | 		code: 'INTERNAL_ERROR', | ||||||
|  | 		message: text || 'Internal error occurred. Please contact us if the error persists.', | ||||||
|  | 		id: '5d37dbcb-891e-41ca-a3d6-e690c97775ac', | ||||||
|  | 		kind: 'server', | ||||||
|  | 		httpStatusCode: res.status, | ||||||
|  | 	}); | ||||||
|  | } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue