]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blob - client/src/app/shared/users/user.service.ts
Begin to add avatar to actors
[github/Chocobozzz/PeerTube.git] / client / src / app / shared / users / user.service.ts
1 import { HttpClient } from '@angular/common/http'
2 import { Injectable } from '@angular/core'
3 import 'rxjs/add/operator/catch'
4 import 'rxjs/add/operator/map'
5 import { UserCreate, UserUpdateMe } from '../../../../../shared'
6 import { environment } from '../../../environments/environment'
7 import { RestExtractor } from '../rest'
8 import { User } from './user.model'
9
10 @Injectable()
11 export class UserService {
12 static BASE_USERS_URL = environment.apiUrl + '/api/v1/users/'
13
14 constructor (
15 private authHttp: HttpClient,
16 private restExtractor: RestExtractor
17 ) {}
18
19 changePassword (newPassword: string) {
20 const url = UserService.BASE_USERS_URL + 'me'
21 const body: UserUpdateMe = {
22 password: newPassword
23 }
24
25 return this.authHttp.put(url, body)
26 .map(this.restExtractor.extractDataBool)
27 .catch(res => this.restExtractor.handleError(res))
28 }
29
30 updateMyDetails (details: UserUpdateMe) {
31 const url = UserService.BASE_USERS_URL + 'me'
32
33 return this.authHttp.put(url, details)
34 .map(this.restExtractor.extractDataBool)
35 .catch(res => this.restExtractor.handleError(res))
36 }
37
38 changeAvatar (avatarForm: FormData) {
39 const url = UserService.BASE_USERS_URL + 'me/avatar/pick'
40
41 return this.authHttp.post(url, avatarForm)
42 .catch(this.restExtractor.handleError)
43 }
44
45 signup (userCreate: UserCreate) {
46 return this.authHttp.post(UserService.BASE_USERS_URL + 'register', userCreate)
47 .map(this.restExtractor.extractDataBool)
48 .catch(res => this.restExtractor.handleError(res))
49 }
50
51 getMyInformation () {
52 const url = UserService.BASE_USERS_URL + 'me'
53
54 return this.authHttp.get(url)
55 .map((userHash: any) => new User(userHash))
56 .catch(res => this.restExtractor.handleError(res))
57 }
58 }