-import {
- User as UserServerModel,
- UserRole,
- VideoChannel,
- UserRight,
- hasUserRight
-} from '../../../../../shared'
+import { hasUserRight, User as UserServerModel, UserRight, UserRole, VideoChannel } from '../../../../../shared'
+import { NSFWPolicyType } from '../../../../../shared/models/videos/nsfw-policy.type'
+import { Account } from '@app/shared/account/account.model'
+import { Avatar } from '../../../../../shared/models/avatars/avatar.model'
-export type UserConstructorHash = {
- id: number,
- username: string,
- email: string,
- role: UserRole,
- videoQuota?: number,
- displayNSFW?: boolean,
- createdAt?: Date,
- author?: {
- id: number
- uuid: string
- },
- videoChannels?: VideoChannel[]
-}
export class User implements UserServerModel {
id: number
username: string
email: string
+ emailVerified: boolean
role: UserRole
- displayNSFW: boolean
+ nsfwPolicy: NSFWPolicyType
+
+ webTorrentEnabled: boolean
+ autoPlayVideo: boolean
+ videosHistoryEnabled: boolean
+
videoQuota: number
- author: {
- id: number
- uuid: string
- }
+ videoQuotaDaily: number
+ account: Account
videoChannels: VideoChannel[]
createdAt: Date
- constructor (hash: UserConstructorHash) {
+ blocked: boolean
+ blockedReason?: string
+
+ constructor (hash: Partial<UserServerModel>) {
this.id = hash.id
this.username = hash.username
this.email = hash.email
this.role = hash.role
- this.author = hash.author
- if (hash.videoChannels !== undefined) {
- this.videoChannels = hash.videoChannels
- }
+ this.videoChannels = hash.videoChannels
+ this.videoQuota = hash.videoQuota
+ this.videoQuotaDaily = hash.videoQuotaDaily
+ this.nsfwPolicy = hash.nsfwPolicy
+ this.webTorrentEnabled = hash.webTorrentEnabled
+ this.videosHistoryEnabled = hash.videosHistoryEnabled
+ this.autoPlayVideo = hash.autoPlayVideo
+ this.createdAt = hash.createdAt
+ this.blocked = hash.blocked
+ this.blockedReason = hash.blockedReason
- if (hash.videoQuota !== undefined) {
- this.videoQuota = hash.videoQuota
+ if (hash.account !== undefined) {
+ this.account = new Account(hash.account)
}
+ }
- if (hash.displayNSFW !== undefined) {
- this.displayNSFW = hash.displayNSFW
- }
+ get accountAvatarUrl () {
+ if (!this.account) return ''
- if (hash.createdAt !== undefined) {
- this.createdAt = hash.createdAt
- }
+ return this.account.avatarUrl
}
hasRight (right: UserRight) {
return hasUserRight(this.role, right)
}
+
+ patch (obj: UserServerModel) {
+ for (const key of Object.keys(obj)) {
+ this[key] = obj[key]
+ }
+
+ if (obj.account !== undefined) {
+ this.account = new Account(obj.account)
+ }
+ }
+
+ updateAccountAvatar (newAccountAvatar: Avatar) {
+ this.account.updateAvatar(newAccountAvatar)
+ }
}