]>
Commit | Line | Data |
---|---|---|
5fb2e288 | 1 | import { Observable } from 'rxjs' |
f37dc0dd | 2 | import { catchError, map, switchMap } from 'rxjs/operators' |
57c36b27 C |
3 | import { HttpClient, HttpParams } from '@angular/common/http' |
4 | import { Injectable } from '@angular/core' | |
67ed6552 | 5 | import { ComponentPaginationLight, RestExtractor, RestPagination, RestService } from '@app/core' |
67ed6552 | 6 | import { Video, VideoChannel, VideoChannelService, VideoService } from '@app/shared/shared-main' |
37a44fc9 C |
7 | import { peertubeLocalStorage } from '@root-helpers/peertube-web-storage' |
8 | import { | |
9 | ResultList, | |
10 | SearchTargetType, | |
11 | Video as VideoServerModel, | |
12 | VideoChannel as VideoChannelServerModel, | |
13 | VideoPlaylist as VideoPlaylistServerModel | |
14 | } from '@shared/models' | |
1942f11d | 15 | import { environment } from '../../../environments/environment' |
37a44fc9 | 16 | import { VideoPlaylist, VideoPlaylistService } from '../shared-video-playlist' |
1942f11d | 17 | import { AdvancedSearch } from './advanced-search.model' |
57c36b27 C |
18 | |
19 | @Injectable() | |
20 | export class SearchService { | |
21 | static BASE_SEARCH_URL = environment.apiUrl + '/api/v1/search/' | |
22 | ||
23 | constructor ( | |
24 | private authHttp: HttpClient, | |
25 | private restExtractor: RestExtractor, | |
26 | private restService: RestService, | |
37a44fc9 C |
27 | private videoService: VideoService, |
28 | private playlistService: VideoPlaylistService | |
b0e769bb C |
29 | ) { |
30 | // Add ability to override search endpoint if the user updated this local storage key | |
31 | const searchUrl = peertubeLocalStorage.getItem('search-url') | |
32 | if (searchUrl) SearchService.BASE_SEARCH_URL = searchUrl | |
33 | } | |
57c36b27 | 34 | |
93cae479 | 35 | searchVideos (parameters: { |
57c36b27 | 36 | search: string, |
5fb2e288 C |
37 | componentPagination?: ComponentPaginationLight, |
38 | advancedSearch?: AdvancedSearch | |
93cae479 C |
39 | }): Observable<ResultList<Video>> { |
40 | const { search, componentPagination, advancedSearch } = parameters | |
57c36b27 | 41 | |
93cae479 | 42 | const url = SearchService.BASE_SEARCH_URL + 'videos' |
5fb2e288 C |
43 | let pagination: RestPagination |
44 | ||
45 | if (componentPagination) { | |
46 | pagination = this.restService.componentPaginationToRestPagination(componentPagination) | |
47 | } | |
57c36b27 C |
48 | |
49 | let params = new HttpParams() | |
50 | params = this.restService.addRestGetParams(params, pagination) | |
4278710d C |
51 | |
52 | if (search) params = params.append('search', search) | |
57c36b27 | 53 | |
5fb2e288 C |
54 | if (advancedSearch) { |
55 | const advancedSearchObject = advancedSearch.toAPIObject() | |
56 | params = this.restService.addObjectParams(params, advancedSearchObject) | |
57 | } | |
0b18f4aa | 58 | |
57c36b27 C |
59 | return this.authHttp |
60 | .get<ResultList<VideoServerModel>>(url, { params }) | |
61 | .pipe( | |
62 | switchMap(res => this.videoService.extractVideos(res)), | |
63 | catchError(err => this.restExtractor.handleError(err)) | |
64 | ) | |
65 | } | |
f37dc0dd | 66 | |
93cae479 | 67 | searchVideoChannels (parameters: { |
f37dc0dd | 68 | search: string, |
5fb2e288 C |
69 | searchTarget?: SearchTargetType, |
70 | componentPagination?: ComponentPaginationLight | |
93cae479 | 71 | }): Observable<ResultList<VideoChannel>> { |
5fb2e288 | 72 | const { search, componentPagination, searchTarget } = parameters |
f37dc0dd | 73 | |
93cae479 | 74 | const url = SearchService.BASE_SEARCH_URL + 'video-channels' |
5fb2e288 C |
75 | |
76 | let pagination: RestPagination | |
77 | if (componentPagination) { | |
78 | pagination = this.restService.componentPaginationToRestPagination(componentPagination) | |
79 | } | |
f37dc0dd C |
80 | |
81 | let params = new HttpParams() | |
82 | params = this.restService.addRestGetParams(params, pagination) | |
83 | params = params.append('search', search) | |
84 | ||
5fb2e288 C |
85 | if (searchTarget) { |
86 | params = params.append('searchTarget', searchTarget as string) | |
87 | } | |
88 | ||
f37dc0dd C |
89 | return this.authHttp |
90 | .get<ResultList<VideoChannelServerModel>>(url, { params }) | |
91 | .pipe( | |
92 | map(res => VideoChannelService.extractVideoChannels(res)), | |
93 | catchError(err => this.restExtractor.handleError(err)) | |
94 | ) | |
95 | } | |
37a44fc9 C |
96 | |
97 | searchVideoPlaylists (parameters: { | |
98 | search: string, | |
99 | searchTarget?: SearchTargetType, | |
100 | componentPagination?: ComponentPaginationLight | |
101 | }): Observable<ResultList<VideoPlaylist>> { | |
102 | const { search, componentPagination, searchTarget } = parameters | |
103 | ||
104 | const url = SearchService.BASE_SEARCH_URL + 'video-playlists' | |
105 | ||
106 | let pagination: RestPagination | |
107 | if (componentPagination) { | |
108 | pagination = this.restService.componentPaginationToRestPagination(componentPagination) | |
109 | } | |
110 | ||
111 | let params = new HttpParams() | |
112 | params = this.restService.addRestGetParams(params, pagination) | |
113 | params = params.append('search', search) | |
114 | ||
115 | if (searchTarget) { | |
116 | params = params.append('searchTarget', searchTarget as string) | |
117 | } | |
118 | ||
119 | return this.authHttp | |
120 | .get<ResultList<VideoPlaylistServerModel>>(url, { params }) | |
121 | .pipe( | |
122 | switchMap(res => this.playlistService.extractPlaylists(res)), | |
123 | catchError(err => this.restExtractor.handleError(err)) | |
124 | ) | |
125 | } | |
57c36b27 | 126 | } |