feat: add pagination options to watchlist api request

feature/watchlist-sync
Ryan Cohen 2 years ago committed by Ryan Cohen
parent d435418d3b
commit 4e6c9ec545

@ -286,11 +286,18 @@ class PlexTvAPI extends ExternalAPI {
return parsedXml;
}
public async getWatchlist(): Promise<PlexWatchlistItem[]> {
public async getWatchlist({
offset = 0,
size = 20,
}: { offset?: number; size?: number } = {}): Promise<PlexWatchlistItem[]> {
try {
const response = await this.axios.get<WatchlistResponse>(
'/library/sections/watchlist/all',
{
params: {
'X-Plex-Container-Start': offset,
'X-Plex-Container-Size': size,
},
baseURL: 'https://metadata.provider.plex.tv',
}
);

@ -709,9 +709,7 @@ discoverRoutes.get<{ language: string }, GenreSliderItem[]>(
}
);
discoverRoutes.get<never, WatchlistItem[]>(
'/watchlist',
async (req, res, next) => {
discoverRoutes.get<never, WatchlistItem[]>('/watchlist', async (req, res) => {
const userRepository = getRepository(User);
const activeUser = await userRepository.findOne({
@ -720,10 +718,8 @@ discoverRoutes.get<never, WatchlistItem[]>(
});
if (!activeUser?.plexToken) {
return next({
status: 500,
message: 'Must be a Plex account to use watchlist feature.',
});
// We will just return an empty array if the user has no plex token
return res.json([]);
}
const plexTV = new PlexTvAPI(activeUser?.plexToken);
@ -731,7 +727,6 @@ discoverRoutes.get<never, WatchlistItem[]>(
const watchlist = await plexTV.getWatchlist();
return res.json(watchlist);
}
);
});
export default discoverRoutes;

Loading…
Cancel
Save