Add accept-language header (#2457)
This commit is contained in:
parent
1d3e20220d
commit
7df0b7ade1
2 changed files with 28 additions and 14 deletions
|
@ -4,15 +4,20 @@ import {
|
||||||
} from '@atproto/api'
|
} from '@atproto/api'
|
||||||
import {FeedAPI, FeedAPIResponse} from './types'
|
import {FeedAPI, FeedAPIResponse} from './types'
|
||||||
import {getAgent} from '#/state/session'
|
import {getAgent} from '#/state/session'
|
||||||
|
import {getContentLanguages} from '#/state/preferences/languages'
|
||||||
|
|
||||||
export class CustomFeedAPI implements FeedAPI {
|
export class CustomFeedAPI implements FeedAPI {
|
||||||
constructor(public params: GetCustomFeed.QueryParams) {}
|
constructor(public params: GetCustomFeed.QueryParams) {}
|
||||||
|
|
||||||
async peekLatest(): Promise<AppBskyFeedDefs.FeedViewPost> {
|
async peekLatest(): Promise<AppBskyFeedDefs.FeedViewPost> {
|
||||||
const res = await getAgent().app.bsky.feed.getFeed({
|
const contentLangs = getContentLanguages().join(',')
|
||||||
...this.params,
|
const res = await getAgent().app.bsky.feed.getFeed(
|
||||||
limit: 1,
|
{
|
||||||
})
|
...this.params,
|
||||||
|
limit: 1,
|
||||||
|
},
|
||||||
|
{headers: {'Accept-Language': contentLangs}},
|
||||||
|
)
|
||||||
return res.data.feed[0]
|
return res.data.feed[0]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -23,11 +28,15 @@ export class CustomFeedAPI implements FeedAPI {
|
||||||
cursor: string | undefined
|
cursor: string | undefined
|
||||||
limit: number
|
limit: number
|
||||||
}): Promise<FeedAPIResponse> {
|
}): Promise<FeedAPIResponse> {
|
||||||
const res = await getAgent().app.bsky.feed.getFeed({
|
const contentLangs = getContentLanguages().join(',')
|
||||||
...this.params,
|
const res = await getAgent().app.bsky.feed.getFeed(
|
||||||
cursor,
|
{
|
||||||
limit,
|
...this.params,
|
||||||
})
|
cursor,
|
||||||
|
limit,
|
||||||
|
},
|
||||||
|
{headers: {'Accept-Language': contentLangs}},
|
||||||
|
)
|
||||||
if (res.success) {
|
if (res.success) {
|
||||||
// NOTE
|
// NOTE
|
||||||
// some custom feeds fail to enforce the pagination limit
|
// some custom feeds fail to enforce the pagination limit
|
||||||
|
|
|
@ -8,6 +8,7 @@ import {FeedAPI, FeedAPIResponse, ReasonFeedSource} from './types'
|
||||||
import {FeedParams} from '#/state/queries/post-feed'
|
import {FeedParams} from '#/state/queries/post-feed'
|
||||||
import {FeedTunerFn} from '../feed-manip'
|
import {FeedTunerFn} from '../feed-manip'
|
||||||
import {getAgent} from '#/state/session'
|
import {getAgent} from '#/state/session'
|
||||||
|
import {getContentLanguages} from '#/state/preferences/languages'
|
||||||
|
|
||||||
const REQUEST_WAIT_MS = 500 // 500ms
|
const REQUEST_WAIT_MS = 500 // 500ms
|
||||||
const POST_AGE_CUTOFF = 60e3 * 60 * 24 // 24hours
|
const POST_AGE_CUTOFF = 60e3 * 60 * 24 // 24hours
|
||||||
|
@ -231,11 +232,15 @@ class MergeFeedSource_Custom extends MergeFeedSource {
|
||||||
limit: number,
|
limit: number,
|
||||||
): Promise<AppBskyFeedGetTimeline.Response> {
|
): Promise<AppBskyFeedGetTimeline.Response> {
|
||||||
try {
|
try {
|
||||||
const res = await getAgent().app.bsky.feed.getFeed({
|
const contentLangs = getContentLanguages().join(',')
|
||||||
cursor,
|
const res = await getAgent().app.bsky.feed.getFeed(
|
||||||
limit,
|
{
|
||||||
feed: this.feedUri,
|
cursor,
|
||||||
})
|
limit,
|
||||||
|
feed: this.feedUri,
|
||||||
|
},
|
||||||
|
{headers: {'Accept-Language': contentLangs}},
|
||||||
|
)
|
||||||
// NOTE
|
// NOTE
|
||||||
// some custom feeds fail to enforce the pagination limit
|
// some custom feeds fail to enforce the pagination limit
|
||||||
// so we manually truncate here
|
// so we manually truncate here
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue