import { SortMeta } from 'primeng/api'
-import { Observable } from 'rxjs'
-import { catchError, map } from 'rxjs/operators'
+import { from, Observable } from 'rxjs'
+import { catchError, concatMap, toArray } from 'rxjs/operators'
import { HttpClient, HttpParams } from '@angular/common/http'
import { Injectable } from '@angular/core'
import { RestExtractor, RestPagination, RestService } from '@app/core'
+import { arrayify } from '@shared/core-utils'
import { ActivityPubActorType, ActorFollow, FollowState, ResultList, ServerFollowCreate } from '@shared/models'
import { environment } from '../../../environments/environment'
+import { AdvancedInputFilter } from '../shared-forms'
@Injectable()
export class InstanceFollowService {
let params = new HttpParams()
params = this.restService.addRestGetParams(params, pagination, sort)
- if (search) params = params.append('search', search)
+ if (search) {
+ params = this.restService.addObjectParams(params, this.parseFollowsListFilters(search))
+ }
+
if (state) params = params.append('state', state)
if (actorType) params = params.append('actorType', actorType)
return this.authHttp.get<ResultList<ActorFollow>>(InstanceFollowService.BASE_APPLICATION_URL + '/following', { params })
- .pipe(
- map(res => this.restExtractor.convertResultListDateToHuman(res)),
- catchError(res => this.restExtractor.handleError(res))
- )
+ .pipe(catchError(res => this.restExtractor.handleError(res)))
}
getFollowers (options: {
let params = new HttpParams()
params = this.restService.addRestGetParams(params, pagination, sort)
- if (search) params = params.append('search', search)
+ if (search) {
+ params = this.restService.addObjectParams(params, this.parseFollowsListFilters(search))
+ }
+
if (state) params = params.append('state', state)
if (actorType) params = params.append('actorType', actorType)
return this.authHttp.get<ResultList<ActorFollow>>(InstanceFollowService.BASE_APPLICATION_URL + '/followers', { params })
- .pipe(
- map(res => this.restExtractor.convertResultListDateToHuman(res)),
- catchError(res => this.restExtractor.handleError(res))
- )
+ .pipe(catchError(res => this.restExtractor.handleError(res)))
}
follow (hostsOrHandles: string[]) {
}
return this.authHttp.post(InstanceFollowService.BASE_APPLICATION_URL + '/following', body)
- .pipe(
- map(this.restExtractor.extractDataBool),
- catchError(res => this.restExtractor.handleError(res))
- )
+ .pipe(catchError(res => this.restExtractor.handleError(res)))
+ }
+
+ unfollow (followsArg: ActorFollow[] | ActorFollow) {
+ const follows = arrayify(followsArg)
+
+ return from(follows)
+ .pipe(
+ concatMap(follow => {
+ const handle = follow.following.name + '@' + follow.following.host
+
+ return this.authHttp.delete(InstanceFollowService.BASE_APPLICATION_URL + '/following/' + handle)
+ }),
+ toArray(),
+ catchError(err => this.restExtractor.handleError(err))
+ )
}
- unfollow (follow: ActorFollow) {
- const handle = follow.following.name + '@' + follow.following.host
+ acceptFollower (followsArg: ActorFollow[] | ActorFollow) {
+ const follows = arrayify(followsArg)
+
+ return from(follows)
+ .pipe(
+ concatMap(follow => {
+ const handle = follow.follower.name + '@' + follow.follower.host
- return this.authHttp.delete(InstanceFollowService.BASE_APPLICATION_URL + '/following/' + handle)
- .pipe(
- map(this.restExtractor.extractDataBool),
- catchError(res => this.restExtractor.handleError(res))
- )
+ return this.authHttp.post(`${InstanceFollowService.BASE_APPLICATION_URL}/followers/${handle}/accept`, {})
+ }),
+ toArray(),
+ catchError(err => this.restExtractor.handleError(err))
+ )
}
- acceptFollower (follow: ActorFollow) {
- const handle = follow.follower.name + '@' + follow.follower.host
+ rejectFollower (followsArg: ActorFollow[] | ActorFollow) {
+ const follows = arrayify(followsArg)
- return this.authHttp.post(`${InstanceFollowService.BASE_APPLICATION_URL}/followers/${handle}/accept`, {})
- .pipe(
- map(this.restExtractor.extractDataBool),
- catchError(res => this.restExtractor.handleError(res))
- )
+ return from(follows)
+ .pipe(
+ concatMap(follow => {
+ const handle = follow.follower.name + '@' + follow.follower.host
+
+ return this.authHttp.post(`${InstanceFollowService.BASE_APPLICATION_URL}/followers/${handle}/reject`, {})
+ }),
+ toArray(),
+ catchError(err => this.restExtractor.handleError(err))
+ )
}
- rejectFollower (follow: ActorFollow) {
- const handle = follow.follower.name + '@' + follow.follower.host
+ removeFollower (followsArg: ActorFollow[] | ActorFollow) {
+ const follows = arrayify(followsArg)
+
+ return from(follows)
+ .pipe(
+ concatMap(follow => {
+ const handle = follow.follower.name + '@' + follow.follower.host
- return this.authHttp.post(`${InstanceFollowService.BASE_APPLICATION_URL}/followers/${handle}/reject`, {})
- .pipe(
- map(this.restExtractor.extractDataBool),
- catchError(res => this.restExtractor.handleError(res))
- )
+ return this.authHttp.delete(`${InstanceFollowService.BASE_APPLICATION_URL}/followers/${handle}`)
+ }),
+ toArray(),
+ catchError(err => this.restExtractor.handleError(err))
+ )
}
- removeFollower (follow: ActorFollow) {
- const handle = follow.follower.name + '@' + follow.follower.host
+ buildFollowsListFilters (): AdvancedInputFilter[] {
+ return [
+ {
+ title: $localize`Advanced filters`,
+ children: [
+ {
+ value: 'state:accepted',
+ label: $localize`Accepted follows`
+ },
+ {
+ value: 'state:rejected',
+ label: $localize`Rejected follows`
+ },
+ {
+ value: 'state:pending',
+ label: $localize`Pending follows`
+ }
+ ]
+ }
+ ]
+ }
- return this.authHttp.delete(`${InstanceFollowService.BASE_APPLICATION_URL}/followers/${handle}`)
- .pipe(
- map(this.restExtractor.extractDataBool),
- catchError(res => this.restExtractor.handleError(res))
- )
+ private parseFollowsListFilters (search: string) {
+ return this.restService.parseQueryStringFilter(search, {
+ state: {
+ prefix: 'state:'
+ }
+ })
}
}