-import { ServerService } from '../../../core'
-import { FormReactive } from '../../../shared'
-import { USER_ROLE_LABELS, VideoResolution } from '../../../../../../shared'
-
-export abstract class UserEdit extends FormReactive {
- videoQuotaOptions = [
- { value: -1, label: 'Unlimited' },
- { value: 0, label: '0'},
- { value: 100 * 1024 * 1024, label: '100MB' },
- { value: 500 * 1024 * 1024, label: '500MB' },
- { value: 1024 * 1024 * 1024, label: '1GB' },
- { value: 5 * 1024 * 1024 * 1024, label: '5GB' },
- { value: 20 * 1024 * 1024 * 1024, label: '20GB' },
- { value: 50 * 1024 * 1024 * 1024, label: '50GB' }
- ]
-
- roles = Object.keys(USER_ROLE_LABELS).map(key => ({ value: key, label: USER_ROLE_LABELS[key] }))
+import { Directive, OnInit } from '@angular/core'
+import { ConfigService } from '@app/+admin/config/shared/config.service'
+import { AuthService, ScreenService, ServerService, User } from '@app/core'
+import { FormReactive } from '@app/shared/shared-forms'
+import { USER_ROLE_LABELS } from '@shared/core-utils/users'
+import { HTMLServerConfig, UserAdminFlag, UserRole, VideoResolution } from '@shared/models'
+import { SelectOptionsItem } from '../../../../types/select-options-item.model'
+
+@Directive()
+// tslint:disable-next-line: directive-class-suffix
+export abstract class UserEdit extends FormReactive implements OnInit {
+ videoQuotaOptions: SelectOptionsItem[] = []
+ videoQuotaDailyOptions: SelectOptionsItem[] = []
+ username: string
+ user: User
+
+ roles: { value: string, label: string }[] = []
+
+ protected serverConfig: HTMLServerConfig
protected abstract serverService: ServerService
+ protected abstract configService: ConfigService
+ protected abstract screenService: ScreenService
+ protected abstract auth: AuthService
abstract isCreation (): boolean
abstract getFormButtonTitle (): string
+ ngOnInit (): void {
+ this.serverConfig = this.serverService.getHTMLConfig()
+
+ this.buildRoles()
+ }
+
+ get subscribersCount () {
+ const forAccount = this.user
+ ? this.user.account.followersCount
+ : 0
+ const forChannels = this.user
+ ? this.user.videoChannels.map(c => c.followersCount).reduce((a, b) => a + b, 0)
+ : 0
+ return forAccount + forChannels
+ }
+
+ getAuthPlugins () {
+ return this.serverConfig.plugin.registeredIdAndPassAuths.map(p => p.npmName)
+ .concat(this.serverConfig.plugin.registeredExternalAuths.map(p => p.npmName))
+ }
+
+ isInBigView () {
+ return this.screenService.getWindowInnerWidth() > 1600
+ }
+
+ buildRoles () {
+ const authUser = this.auth.getUser()
+
+ if (authUser.role === UserRole.ADMINISTRATOR) {
+ this.roles = Object.keys(USER_ROLE_LABELS)
+ .map(key => ({ value: key.toString(), label: USER_ROLE_LABELS[key] }))
+ return
+ }
+
+ this.roles = [
+ { value: UserRole.USER.toString(), label: USER_ROLE_LABELS[UserRole.USER] }
+ ]
+ }
+
isTranscodingInformationDisplayed () {
const formVideoQuota = parseInt(this.form.value['videoQuota'], 10)
- return this.serverService.getConfig().transcoding.enabledResolutions.length !== 0 &&
+ return this.serverConfig.transcoding.enabledResolutions.length !== 0 &&
formVideoQuota > 0
}
computeQuotaWithTranscoding () {
- const resolutions = this.serverService.getConfig().transcoding.enabledResolutions
- const higherResolution = VideoResolution.H_1080P
+ const transcodingConfig = this.serverConfig.transcoding
+
+ const resolutions = transcodingConfig.enabledResolutions
+ const higherResolution = VideoResolution.H_4K
let multiplier = 0
for (const resolution of resolutions) {
multiplier += resolution / higherResolution
}
+ if (transcodingConfig.hls.enabled) multiplier *= 2
+
return multiplier * parseInt(this.form.value['videoQuota'], 10)
}
+
+ resetPassword () {
+ return
+ }
+
+ protected buildAdminFlags (formValue: any) {
+ return formValue.byPassAutoBlock ? UserAdminFlag.BYPASS_VIDEO_AUTO_BLACKLIST : UserAdminFlag.NONE
+ }
+
+ protected buildQuotaOptions () {
+ this.videoQuotaOptions = this.configService.videoQuotaOptions
+ this.videoQuotaDailyOptions = this.configService.videoQuotaDailyOptions
+ }
}