diff options
author | Chocobozzz <florian.bigard@gmail.com> | 2016-03-22 15:51:54 +0100 |
---|---|---|
committer | Chocobozzz <florian.bigard@gmail.com> | 2016-03-22 15:51:54 +0100 |
commit | b1794c53ac97d77a16c10ed915336f08cff1e5e3 (patch) | |
tree | 9dd64ee8316e1e60c434a7d0a6dcbace49eb4d6b /client/angular/users/services | |
parent | 13ce1d01c953f0c4fd3b1d714c016f927dc16f66 (diff) | |
download | PeerTube-b1794c53ac97d77a16c10ed915336f08cff1e5e3.tar.gz PeerTube-b1794c53ac97d77a16c10ed915336f08cff1e5e3.tar.zst PeerTube-b1794c53ac97d77a16c10ed915336f08cff1e5e3.zip |
Login in Angular : first draft
Diffstat (limited to 'client/angular/users/services')
-rw-r--r-- | client/angular/users/services/auth.service.ts | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/client/angular/users/services/auth.service.ts b/client/angular/users/services/auth.service.ts new file mode 100644 index 000000000..a512c3d9c --- /dev/null +++ b/client/angular/users/services/auth.service.ts | |||
@@ -0,0 +1,54 @@ | |||
1 | import { Injectable } from 'angular2/core'; | ||
2 | import { Http, Response, Headers, URLSearchParams } from 'angular2/http'; | ||
3 | import { Observable, Subject } from 'rxjs/Rx'; | ||
4 | |||
5 | import { Token } from '../models/token'; | ||
6 | import { AuthStatus } from '../models/authStatus'; | ||
7 | |||
8 | @Injectable() | ||
9 | export class AuthService { | ||
10 | private _loginChanged = new Subject<AuthStatus>(); | ||
11 | |||
12 | private _baseLoginUrl = '/api/v1/users/token'; | ||
13 | private _clientId = '56f055587305d40b21904240'; | ||
14 | private _clientSecret = 'megustalabanana'; | ||
15 | |||
16 | loginChanged$ = this._loginChanged.asObservable(); | ||
17 | |||
18 | constructor (private http: Http) {} | ||
19 | |||
20 | login(username: string, password: string) { | ||
21 | let body = new URLSearchParams(); | ||
22 | body.set('client_id', this._clientId); | ||
23 | body.set('client_secret', this._clientSecret); | ||
24 | body.set('response_type', 'code'); | ||
25 | body.set('grant_type', 'password'); | ||
26 | body.set('scope', 'upload'); | ||
27 | body.set('username', username); | ||
28 | body.set('password', password); | ||
29 | |||
30 | let headers = new Headers(); | ||
31 | headers.append('Content-Type', 'application/x-www-form-urlencoded'); | ||
32 | |||
33 | let options = { | ||
34 | headers: headers | ||
35 | } | ||
36 | |||
37 | return this.http.post(this._baseLoginUrl, body.toString(), options) | ||
38 | .map(res => res.json()) | ||
39 | .catch(this.handleError); | ||
40 | } | ||
41 | |||
42 | logout() { | ||
43 | // TODO make HTTP request | ||
44 | } | ||
45 | |||
46 | setStatus(status: AuthStatus) { | ||
47 | this._loginChanged.next(status); | ||
48 | } | ||
49 | |||
50 | private handleError (error: Response) { | ||
51 | console.error(error); | ||
52 | return Observable.throw(error.json().error || 'Server error'); | ||
53 | } | ||
54 | } | ||