Compare commits
9 Commits
update_any
...
feat/publi
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
6e111921b5 | ||
|
|
c95a66baae | ||
|
|
f3f4868ef8 | ||
|
|
6bcddc62f1 | ||
|
|
2b26b7b848 | ||
|
|
6c361002bf | ||
|
|
6fd471b921 | ||
|
|
562864a70f | ||
|
|
1200064194 |
33
.github/workflows/npm-publish.yml
vendored
Normal file
33
.github/workflows/npm-publish.yml
vendored
Normal file
@@ -0,0 +1,33 @@
|
||||
# This workflow will run tests using node and then publish a package to GitHub Packages when a release is created
|
||||
# For more information see: https://docs.github.com/en/actions/publishing-packages/publishing-nodejs-packages
|
||||
|
||||
name: Node.js Package
|
||||
|
||||
on:
|
||||
release:
|
||||
types: [created]
|
||||
|
||||
jobs:
|
||||
build:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- uses: actions/setup-node@v3
|
||||
with:
|
||||
node-version: 16
|
||||
- run: npm ci
|
||||
- run: npm test
|
||||
|
||||
publish-npm:
|
||||
needs: build
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- uses: actions/setup-node@v3
|
||||
with:
|
||||
node-version: 16
|
||||
registry-url: https://registry.npmjs.org/
|
||||
- run: npm ci
|
||||
- run: npm publish
|
||||
env:
|
||||
NODE_AUTH_TOKEN: ${{secrets.npm_token}}
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "tmdb-ts",
|
||||
"version": "0.1.9",
|
||||
"version": "0.2.0",
|
||||
"description": "TMDB v3 library wrapper",
|
||||
"main": "dist/index.js",
|
||||
"types": "dist/index.d.ts",
|
||||
|
||||
@@ -1,4 +1,5 @@
|
||||
import fetch from 'cross-fetch';
|
||||
import { parseOptions } from './utils';
|
||||
|
||||
const BASE_URL_V3 = 'https://api.themoviedb.org/3';
|
||||
|
||||
@@ -7,8 +8,9 @@ export default class Api {
|
||||
this.accessToken = accessToken;
|
||||
}
|
||||
|
||||
async get<T>(path: string): Promise<T> {
|
||||
const response = await fetch(`${BASE_URL_V3}${path}`, {
|
||||
async get<T>(path: string, options?: Record<string, any>): Promise<T> {
|
||||
const params = parseOptions(options);
|
||||
const response = await fetch(`${BASE_URL_V3}${path}?${params}`, {
|
||||
method: 'GET',
|
||||
headers: {
|
||||
Authorization: `Bearer ${this.accessToken}`,
|
||||
|
||||
@@ -1,6 +1,5 @@
|
||||
import { BaseEndpoint } from './base';
|
||||
import { ChangeOptions, Changes } from '../types/changes';
|
||||
import { parseOptions } from '../utils';
|
||||
|
||||
export class ChangeEndpoint extends BaseEndpoint {
|
||||
constructor(protected readonly accessToken: string) {
|
||||
@@ -8,17 +7,14 @@ export class ChangeEndpoint extends BaseEndpoint {
|
||||
}
|
||||
|
||||
async movies(options?: ChangeOptions): Promise<Changes> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<Changes>(`/movie/changes?${params}`);
|
||||
return await this.api.get<Changes>(`/movie/changes`, options);
|
||||
}
|
||||
|
||||
async tvShows(options?: ChangeOptions): Promise<Changes> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<Changes>(`/tv/changes?${params}`);
|
||||
return await this.api.get<Changes>(`/tv/changes`, options);
|
||||
}
|
||||
|
||||
async person(options?: ChangeOptions): Promise<Changes> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<Changes>(`/person/changes${params}`);
|
||||
return await this.api.get<Changes>(`/person/change`, options);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -4,7 +4,6 @@ import {
|
||||
LanguageOption,
|
||||
Translations,
|
||||
} from '../types';
|
||||
import { parseOptions } from '../utils';
|
||||
import { BaseEndpoint } from './base';
|
||||
|
||||
const BASE_COLLECTION = '/collection';
|
||||
@@ -18,16 +17,16 @@ export class CollectionsEndpoint extends BaseEndpoint {
|
||||
id: number,
|
||||
options?: LanguageOption
|
||||
): Promise<DetailedCollection> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<DetailedCollection>(
|
||||
`${BASE_COLLECTION}/${id}?${params}`
|
||||
`${BASE_COLLECTION}/${id}`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
async images(id: number, options?: LanguageOption): Promise<ImageCollection> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<ImageCollection>(
|
||||
`${BASE_COLLECTION}/${id}/images?${params}`
|
||||
`${BASE_COLLECTION}/${id}/images`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
@@ -35,9 +34,9 @@ export class CollectionsEndpoint extends BaseEndpoint {
|
||||
id: number,
|
||||
options?: LanguageOption
|
||||
): Promise<Translations> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<Translations>(
|
||||
`${BASE_COLLECTION}/${id}/translations?${params}`
|
||||
`${BASE_COLLECTION}/${id}/translations`,
|
||||
options
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -3,7 +3,6 @@ import {
|
||||
SortOption,
|
||||
TvShowDiscoverResult,
|
||||
} from '../types';
|
||||
import { parseOptions } from '../utils';
|
||||
import { BaseEndpoint } from './base';
|
||||
|
||||
const BASE_DISCOVER = '/discover';
|
||||
@@ -70,16 +69,16 @@ export class DiscoverEndpoint extends BaseEndpoint {
|
||||
}
|
||||
|
||||
async movie(options?: MovieQueryOptions): Promise<MovieDiscoverResult> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<MovieDiscoverResult>(
|
||||
`${BASE_DISCOVER}/movie?${params}`
|
||||
`${BASE_DISCOVER}/movie`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
async tvShow(options?: TvShowQueryOptions): Promise<TvShowDiscoverResult> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<TvShowDiscoverResult>(
|
||||
`${BASE_DISCOVER}/tv?${params}`
|
||||
`${BASE_DISCOVER}/tv`,
|
||||
options
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,6 +1,5 @@
|
||||
import { BaseEndpoint } from './base';
|
||||
import { ExternalIdOptions, FindResult } from '../types';
|
||||
import { parseOptions } from '../utils';
|
||||
|
||||
export class FindEndpoint extends BaseEndpoint {
|
||||
constructor(accessToken: string) {
|
||||
@@ -11,7 +10,6 @@ export class FindEndpoint extends BaseEndpoint {
|
||||
externalId: string,
|
||||
options: ExternalIdOptions
|
||||
): Promise<FindResult> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<FindResult>(`/find/${externalId}?${params}`);
|
||||
return await this.api.get<FindResult>(`/find/${externalId}`, options);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,6 +1,5 @@
|
||||
import { BaseEndpoint } from './base';
|
||||
import { BelongingMovies, Keyword, KeywordsOptions } from '../types';
|
||||
import { parseOptions } from '../utils';
|
||||
|
||||
const BASE_Keyword = '/keyword';
|
||||
|
||||
@@ -17,9 +16,9 @@ export class KeywordsEndpoint extends BaseEndpoint {
|
||||
keywordId: number,
|
||||
options?: KeywordsOptions
|
||||
): Promise<BelongingMovies> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<BelongingMovies>(
|
||||
`${BASE_Keyword}/${keywordId}/movies?${params}`
|
||||
`${BASE_Keyword}/${keywordId}/movies`,
|
||||
options
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -25,7 +25,6 @@ import {
|
||||
Videos,
|
||||
WatchProviders,
|
||||
} from '../types';
|
||||
import { parseOptions } from '../utils';
|
||||
|
||||
const BASE_MOVIE = '/movie';
|
||||
|
||||
@@ -45,9 +44,9 @@ export class MoviesEndpoint extends BaseEndpoint {
|
||||
}
|
||||
|
||||
async changes(id: number, options?: ChangeOptions): Promise<MovieChanges> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<MovieChanges>(
|
||||
`${BASE_MOVIE}/${id}/changes?${params}`
|
||||
`${BASE_MOVIE}/${id}/changes`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
@@ -71,19 +70,16 @@ export class MoviesEndpoint extends BaseEndpoint {
|
||||
id: number,
|
||||
options?: LanguageOption | PageOption
|
||||
): Promise<MovieLists> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<MovieLists>(
|
||||
`${BASE_MOVIE}/${id}/lists?${params}`
|
||||
);
|
||||
return await this.api.get<MovieLists>(`${BASE_MOVIE}/${id}/lists`, options);
|
||||
}
|
||||
|
||||
async recommendations(
|
||||
id: number,
|
||||
options?: PageOption
|
||||
): Promise<Recommendations> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<Recommendations>(
|
||||
`${BASE_MOVIE}/${id}/recommendations?${params}`
|
||||
`${BASE_MOVIE}/${id}/recommendations`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
@@ -94,14 +90,13 @@ export class MoviesEndpoint extends BaseEndpoint {
|
||||
}
|
||||
|
||||
async reviews(id: number, options?: PageOption): Promise<Reviews> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<Reviews>(`${BASE_MOVIE}/${id}/reviews?${params}`);
|
||||
return await this.api.get<Reviews>(`${BASE_MOVIE}/${id}/reviews`, options);
|
||||
}
|
||||
|
||||
async similar(id: number, options?: PageOption): Promise<SimilarMovies> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<SimilarMovies>(
|
||||
`${BASE_MOVIE}/${id}/similar?${params}`
|
||||
`${BASE_MOVIE}/${id}/similar`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
@@ -130,32 +125,31 @@ export class MoviesEndpoint extends BaseEndpoint {
|
||||
async nowPlaying(
|
||||
options?: PageOption & LanguageOption & RegionOption
|
||||
): Promise<MoviesPlayingNow> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<MoviesPlayingNow>(
|
||||
`${BASE_MOVIE}/now_playing?${params}`
|
||||
`${BASE_MOVIE}/now_playing`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
async popular(options?: PageOption): Promise<PopularMovies> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<PopularMovies>(`${BASE_MOVIE}/popular?${params}`);
|
||||
return await this.api.get<PopularMovies>(`${BASE_MOVIE}/popular`, options);
|
||||
}
|
||||
|
||||
async topRated(
|
||||
options?: PageOption & LanguageOption & RegionOption
|
||||
): Promise<TopRatedMovies> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<TopRatedMovies>(
|
||||
`${BASE_MOVIE}/top_rated?${params}`
|
||||
`${BASE_MOVIE}/top_rated`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
async upcoming(
|
||||
options?: PageOption & LanguageOption & RegionOption
|
||||
): Promise<UpcomingMovies> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<UpcomingMovies>(
|
||||
`${BASE_MOVIE}/upcoming?${params}`
|
||||
`${BASE_MOVIE}/upcoming`,
|
||||
options
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -12,7 +12,6 @@ import {
|
||||
PopularPersons,
|
||||
TaggedImages,
|
||||
} from '../types';
|
||||
import { parseOptions } from '../utils';
|
||||
import { BaseEndpoint } from './base';
|
||||
|
||||
const BASE_PERSON = '/person';
|
||||
@@ -27,9 +26,9 @@ export class PeopleEndpoint extends BaseEndpoint {
|
||||
}
|
||||
|
||||
async changes(id: number, options?: ChangeOptions): Promise<PersonChanges> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<PersonChanges>(
|
||||
`${BASE_PERSON}/${id}/changes?${params}`
|
||||
`${BASE_PERSON}/${id}/changes`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
@@ -62,9 +61,9 @@ export class PeopleEndpoint extends BaseEndpoint {
|
||||
}
|
||||
|
||||
async taggedImages(id: number, options?: PageOption): Promise<TaggedImages> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<TaggedImages>(
|
||||
`${BASE_PERSON}/${id}/tagged_images?${params}`
|
||||
`${BASE_PERSON}/${id}/tagged_images`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
@@ -79,9 +78,9 @@ export class PeopleEndpoint extends BaseEndpoint {
|
||||
}
|
||||
|
||||
async popular(options?: PageOption): Promise<PopularPersons> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<PopularPersons>(
|
||||
`${BASE_PERSON}/popular?${params}`
|
||||
`${BASE_PERSON}/popular`,
|
||||
options
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,7 +1,6 @@
|
||||
import { BaseEndpoint } from './base';
|
||||
import { Search } from '../types/search';
|
||||
import { Collection, Company, Movie, Person, TV } from '../types';
|
||||
import { parseOptions } from '../utils';
|
||||
|
||||
const BASE_SEARCH = '/search';
|
||||
|
||||
@@ -31,44 +30,39 @@ export class SearchEndpoint extends BaseEndpoint {
|
||||
}
|
||||
|
||||
async companies(options: SearchOptions): Promise<Search<Company>> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<Search<Company>>(
|
||||
`${BASE_SEARCH}/company?${params}`
|
||||
`${BASE_SEARCH}/company`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
async collections(options: SearchOptions): Promise<Search<Collection>> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<Search<Collection>>(
|
||||
`${BASE_SEARCH}/collection?${params}`
|
||||
`${BASE_SEARCH}/collection`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
async keywords(
|
||||
options: SearchOptions
|
||||
): Promise<Search<{ id: string; name: string }>> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<Search<{ id: string; name: string }>>(
|
||||
`${BASE_SEARCH}/keyword?${params}`
|
||||
`${BASE_SEARCH}/keyword`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
async movies(options: MovieSearchOptions): Promise<Search<Movie>> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<Search<Movie>>(`${BASE_SEARCH}/movie?${params}`);
|
||||
return await this.api.get<Search<Movie>>(`${BASE_SEARCH}/movie`, options);
|
||||
}
|
||||
|
||||
async people(options: PeopleSearchOptions): Promise<Search<Person>> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<Search<Person>>(
|
||||
`${BASE_SEARCH}/person?${params}`
|
||||
);
|
||||
return await this.api.get<Search<Person>>(`${BASE_SEARCH}/person`, options);
|
||||
}
|
||||
|
||||
// TODO: Multi search
|
||||
|
||||
async tvShows(options: TvSearchOptions): Promise<Search<TV>> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<Search<TV>>(`${BASE_SEARCH}/tv?${params}`);
|
||||
return await this.api.get<Search<TV>>(`${BASE_SEARCH}/tv`, options);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -27,7 +27,6 @@ import {
|
||||
Videos,
|
||||
WatchProviders,
|
||||
} from '../types';
|
||||
import { parseOptions } from '../utils';
|
||||
|
||||
const BASE_TV = '/tv';
|
||||
|
||||
@@ -47,9 +46,9 @@ export class TvShowsEndpoint extends BaseEndpoint {
|
||||
}
|
||||
|
||||
async changes(id: number, options?: ChangeOptions): Promise<TvShowChanges> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<TvShowChanges>(
|
||||
`${BASE_TV}/${id}/changes?${params}`
|
||||
`${BASE_TV}/${id}/changes`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
@@ -89,15 +88,14 @@ export class TvShowsEndpoint extends BaseEndpoint {
|
||||
id: number,
|
||||
options?: PageOption
|
||||
): Promise<Recommendations> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<Recommendations>(
|
||||
`${BASE_TV}/${id}/recommendations?${params}`
|
||||
`${BASE_TV}/${id}/recommendations`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
async reviews(id: number, options?: PageOption): Promise<Reviews> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<Reviews>(`${BASE_TV}/${id}/reviews?${params}`);
|
||||
return await this.api.get<Reviews>(`${BASE_TV}/${id}/reviews`, options);
|
||||
}
|
||||
|
||||
async screenedTheatrically(id: number): Promise<ScreenedTheatrically> {
|
||||
@@ -107,9 +105,9 @@ export class TvShowsEndpoint extends BaseEndpoint {
|
||||
}
|
||||
|
||||
async similar(id: number, options?: PageOption): Promise<SimilarTvShows> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<SimilarTvShows>(
|
||||
`${BASE_TV}/${id}/similar?${params}`
|
||||
`${BASE_TV}/${id}/similar`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
@@ -142,25 +140,21 @@ export class TvShowsEndpoint extends BaseEndpoint {
|
||||
async airingToday(
|
||||
options?: PageOption & LanguageOption & RegionOption
|
||||
): Promise<TvShowsAiringToday> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<TvShowsAiringToday>(
|
||||
`${BASE_TV}/airing_today?${params}`
|
||||
`${BASE_TV}/airing_today`,
|
||||
options
|
||||
);
|
||||
}
|
||||
|
||||
async popular(
|
||||
options?: PageOption & LanguageOption & RegionOption
|
||||
): Promise<PopularTvShows> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<PopularTvShows>(`${BASE_TV}/popular?${params}`);
|
||||
return await this.api.get<PopularTvShows>(`${BASE_TV}/popular`, options);
|
||||
}
|
||||
|
||||
async topRated(
|
||||
options?: PageOption & LanguageOption & RegionOption
|
||||
): Promise<TopRatedTvShows> {
|
||||
const params = parseOptions(options);
|
||||
return await this.api.get<TopRatedTvShows>(
|
||||
`${BASE_TV}/top_rated?${params}`
|
||||
);
|
||||
return await this.api.get<TopRatedTvShows>(`${BASE_TV}/top_rated`, options);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
export function parseOptions(options?: Record<string, any>): string {
|
||||
/* eslint-disable @typescript-eslint/no-explicit-any */
|
||||
export function parseOptions(options?: { [s: string]: any }): string {
|
||||
return options ? new URLSearchParams(Object.entries(options)).toString() : '';
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user