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'
11 export class UserService {
12 static BASE_USERS_URL = environment.apiUrl + '/api/v1/users/'
15 private authHttp: HttpClient,
16 private restExtractor: RestExtractor
19 changePassword (newPassword: string) {
20 const url = UserService.BASE_USERS_URL + 'me'
21 const body: UserUpdateMe = {
25 return this.authHttp.put(url, body)
26 .map(this.restExtractor.extractDataBool)
27 .catch(res => this.restExtractor.handleError(res))
30 updateMyDetails (details: UserUpdateMe) {
31 const url = UserService.BASE_USERS_URL + 'me'
33 return this.authHttp.put(url, details)
34 .map(this.restExtractor.extractDataBool)
35 .catch(res => this.restExtractor.handleError(res))
38 changeAvatar (avatarForm: FormData) {
39 const url = UserService.BASE_USERS_URL + 'me/avatar/pick'
41 return this.authHttp.post(url, avatarForm)
42 .catch(this.restExtractor.handleError)
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))
51 getMyVideoQuotaUsed () {
52 const url = UserService.BASE_USERS_URL + '/me/video-quota-used'
54 return this.authHttp.get(url)
55 .catch(res => this.restExtractor.handleError(res))