Reorganize plugin models

This commit is contained in:
Chocobozzz 2021-05-11 12:04:47 +02:00
parent 2b02c520e6
commit 428ccb8b7a
No known key found for this signature in database
GPG Key ID: 583A612D890159BE
48 changed files with 113 additions and 112 deletions

View File

@ -5,8 +5,7 @@ import { PluginApiService } from '@app/+admin/plugins/shared/plugin-api.service'
import { ComponentPagination, ConfirmService, hasMoreItems, Notifier } from '@app/core' import { ComponentPagination, ConfirmService, hasMoreItems, Notifier } from '@app/core'
import { PluginService } from '@app/core/plugins/plugin.service' import { PluginService } from '@app/core/plugins/plugin.service'
import { compareSemVer } from '@shared/core-utils/miscs/miscs' import { compareSemVer } from '@shared/core-utils/miscs/miscs'
import { PeerTubePlugin } from '@shared/models/plugins/peertube-plugin.model' import { PeerTubePlugin, PluginType } from '@shared/models'
import { PluginType } from '@shared/models/plugins/plugin.type'
@Component({ @Component({
selector: 'my-plugin-list-installed', selector: 'my-plugin-list-installed',

View File

@ -4,8 +4,7 @@ import { Component, OnInit } from '@angular/core'
import { ActivatedRoute, Router } from '@angular/router' import { ActivatedRoute, Router } from '@angular/router'
import { PluginApiService } from '@app/+admin/plugins/shared/plugin-api.service' import { PluginApiService } from '@app/+admin/plugins/shared/plugin-api.service'
import { ComponentPagination, ConfirmService, hasMoreItems, Notifier, PluginService } from '@app/core' import { ComponentPagination, ConfirmService, hasMoreItems, Notifier, PluginService } from '@app/core'
import { PeerTubePluginIndex } from '@shared/models/plugins/peertube-plugin-index.model' import { PeerTubePluginIndex, PluginType } from '@shared/models'
import { PluginType } from '@shared/models/plugins/plugin.type'
@Component({ @Component({
selector: 'my-plugin-search', selector: 'my-plugin-search',

View File

@ -21,8 +21,15 @@ import {
import { FormReactiveValidationMessages, FormValidatorService } from '@app/shared/shared-forms' import { FormReactiveValidationMessages, FormValidatorService } from '@app/shared/shared-forms'
import { InstanceService } from '@app/shared/shared-instance' import { InstanceService } from '@app/shared/shared-instance'
import { VideoCaptionEdit, VideoEdit, VideoService } from '@app/shared/shared-main' import { VideoCaptionEdit, VideoEdit, VideoService } from '@app/shared/shared-main'
import { LiveVideo, ServerConfig, VideoConstant, VideoDetails, VideoPrivacy } from '@shared/models' import {
import { RegisterClientFormFieldOptions, RegisterClientVideoFieldOptions } from '@shared/models/plugins/register-client-form-field.model' LiveVideo,
RegisterClientFormFieldOptions,
RegisterClientVideoFieldOptions,
ServerConfig,
VideoConstant,
VideoDetails,
VideoPrivacy
} from '@shared/models'
import { I18nPrimengCalendarService } from './i18n-primeng-calendar.service' import { I18nPrimengCalendarService } from './i18n-primeng-calendar.service'
import { VideoCaptionAddModalComponent } from './video-caption-add-modal.component' import { VideoCaptionAddModalComponent } from './video-caption-add-modal.component'
import { VideoEditType } from './video-edit.type' import { VideoEditType } from './video-edit.type'

View File

@ -1,14 +1,15 @@
import { RegisterClientHelpers } from 'src/types/register-client-option.model' import { RegisterClientHelpers } from 'src/types/register-client-option.model'
import { getHookType, internalRunHook } from '@shared/core-utils/plugins/hooks' import { getHookType, internalRunHook } from '@shared/core-utils/plugins/hooks'
import { RegisterClientFormFieldOptions, RegisterClientVideoFieldOptions } from '@shared/models/plugins/register-client-form-field.model'
import { import {
ClientHookName, ClientHookName,
clientHookObject, clientHookObject,
ClientScript, ClientScript,
PluginType, PluginType,
RegisterClientFormFieldOptions,
RegisterClientHookOptions, RegisterClientHookOptions,
ServerConfigPlugin, RegisterClientSettingsScript,
RegisterClientSettingsScript RegisterClientVideoFieldOptions,
ServerConfigPlugin
} from '../../../shared/models' } from '../../../shared/models'
import { ClientScript as ClientScriptModule } from '../types/client-script.model' import { ClientScript as ClientScriptModule } from '../types/client-script.model'
import { importModule } from './utils' import { importModule } from './utils'

View File

@ -1,16 +1,18 @@
import * as express from 'express' import * as express from 'express'
import { getFormattedObjects } from '../../helpers/utils' import { logger } from '@server/helpers/logger'
import { getFormattedObjects } from '@server/helpers/utils'
import { listAvailablePluginsFromIndex } from '@server/lib/plugins/plugin-index'
import { PluginManager } from '@server/lib/plugins/plugin-manager'
import { import {
asyncMiddleware, asyncMiddleware,
authenticate, authenticate,
availablePluginsSortValidator,
ensureUserHasRight, ensureUserHasRight,
paginationValidator, paginationValidator,
pluginsSortValidator,
setDefaultPagination, setDefaultPagination,
setDefaultSort setDefaultSort
} from '../../middlewares' } from '@server/middlewares'
import { availablePluginsSortValidator, pluginsSortValidator } from '../../middlewares/validators'
import { PluginModel } from '../../models/server/plugin'
import { UserRight } from '../../../shared/models/users'
import { import {
existingPluginValidator, existingPluginValidator,
installOrUpdatePluginValidator, installOrUpdatePluginValidator,
@ -18,16 +20,17 @@ import {
listPluginsValidator, listPluginsValidator,
uninstallPluginValidator, uninstallPluginValidator,
updatePluginSettingsValidator updatePluginSettingsValidator
} from '../../middlewares/validators/plugins' } from '@server/middlewares/validators/plugins'
import { PluginManager } from '../../lib/plugins/plugin-manager' import { PluginModel } from '@server/models/server/plugin'
import { InstallOrUpdatePlugin } from '../../../shared/models/plugins/install-plugin.model' import { HttpStatusCode } from '@shared/core-utils'
import { ManagePlugin } from '../../../shared/models/plugins/manage-plugin.model' import {
import { logger } from '../../helpers/logger' InstallOrUpdatePlugin,
import { listAvailablePluginsFromIndex } from '../../lib/plugins/plugin-index' ManagePlugin,
import { PeertubePluginIndexList } from '../../../shared/models/plugins/peertube-plugin-index-list.model' PeertubePluginIndexList,
import { RegisteredServerSettings } from '../../../shared/models/plugins/register-server-setting.model' PublicServerSetting,
import { PublicServerSetting } from '../../../shared/models/plugins/public-server.setting' RegisteredServerSettings,
import { HttpStatusCode } from '../../../shared/core-utils/miscs/http-error-codes' UserRight
} from '@shared/models'
const pluginRouter = express.Router() const pluginRouter = express.Router()

View File

@ -1,7 +1,7 @@
import { ServerActionHookName, ServerFilterHookName } from '../../../shared/models/plugins/server-hook.model'
import { PluginManager } from './plugin-manager'
import { logger } from '../../helpers/logger'
import * as Bluebird from 'bluebird' import * as Bluebird from 'bluebird'
import { ServerActionHookName, ServerFilterHookName } from '../../../shared/models'
import { logger } from '../../helpers/logger'
import { PluginManager } from './plugin-manager'
type PromiseFunction <U, T> = (params: U) => Promise<T> | Bluebird<T> type PromiseFunction <U, T> = (params: U) => Promise<T> | Bluebird<T>
type RawFunction <U, T> = (params: U) => T type RawFunction <U, T> = (params: U) => T

View File

@ -1,16 +1,16 @@
import { sanitizeUrl } from '@server/helpers/core-utils' import { sanitizeUrl } from '@server/helpers/core-utils'
import { ResultList } from '../../../shared/models' import { logger } from '@server/helpers/logger'
import { PeertubePluginIndexList } from '../../../shared/models/plugins/peertube-plugin-index-list.model' import { doJSONRequest } from '@server/helpers/requests'
import { PeerTubePluginIndex } from '../../../shared/models/plugins/peertube-plugin-index.model' import { CONFIG } from '@server/initializers/config'
import { PEERTUBE_VERSION } from '@server/initializers/constants'
import { PluginModel } from '@server/models/server/plugin'
import { import {
PeerTubePluginIndex,
PeertubePluginIndexList,
PeertubePluginLatestVersionRequest, PeertubePluginLatestVersionRequest,
PeertubePluginLatestVersionResponse PeertubePluginLatestVersionResponse,
} from '../../../shared/models/plugins/peertube-plugin-latest-version.model' ResultList
import { logger } from '../../helpers/logger' } from '@shared/models'
import { doJSONRequest } from '../../helpers/requests'
import { CONFIG } from '../../initializers/config'
import { PEERTUBE_VERSION } from '../../initializers/constants'
import { PluginModel } from '../../models/server/plugin'
import { PluginManager } from './plugin-manager' import { PluginManager } from './plugin-manager'
async function listAvailablePluginsFromIndex (options: PeertubePluginIndexList) { async function listAvailablePluginsFromIndex (options: PeertubePluginIndexList) {

View File

@ -4,16 +4,11 @@ import { createReadStream, createWriteStream } from 'fs'
import { ensureDir, outputFile, readJSON } from 'fs-extra' import { ensureDir, outputFile, readJSON } from 'fs-extra'
import { basename, join } from 'path' import { basename, join } from 'path'
import { MOAuthTokenUser, MUser } from '@server/types/models' import { MOAuthTokenUser, MUser } from '@server/types/models'
import { RegisterServerHookOptions } from '@shared/models/plugins/register-server-hook.model' import { getCompleteLocale } from '@shared/core-utils'
import { ClientScript, PluginPackageJson, PluginTranslation, PluginTranslationPaths, RegisterServerHookOptions } from '@shared/models'
import { getHookType, internalRunHook } from '../../../shared/core-utils/plugins/hooks' import { getHookType, internalRunHook } from '../../../shared/core-utils/plugins/hooks'
import {
ClientScript,
PluginPackageJson,
PluginTranslationPaths as PackagePluginTranslations
} from '../../../shared/models/plugins/plugin-package-json.model'
import { PluginTranslation } from '../../../shared/models/plugins/plugin-translation.model'
import { PluginType } from '../../../shared/models/plugins/plugin.type' import { PluginType } from '../../../shared/models/plugins/plugin.type'
import { ServerHook, ServerHookName } from '../../../shared/models/plugins/server-hook.model' import { ServerHook, ServerHookName } from '../../../shared/models/plugins/server/server-hook.model'
import { isLibraryCodeValid, isPackageJSONValid } from '../../helpers/custom-validators/plugins' import { isLibraryCodeValid, isPackageJSONValid } from '../../helpers/custom-validators/plugins'
import { logger } from '../../helpers/logger' import { logger } from '../../helpers/logger'
import { CONFIG } from '../../initializers/config' import { CONFIG } from '../../initializers/config'
@ -23,7 +18,6 @@ import { PluginLibrary, RegisterServerAuthExternalOptions, RegisterServerAuthPas
import { ClientHtml } from '../client-html' import { ClientHtml } from '../client-html'
import { RegisterHelpers } from './register-helpers' import { RegisterHelpers } from './register-helpers'
import { installNpmPlugin, installNpmPluginFromDisk, removeNpmPlugin } from './yarn' import { installNpmPlugin, installNpmPluginFromDisk, removeNpmPlugin } from './yarn'
import { getCompleteLocale } from '@shared/core-utils'
export interface RegisteredPlugin { export interface RegisteredPlugin {
npmName: string npmName: string
@ -443,7 +437,7 @@ export class PluginManager implements ServerHook {
// ###################### Translations ###################### // ###################### Translations ######################
private async addTranslations (plugin: PluginModel, npmName: string, translationPaths: PackagePluginTranslations) { private async addTranslations (plugin: PluginModel, npmName: string, translationPaths: PluginTranslationPaths) {
for (const locale of Object.keys(translationPaths)) { for (const locale of Object.keys(translationPaths)) {
const path = translationPaths[locale] const path = translationPaths[locale]
const json = await readJSON(join(this.getPluginPath(plugin.name, plugin.type), path)) const json = await readJSON(join(this.getPluginPath(plugin.name, plugin.type), path))

View File

@ -26,9 +26,9 @@ import {
PluginVideoLicenceManager, PluginVideoLicenceManager,
PluginVideoPrivacyManager, PluginVideoPrivacyManager,
RegisterServerHookOptions, RegisterServerHookOptions,
RegisterServerSettingOptions RegisterServerSettingOptions,
serverHookObject
} from '@shared/models' } from '@shared/models'
import { serverHookObject } from '@shared/models/plugins/server-hook.model'
import { VideoTranscodingProfilesManager } from '../transcoding/video-transcoding-profiles' import { VideoTranscodingProfilesManager } from '../transcoding/video-transcoding-profiles'
import { buildPluginHelpers } from './plugin-helpers-builder' import { buildPluginHelpers } from './plugin-helpers-builder'

View File

@ -1,15 +1,15 @@
import * as express from 'express' import * as express from 'express'
import { body, param, query, ValidationChain } from 'express-validator' import { body, param, query, ValidationChain } from 'express-validator'
import { logger } from '../../helpers/logger'
import { areValidationErrors } from './utils'
import { isNpmPluginNameValid, isPluginNameValid, isPluginTypeValid, isPluginVersionValid } from '../../helpers/custom-validators/plugins'
import { PluginManager } from '../../lib/plugins/plugin-manager'
import { isBooleanValid, isSafePath, toBooleanOrNull, exists, toIntOrNull } from '../../helpers/custom-validators/misc'
import { PluginModel } from '../../models/server/plugin'
import { InstallOrUpdatePlugin } from '../../../shared/models/plugins/install-plugin.model'
import { PluginType } from '../../../shared/models/plugins/plugin.type'
import { CONFIG } from '../../initializers/config'
import { HttpStatusCode } from '../../../shared/core-utils/miscs/http-error-codes' import { HttpStatusCode } from '../../../shared/core-utils/miscs/http-error-codes'
import { PluginType } from '../../../shared/models/plugins/plugin.type'
import { InstallOrUpdatePlugin } from '../../../shared/models/plugins/server/api/install-plugin.model'
import { exists, isBooleanValid, isSafePath, toBooleanOrNull, toIntOrNull } from '../../helpers/custom-validators/misc'
import { isNpmPluginNameValid, isPluginNameValid, isPluginTypeValid, isPluginVersionValid } from '../../helpers/custom-validators/plugins'
import { logger } from '../../helpers/logger'
import { CONFIG } from '../../initializers/config'
import { PluginManager } from '../../lib/plugins/plugin-manager'
import { PluginModel } from '../../models/server/plugin'
import { areValidationErrors } from './utils'
const getPluginValidator = (pluginType: PluginType, withVersion = true) => { const getPluginValidator = (pluginType: PluginType, withVersion = true) => {
const validators: (ValidationChain | express.Handler)[] = [ const validators: (ValidationChain | express.Handler)[] = [

View File

@ -1,9 +1,7 @@
import { FindAndCountOptions, json, QueryTypes } from 'sequelize' import { FindAndCountOptions, json, QueryTypes } from 'sequelize'
import { AllowNull, Column, CreatedAt, DataType, DefaultScope, Is, Model, Table, UpdatedAt } from 'sequelize-typescript' import { AllowNull, Column, CreatedAt, DataType, DefaultScope, Is, Model, Table, UpdatedAt } from 'sequelize-typescript'
import { MPlugin, MPluginFormattable } from '@server/types/models' import { MPlugin, MPluginFormattable } from '@server/types/models'
import { PeerTubePlugin } from '../../../shared/models/plugins/peertube-plugin.model' import { PeerTubePlugin, PluginType, RegisterServerSettingOptions } from '../../../shared/models'
import { PluginType } from '../../../shared/models/plugins/plugin.type'
import { RegisterServerSettingOptions } from '../../../shared/models/plugins/register-server-setting.model'
import { import {
isPluginDescriptionValid, isPluginDescriptionValid,
isPluginHomepage, isPluginHomepage,

View File

@ -1,7 +1,7 @@
/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */ /* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
import 'mocha' import 'mocha'
import { HttpStatusCode } from '@shared/core-utils'
import { import {
checkBadCountPagination, checkBadCountPagination,
checkBadSortPagination, checkBadSortPagination,
@ -11,14 +11,14 @@ import {
flushAndRunServer, flushAndRunServer,
immutableAssign, immutableAssign,
installPlugin, installPlugin,
makeGetRequest, makePostBodyRequest, makePutBodyRequest, makeGetRequest,
makePostBodyRequest,
makePutBodyRequest,
ServerInfo, ServerInfo,
setAccessTokensToServers, setAccessTokensToServers,
userLogin userLogin
} from '../../../../shared/extra-utils' } from '@shared/extra-utils'
import { PluginType } from '../../../../shared/models/plugins/plugin.type' import { PeerTubePlugin, PluginType } from '@shared/models'
import { PeerTubePlugin } from '../../../../shared/models/plugins/peertube-plugin.model'
import { HttpStatusCode } from '../../../../shared/core-utils/miscs/http-error-codes'
describe('Test server plugins API validators', function () { describe('Test server plugins API validators', function () {
let server: ServerInfo let server: ServerInfo

View File

@ -28,14 +28,8 @@ import {
updatePluginSettings, updatePluginSettings,
wait, wait,
waitUntilLog waitUntilLog
} from '../../../../shared/extra-utils' } from '@shared/extra-utils'
import { PeerTubePluginIndex } from '../../../../shared/models/plugins/peertube-plugin-index.model' import { PeerTubePlugin, PeerTubePluginIndex, PluginPackageJson, PluginType, PublicServerSetting, ServerConfig, User } from '@shared/models'
import { PeerTubePlugin } from '../../../../shared/models/plugins/peertube-plugin.model'
import { PluginPackageJson } from '../../../../shared/models/plugins/plugin-package-json.model'
import { PluginType } from '../../../../shared/models/plugins/plugin.type'
import { PublicServerSetting } from '../../../../shared/models/plugins/public-server.setting'
import { ServerConfig } from '../../../../shared/models/server'
import { User } from '../../../../shared/models/users'
const expect = chai.expect const expect = chai.expect

View File

@ -4,10 +4,9 @@ import { registerTSPaths } from '../helpers/register-ts-paths'
registerTSPaths() registerTSPaths()
import * as program from 'commander' import * as program from 'commander'
import { PluginType } from '../../shared/models/plugins/plugin.type'
import { installPlugin, listPlugins, uninstallPlugin, updatePlugin } from '../../shared/extra-utils/server/plugins' import { installPlugin, listPlugins, uninstallPlugin, updatePlugin } from '../../shared/extra-utils/server/plugins'
import { getAdminTokenOrDie, getServerCredentials } from './cli' import { getAdminTokenOrDie, getServerCredentials } from './cli'
import { PeerTubePlugin } from '../../shared/models/plugins/peertube-plugin.model' import { PeerTubePlugin, PluginType } from '../../shared/models'
import { isAbsolute } from 'path' import { isAbsolute } from 'path'
import * as CliTable3 from 'cli-table3' import * as CliTable3 from 'cli-table3'
import commander = require('commander') import commander = require('commander')

View File

@ -4,12 +4,12 @@ import { expect } from 'chai'
import { readJSON, writeJSON } from 'fs-extra' import { readJSON, writeJSON } from 'fs-extra'
import { join } from 'path' import { join } from 'path'
import { RegisteredServerSettings } from '@shared/models' import { RegisteredServerSettings } from '@shared/models'
import { PeertubePluginIndexList } from '../../models/plugins/peertube-plugin-index-list.model' import { HttpStatusCode } from '../../../shared/core-utils/miscs/http-error-codes'
import { PeertubePluginIndexList } from '../../models/plugins/plugin-index/peertube-plugin-index-list.model'
import { PluginType } from '../../models/plugins/plugin.type' import { PluginType } from '../../models/plugins/plugin.type'
import { buildServerDirectory, root } from '../miscs/miscs' import { buildServerDirectory, root } from '../miscs/miscs'
import { makeGetRequest, makePostBodyRequest, makePutBodyRequest } from '../requests/requests' import { makeGetRequest, makePostBodyRequest, makePutBodyRequest } from '../requests/requests'
import { ServerInfo } from './servers' import { ServerInfo } from './servers'
import { HttpStatusCode } from '../../../shared/core-utils/miscs/http-error-codes'
function listPlugins (parameters: { function listPlugins (parameters: {
url: string url: string

View File

@ -0,0 +1,6 @@
export * from './client-hook.model'
export * from './plugin-client-scope.type'
export * from './plugin-element-placeholder.type'
export * from './register-client-form-field.model'
export * from './register-client-hook.model'
export * from './register-client-settings-script.model'

View File

@ -1,4 +1,4 @@
import { RegisterServerSettingOptions } from "./register-server-setting.model" import { RegisterServerSettingOptions } from '../server'
export interface RegisterClientSettingsScript { export interface RegisterClientSettingsScript {
isSettingHidden (options: { isSettingHidden (options: {

View File

@ -1,28 +1,6 @@
export * from './client-hook.model' export * from './client'
export * from './plugin-index'
export * from './server'
export * from './hook-type.enum' export * from './hook-type.enum'
export * from './install-plugin.model'
export * from './manage-plugin.model'
export * from './peertube-plugin-index-list.model'
export * from './peertube-plugin-index.model'
export * from './peertube-plugin-latest-version.model'
export * from './peertube-plugin.model'
export * from './plugin-client-scope.type'
export * from './plugin-element-placeholder.type'
export * from './plugin-package-json.model' export * from './plugin-package-json.model'
export * from './plugin-playlist-privacy-manager.model'
export * from './plugin-settings-manager.model'
export * from './plugin-storage-manager.model'
export * from './plugin-transcoding-manager.model'
export * from './plugin-translation.model'
export * from './plugin-video-category-manager.model'
export * from './plugin-video-language-manager.model'
export * from './plugin-video-licence-manager.model'
export * from './plugin-video-privacy-manager.model'
export * from './plugin.type' export * from './plugin.type'
export * from './public-server.setting'
export * from './register-client-hook.model'
export * from './register-client-settings-script.model'
export * from './register-client-form-field.model'
export * from './register-server-hook.model'
export * from './register-server-setting.model'
export * from './server-hook.model'

View File

@ -0,0 +1,3 @@
export * from './peertube-plugin-index-list.model'
export * from './peertube-plugin-index.model'
export * from './peertube-plugin-latest-version.model'

View File

@ -1,4 +1,4 @@
import { PluginType } from './plugin.type' import { PluginType } from '../plugin.type'
export interface PeertubePluginIndexList { export interface PeertubePluginIndexList {
start: number start: number

View File

@ -1,4 +1,4 @@
import { PluginClientScope } from './plugin-client-scope.type' import { PluginClientScope } from './client/plugin-client-scope.type'
export type PluginTranslationPaths = { export type PluginTranslationPaths = {
[ locale: string ]: string [ locale: string ]: string

View File

@ -0,0 +1,3 @@
export * from './install-plugin.model'
export * from './manage-plugin.model'
export * from './peertube-plugin.model'

View File

@ -1,4 +1,4 @@
import { PluginType } from './plugin.type' import { PluginType } from '../../plugin.type'
export interface PeerTubePlugin { export interface PeerTubePlugin {
name: string name: string

View File

@ -0,0 +1,6 @@
export * from './api'
export * from './managers'
export * from './settings'
export * from './plugin-translation.model'
export * from './register-server-hook.model'
export * from './server-hook.model'

View File

@ -0,0 +1,9 @@
export * from './plugin-playlist-privacy-manager.model'
export * from './plugin-settings-manager.model'
export * from './plugin-storage-manager.model'
export * from './plugin-transcoding-manager.model'
export * from './plugin-video-category-manager.model'
export * from './plugin-video-language-manager.model'
export * from './plugin-video-licence-manager.model'
export * from './plugin-video-privacy-manager.model'

View File

@ -1,4 +1,4 @@
import { VideoPlaylistPrivacy } from '../videos/playlist/video-playlist-privacy.model' import { VideoPlaylistPrivacy } from '../../../videos/playlist/video-playlist-privacy.model'
export interface PluginPlaylistPrivacyManager { export interface PluginPlaylistPrivacyManager {
// PUBLIC = 1, // PUBLIC = 1,

View File

@ -1,4 +1,4 @@
import { EncoderOptionsBuilder } from '../videos/video-transcoding.model' import { EncoderOptionsBuilder } from '../../../videos/video-transcoding.model'
export interface PluginTranscodingManager { export interface PluginTranscodingManager {
addLiveProfile (encoder: string, profile: string, builder: EncoderOptionsBuilder): boolean addLiveProfile (encoder: string, profile: string, builder: EncoderOptionsBuilder): boolean

View File

@ -1,4 +1,4 @@
import { VideoPrivacy } from '../videos/video-privacy.enum' import { VideoPrivacy } from '../../../videos/video-privacy.enum'
export interface PluginVideoPrivacyManager { export interface PluginVideoPrivacyManager {
// PUBLIC = 1 // PUBLIC = 1

View File

@ -0,0 +1,2 @@
export * from './public-server.setting'
export * from './register-server-setting.model'

View File

@ -1,4 +1,4 @@
import { RegisterClientFormFieldOptions } from './register-client-form-field.model' import { RegisterClientFormFieldOptions } from '../../client'
export type RegisterServerSettingOptions = RegisterClientFormFieldOptions & { export type RegisterServerSettingOptions = RegisterClientFormFieldOptions & {
// If the setting is not private, anyone can view its value (client code included) // If the setting is not private, anyone can view its value (client code included)