-export class User {
- id: string;
- username: string;
- role: string;
- createdDate: Date;
-
- constructor(hash: { id: string, username: string, role: string, createdDate?: Date }) {
- this.id = hash.id;
- this.username = hash.username;
- this.role = hash.role;
-
- if (hash.createdDate) {
- this.createdDate = hash.createdDate;
+import { hasUserRight, User as UserServerModel, UserRight, UserRole, VideoChannel } from '../../../../../shared'
+import { Account } from '../account/account.model'
+import { NSFWPolicyType } from '../../../../../shared/models/videos/nsfw-policy.type'
+
+export type UserConstructorHash = {
+ id: number,
+ username: string,
+ email: string,
+ role: UserRole,
+ videoQuota?: number,
+ nsfwPolicy?: NSFWPolicyType,
+ autoPlayVideo?: boolean,
+ createdAt?: Date,
+ account?: Account,
+ videoChannels?: VideoChannel[]
+}
+export class User implements UserServerModel {
+ id: number
+ username: string
+ email: string
+ role: UserRole
+ nsfwPolicy: NSFWPolicyType
+ autoPlayVideo: boolean
+ videoQuota: number
+ account: Account
+ videoChannels: VideoChannel[]
+ createdAt: Date
+
+ constructor (hash: UserConstructorHash) {
+ this.id = hash.id
+ this.username = hash.username
+ this.email = hash.email
+ this.role = hash.role
+ this.account = hash.account
+
+ if (hash.videoChannels !== undefined) {
+ this.videoChannels = hash.videoChannels