-import {
- Account as AccountServerModel,
- hasUserRight,
- User as UserServerModel,
- UserRight,
- UserRole,
- VideoChannel
-} from '../../../../../shared'
+import { hasUserRight, User as UserServerModel, UserNotificationSetting, 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'
-import { WebTorrentPolicyType } from '../../../../../shared/models/users/user-webtorrent-policy.type'
-
-export type UserConstructorHash = {
- id: number,
- username: string,
- email: string,
- role: UserRole,
- videoQuota?: number,
- videoQuotaDaily?: number,
- nsfwPolicy?: NSFWPolicyType,
- webTorrentPolicy?: WebTorrentPolicyType,
- autoPlayVideo?: boolean,
- createdAt?: Date,
- account?: AccountServerModel,
- videoChannels?: VideoChannel[]
+import { UserAdminFlag } from '@shared/models/users/user-flag.model'
- blocked?: boolean
- blockedReason?: string
-}
export class User implements UserServerModel {
id: number
username: string
email: string
- role: UserRole
+ pendingEmail: string | null
+
+ emailVerified: boolean
nsfwPolicy: NSFWPolicyType
- webTorrentPolicy: WebTorrentPolicyType
+
+ adminFlags?: UserAdminFlag
+
autoPlayVideo: boolean
+ autoPlayNextVideo: boolean
+ webTorrentEnabled: boolean
+ videosHistoryEnabled: boolean
+ videoLanguages: string[]
+
+ role: UserRole
+ roleLabel: string
+
videoQuota: number
videoQuotaDaily: number
+ videoQuotaUsed?: number
+ videoQuotaUsedDaily?: number
+
+ theme: string
+
account: Account
- videoChannels: VideoChannel[]
- createdAt: Date
+ notificationSettings?: UserNotificationSetting
+ videoChannels?: VideoChannel[]
blocked: boolean
blockedReason?: string
- constructor (hash: UserConstructorHash) {
+ noInstanceConfigWarningModal: boolean
+ noWelcomeModal: boolean
+
+ createdAt: Date
+
+ constructor (hash: Partial<UserServerModel>) {
this.id = hash.id
this.username = hash.username
this.email = hash.email
+
this.role = hash.role
this.videoChannels = hash.videoChannels
+
this.videoQuota = hash.videoQuota
this.videoQuotaDaily = hash.videoQuotaDaily
+ this.videoQuotaUsed = hash.videoQuotaUsed
+ this.videoQuotaUsedDaily = hash.videoQuotaUsedDaily
+
this.nsfwPolicy = hash.nsfwPolicy
- this.webTorrentPolicy = hash.webTorrentPolicy
+ this.webTorrentEnabled = hash.webTorrentEnabled
+ this.videosHistoryEnabled = hash.videosHistoryEnabled
this.autoPlayVideo = hash.autoPlayVideo
- this.createdAt = hash.createdAt
+
+ this.theme = hash.theme
+
+ this.adminFlags = hash.adminFlags
+
this.blocked = hash.blocked
this.blockedReason = hash.blockedReason
+ this.noInstanceConfigWarningModal = hash.noInstanceConfigWarningModal
+ this.noWelcomeModal = hash.noWelcomeModal
+
+ this.notificationSettings = hash.notificationSettings
+
+ this.createdAt = hash.createdAt
+
if (hash.account !== undefined) {
this.account = new Account(hash.account)
}