pinafore/routes/_api/timelines.js

54 lines
1.4 KiB
JavaScript
Raw Normal View History

import { get, paramsString, DEFAULT_TIMEOUT } from '../_utils/ajax'
2018-02-24 23:49:28 +01:00
import { auth, basename } from './utils'
2018-01-19 05:25:34 +01:00
2018-02-09 07:29:29 +01:00
function getTimelineUrlPath (timeline) {
2018-01-22 05:02:32 +01:00
switch (timeline) {
case 'local':
case 'federated':
2018-01-23 06:16:27 +01:00
return 'timelines/public'
2018-01-22 05:02:32 +01:00
case 'home':
2018-01-23 06:16:27 +01:00
return 'timelines/home'
case 'notifications':
return 'notifications'
case 'favorites':
return 'favourites'
2018-01-23 06:16:27 +01:00
}
if (timeline.startsWith('tag/')) {
return 'timelines/tag'
} else if (timeline.startsWith('account/')) {
return 'accounts'
2018-02-08 18:15:25 +01:00
} else if (timeline.startsWith('list/')) {
return 'timelines/list'
2018-01-22 05:02:32 +01:00
}
}
2018-02-09 07:29:29 +01:00
export function getTimeline (instanceName, accessToken, timeline, maxId, since) {
2018-01-23 06:16:27 +01:00
let timelineUrlName = getTimelineUrlPath(timeline)
let url = `${basename(instanceName)}/api/v1/${timelineUrlName}`
2018-01-19 05:25:34 +01:00
2018-01-22 05:02:32 +01:00
if (timeline.startsWith('tag/')) {
url += '/' + timeline.split('/').slice(-1)[0]
2018-01-23 06:16:27 +01:00
} else if (timeline.startsWith('account/')) {
2018-02-08 18:15:25 +01:00
url += '/' + timeline.split('/').slice(-1)[0] + '/statuses'
} else if (timeline.startsWith('list/')) {
url += '/' + timeline.split('/').slice(-1)[0]
2018-01-22 05:02:32 +01:00
}
2018-01-19 05:25:34 +01:00
let params = {}
if (since) {
params.since = since
}
if (maxId) {
params.max_id = maxId
}
2018-01-19 08:37:43 +01:00
if (timeline === 'local') {
params.local = true
}
2018-01-19 05:25:34 +01:00
url += '?' + paramsString(params)
return get(url, auth(accessToken), { timeout: DEFAULT_TIMEOUT })
2018-02-09 07:29:29 +01:00
}