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