mirror of
https://akkoma.dev/AkkomaGang/akkoma-fe.git
synced 2025-01-19 10:46:06 +01:00
Add cleaner message for rate-limited users (#19)
Reviewed-on: https://akkoma.dev/AkkomaGang/pleroma-fe/pulls/19
This commit is contained in:
parent
794906f01e
commit
9e13e5d164
1 changed files with 24 additions and 3 deletions
|
@ -462,6 +462,20 @@ const deleteList = ({ id, credentials }) => {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const errorStatusMapper = (response) => {
|
||||||
|
console.log(response)
|
||||||
|
switch (response.status) {
|
||||||
|
case 429:
|
||||||
|
return 'You are rate limited'
|
||||||
|
case 500:
|
||||||
|
return 'Internal Server Error'
|
||||||
|
case 503:
|
||||||
|
return 'The backend is not available'
|
||||||
|
default:
|
||||||
|
return `Unexpected status: ${response.status}`
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const fetchConversation = ({ id, credentials }) => {
|
const fetchConversation = ({ id, credentials }) => {
|
||||||
let urlContext = MASTODON_STATUS_CONTEXT_URL(id)
|
let urlContext = MASTODON_STATUS_CONTEXT_URL(id)
|
||||||
return fetch(urlContext, { headers: authHeaders(credentials) })
|
return fetch(urlContext, { headers: authHeaders(credentials) })
|
||||||
|
@ -469,7 +483,7 @@ const fetchConversation = ({ id, credentials }) => {
|
||||||
if (data.ok) {
|
if (data.ok) {
|
||||||
return data
|
return data
|
||||||
}
|
}
|
||||||
throw new Error('Error fetching timeline', data)
|
throw new Error('Error fetching timeline', errorStatusMapper(data))
|
||||||
})
|
})
|
||||||
.then((data) => data.json())
|
.then((data) => data.json())
|
||||||
.then(({ ancestors, descendants }) => ({
|
.then(({ ancestors, descendants }) => ({
|
||||||
|
@ -485,7 +499,7 @@ const fetchStatus = ({ id, credentials }) => {
|
||||||
if (data.ok) {
|
if (data.ok) {
|
||||||
return data
|
return data
|
||||||
}
|
}
|
||||||
throw new Error('Error fetching timeline', data)
|
throw new Error('Error fetching timeline', errorStatusMapper(data))
|
||||||
})
|
})
|
||||||
.then((data) => data.json())
|
.then((data) => data.json())
|
||||||
.then((data) => parseStatus(data))
|
.then((data) => parseStatus(data))
|
||||||
|
@ -657,8 +671,15 @@ const fetchTimeline = ({
|
||||||
})
|
})
|
||||||
return data
|
return data
|
||||||
})
|
})
|
||||||
.then((data) => data.json())
|
|
||||||
.then((data) => {
|
.then((data) => {
|
||||||
|
if (data.ok) return data.json()
|
||||||
|
|
||||||
|
throw new Error(errorStatusMapper(data))
|
||||||
|
})
|
||||||
|
.then((data) => {
|
||||||
|
if (data.error) {
|
||||||
|
throw new Error(data.error)
|
||||||
|
}
|
||||||
if (!data.errors) {
|
if (!data.errors) {
|
||||||
return { data: data.map(isNotifications ? parseNotification : parseStatus), pagination }
|
return { data: data.map(isNotifications ? parseNotification : parseStatus), pagination }
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in a new issue