PeerTube/client/src/app/core/auth/auth-user.model.ts

139 lines
3.8 KiB
TypeScript
Raw Normal View History

// Do not use the barrel (dependency loop)
import { hasUserRight, UserRole } from '../../../../../shared/models/users/user-role'
2017-10-25 17:31:11 +02:00
import { User, UserConstructorHash } from '../../shared/users/user.model'
import { UserRight } from '../../../../../shared/models/users/user-right.enum'
export type TokenOptions = {
accessToken: string
refreshToken: string
tokenType: string
}
// Private class only used by User
class Tokens {
private static KEYS = {
ACCESS_TOKEN: 'access_token',
REFRESH_TOKEN: 'refresh_token',
TOKEN_TYPE: 'token_type'
}
accessToken: string
refreshToken: string
tokenType: string
static load () {
const accessTokenLocalStorage = localStorage.getItem(this.KEYS.ACCESS_TOKEN)
const refreshTokenLocalStorage = localStorage.getItem(this.KEYS.REFRESH_TOKEN)
const tokenTypeLocalStorage = localStorage.getItem(this.KEYS.TOKEN_TYPE)
if (accessTokenLocalStorage && refreshTokenLocalStorage && tokenTypeLocalStorage) {
return new Tokens({
accessToken: accessTokenLocalStorage,
refreshToken: refreshTokenLocalStorage,
tokenType: tokenTypeLocalStorage
})
}
return null
}
static flush () {
localStorage.removeItem(this.KEYS.ACCESS_TOKEN)
localStorage.removeItem(this.KEYS.REFRESH_TOKEN)
localStorage.removeItem(this.KEYS.TOKEN_TYPE)
}
constructor (hash?: TokenOptions) {
if (hash) {
this.accessToken = hash.accessToken
this.refreshToken = hash.refreshToken
if (hash.tokenType === 'bearer') {
this.tokenType = 'Bearer'
} else {
this.tokenType = hash.tokenType
}
}
}
save () {
localStorage.setItem(Tokens.KEYS.ACCESS_TOKEN, this.accessToken)
localStorage.setItem(Tokens.KEYS.REFRESH_TOKEN, this.refreshToken)
localStorage.setItem(Tokens.KEYS.TOKEN_TYPE, this.tokenType)
}
}
2016-08-09 21:45:21 +02:00
export class AuthUser extends User {
private static KEYS = {
2016-08-05 18:04:08 +02:00
ID: 'id',
ROLE: 'role',
2017-06-11 11:29:03 +02:00
EMAIL: 'email',
2017-04-04 21:37:03 +02:00
USERNAME: 'username',
DISPLAY_NSFW: 'display_nsfw'
}
tokens: Tokens
static load () {
const usernameLocalStorage = localStorage.getItem(this.KEYS.USERNAME)
if (usernameLocalStorage) {
2016-08-09 21:45:21 +02:00
return new AuthUser(
{
id: parseInt(localStorage.getItem(this.KEYS.ID), 10),
2016-08-09 21:45:21 +02:00
username: localStorage.getItem(this.KEYS.USERNAME),
2017-06-11 11:29:03 +02:00
email: localStorage.getItem(this.KEYS.EMAIL),
role: parseInt(localStorage.getItem(this.KEYS.ROLE), 10) as UserRole,
2017-04-04 21:37:03 +02:00
displayNSFW: localStorage.getItem(this.KEYS.DISPLAY_NSFW) === 'true'
2016-08-09 21:45:21 +02:00
},
2016-08-05 18:04:08 +02:00
Tokens.load()
)
}
return null
}
static flush () {
localStorage.removeItem(this.KEYS.USERNAME)
localStorage.removeItem(this.KEYS.ID)
localStorage.removeItem(this.KEYS.ROLE)
localStorage.removeItem(this.KEYS.DISPLAY_NSFW)
2017-07-11 10:09:18 +02:00
localStorage.removeItem(this.KEYS.EMAIL)
Tokens.flush()
}
2017-10-25 17:31:11 +02:00
constructor (userHash: UserConstructorHash, hashTokens: TokenOptions) {
super(userHash)
this.tokens = new Tokens(hashTokens)
}
getAccessToken () {
return this.tokens.accessToken
}
getRefreshToken () {
return this.tokens.refreshToken
}
getTokenType () {
return this.tokens.tokenType
}
refreshTokens (accessToken: string, refreshToken: string) {
this.tokens.accessToken = accessToken
this.tokens.refreshToken = refreshToken
}
hasRight(right: UserRight) {
return hasUserRight(this.role, right)
}
save () {
localStorage.setItem(AuthUser.KEYS.ID, this.id.toString())
localStorage.setItem(AuthUser.KEYS.USERNAME, this.username)
2017-07-11 10:09:18 +02:00
localStorage.setItem(AuthUser.KEYS.EMAIL, this.email)
localStorage.setItem(AuthUser.KEYS.ROLE, this.role.toString())
localStorage.setItem(AuthUser.KEYS.DISPLAY_NSFW, JSON.stringify(this.displayNSFW))
this.tokens.save()
}
}