1 import { Observable, of } from 'rxjs'
2 import { map } from 'rxjs/operators'
3 import { User } from '@app/core/users/user.model'
4 import { peertubeLocalStorage } from '@root-helpers/peertube-web-storage'
5 import { hasUserRight } from '@shared/core-utils/users'
7 MyUser as ServerMyUserModel,
10 User as ServerUserModel,
14 } from '@shared/models'
15 import { TokenOptions, Tokens } from '@root-helpers/pure-auth-user.model'
17 export class AuthUser extends User implements ServerMyUserModel {
19 specialPlaylists: MyUserSpecialPlaylist[]
21 canSeeVideosLink = true
24 const usernameLocalStorage = peertubeLocalStorage.getItem(this.KEYS.USERNAME)
25 if (usernameLocalStorage) {
28 id: parseInt(peertubeLocalStorage.getItem(this.KEYS.ID), 10),
29 username: peertubeLocalStorage.getItem(this.KEYS.USERNAME),
30 email: peertubeLocalStorage.getItem(this.KEYS.EMAIL),
31 role: parseInt(peertubeLocalStorage.getItem(this.KEYS.ROLE), 10) as UserRole,
32 nsfwPolicy: peertubeLocalStorage.getItem(this.KEYS.NSFW_POLICY) as NSFWPolicyType,
33 webTorrentEnabled: peertubeLocalStorage.getItem(this.KEYS.WEBTORRENT_ENABLED) === 'true',
34 autoPlayVideo: peertubeLocalStorage.getItem(this.KEYS.AUTO_PLAY_VIDEO) === 'true',
35 videosHistoryEnabled: peertubeLocalStorage.getItem(this.KEYS.VIDEOS_HISTORY_ENABLED) === 'true'
45 peertubeLocalStorage.removeItem(this.KEYS.USERNAME)
46 peertubeLocalStorage.removeItem(this.KEYS.ID)
47 peertubeLocalStorage.removeItem(this.KEYS.ROLE)
48 peertubeLocalStorage.removeItem(this.KEYS.EMAIL)
52 constructor (userHash: Partial<ServerMyUserModel>, hashTokens: TokenOptions) {
55 this.tokens = new Tokens(hashTokens)
56 this.specialPlaylists = userHash.specialPlaylists
60 return this.tokens.accessToken
64 return this.tokens.refreshToken
68 return this.tokens.tokenType
71 refreshTokens (accessToken: string, refreshToken: string) {
72 this.tokens.accessToken = accessToken
73 this.tokens.refreshToken = refreshToken
76 hasRight (right: UserRight) {
77 return hasUserRight(this.role, right)
80 canManage (user: ServerUserModel) {
81 const myRole = this.role
83 if (myRole === UserRole.ADMINISTRATOR) return true
85 // I'm a moderator: I can only manage users
86 return user.role === UserRole.USER
90 peertubeLocalStorage.setItem(AuthUser.KEYS.ID, this.id.toString())
91 peertubeLocalStorage.setItem(AuthUser.KEYS.USERNAME, this.username)
92 peertubeLocalStorage.setItem(AuthUser.KEYS.EMAIL, this.email)
93 peertubeLocalStorage.setItem(AuthUser.KEYS.ROLE, this.role.toString())
94 peertubeLocalStorage.setItem(AuthUser.KEYS.NSFW_POLICY, this.nsfwPolicy.toString())
95 peertubeLocalStorage.setItem(AuthUser.KEYS.WEBTORRENT_ENABLED, JSON.stringify(this.webTorrentEnabled))
96 peertubeLocalStorage.setItem(AuthUser.KEYS.AUTO_PLAY_VIDEO, JSON.stringify(this.autoPlayVideo))
100 computeCanSeeVideosLink (quotaObservable: Observable<UserVideoQuota>): Observable<boolean> {
101 if (!this.isUploadDisabled()) {
102 this.canSeeVideosLink = true
103 return of(this.canSeeVideosLink)
106 // Check if the user has videos
107 return quotaObservable.pipe(
108 map(({ videoQuotaUsed }) => {
109 if (videoQuotaUsed !== 0) {
110 // User already uploaded videos, so it can see the link
111 this.canSeeVideosLink = true
113 // No videos, no upload so the user don't need to see the videos link
114 this.canSeeVideosLink = false
117 return this.canSeeVideosLink