mirror of
https://codeberg.org/yeentown/barkey.git
synced 2025-10-24 02:04: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