]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/commitdiff
Reorganize plugin models
authorChocobozzz <me@florianbigard.com>
Tue, 11 May 2021 10:04:47 +0000 (12:04 +0200)
committerChocobozzz <me@florianbigard.com>
Tue, 11 May 2021 11:33:11 +0000 (13:33 +0200)
48 files changed:
client/src/app/+admin/plugins/plugin-list-installed/plugin-list-installed.component.ts
client/src/app/+admin/plugins/plugin-search/plugin-search.component.ts
client/src/app/+videos/+video-edit/shared/video-edit.component.ts
client/src/root-helpers/plugins.ts
server/controllers/api/plugins.ts
server/lib/plugins/hooks.ts
server/lib/plugins/plugin-index.ts
server/lib/plugins/plugin-manager.ts
server/lib/plugins/register-helpers.ts
server/middlewares/validators/plugins.ts
server/models/server/plugin.ts
server/tests/api/check-params/plugins.ts
server/tests/api/server/plugins.ts
server/tools/peertube-plugins.ts
shared/extra-utils/server/plugins.ts
shared/models/plugins/client/client-hook.model.ts [moved from shared/models/plugins/client-hook.model.ts with 100% similarity]
shared/models/plugins/client/index.ts [new file with mode: 0644]
shared/models/plugins/client/plugin-client-scope.type.ts [moved from shared/models/plugins/plugin-client-scope.type.ts with 100% similarity]
shared/models/plugins/client/plugin-element-placeholder.type.ts [moved from shared/models/plugins/plugin-element-placeholder.type.ts with 100% similarity]
shared/models/plugins/client/register-client-form-field.model.ts [moved from shared/models/plugins/register-client-form-field.model.ts with 100% similarity]
shared/models/plugins/client/register-client-hook.model.ts [moved from shared/models/plugins/register-client-hook.model.ts with 100% similarity]
shared/models/plugins/client/register-client-settings-script.model.ts [moved from shared/models/plugins/register-client-settings-script.model.ts with 69% similarity]
shared/models/plugins/index.ts
shared/models/plugins/plugin-index/index.ts [new file with mode: 0644]
shared/models/plugins/plugin-index/peertube-plugin-index-list.model.ts [moved from shared/models/plugins/peertube-plugin-index-list.model.ts with 79% similarity]
shared/models/plugins/plugin-index/peertube-plugin-index.model.ts [moved from shared/models/plugins/peertube-plugin-index.model.ts with 100% similarity]
shared/models/plugins/plugin-index/peertube-plugin-latest-version.model.ts [moved from shared/models/plugins/peertube-plugin-latest-version.model.ts with 100% similarity]
shared/models/plugins/plugin-package-json.model.ts
shared/models/plugins/server/api/index.ts [new file with mode: 0644]
shared/models/plugins/server/api/install-plugin.model.ts [moved from shared/models/plugins/install-plugin.model.ts with 100% similarity]
shared/models/plugins/server/api/manage-plugin.model.ts [moved from shared/models/plugins/manage-plugin.model.ts with 100% similarity]
shared/models/plugins/server/api/peertube-plugin.model.ts [moved from shared/models/plugins/peertube-plugin.model.ts with 86% similarity]
shared/models/plugins/server/index.ts [new file with mode: 0644]
shared/models/plugins/server/managers/index.ts [new file with mode: 0644]
shared/models/plugins/server/managers/plugin-playlist-privacy-manager.model.ts [moved from shared/models/plugins/plugin-playlist-privacy-manager.model.ts with 65% similarity]
shared/models/plugins/server/managers/plugin-settings-manager.model.ts [moved from shared/models/plugins/plugin-settings-manager.model.ts with 100% similarity]
shared/models/plugins/server/managers/plugin-storage-manager.model.ts [moved from shared/models/plugins/plugin-storage-manager.model.ts with 100% similarity]
shared/models/plugins/server/managers/plugin-transcoding-manager.model.ts [moved from shared/models/plugins/plugin-transcoding-manager.model.ts with 85% similarity]
shared/models/plugins/server/managers/plugin-video-category-manager.model.ts [moved from shared/models/plugins/plugin-video-category-manager.model.ts with 100% similarity]
shared/models/plugins/server/managers/plugin-video-language-manager.model.ts [moved from shared/models/plugins/plugin-video-language-manager.model.ts with 100% similarity]
shared/models/plugins/server/managers/plugin-video-licence-manager.model.ts [moved from shared/models/plugins/plugin-video-licence-manager.model.ts with 100% similarity]
shared/models/plugins/server/managers/plugin-video-privacy-manager.model.ts [moved from shared/models/plugins/plugin-video-privacy-manager.model.ts with 72% similarity]
shared/models/plugins/server/plugin-translation.model.ts [moved from shared/models/plugins/plugin-translation.model.ts with 100% similarity]
shared/models/plugins/server/register-server-hook.model.ts [moved from shared/models/plugins/register-server-hook.model.ts with 100% similarity]
shared/models/plugins/server/server-hook.model.ts [moved from shared/models/plugins/server-hook.model.ts with 100% similarity]
shared/models/plugins/server/settings/index.ts [new file with mode: 0644]
shared/models/plugins/server/settings/public-server.setting.ts [moved from shared/models/plugins/public-server.setting.ts with 100% similarity]
shared/models/plugins/server/settings/register-server-setting.model.ts [moved from shared/models/plugins/register-server-setting.model.ts with 83% similarity]

index 1a95980aeda70e794ef964994b6973c8d51f8500..6af2249207b552e63b353dd30ca4dfd001fb8359 100644 (file)
@@ -5,8 +5,7 @@ import { PluginApiService } from '@app/+admin/plugins/shared/plugin-api.service'
 import { ComponentPagination, ConfirmService, hasMoreItems, Notifier } from '@app/core'
 import { PluginService } from '@app/core/plugins/plugin.service'
 import { compareSemVer } from '@shared/core-utils/miscs/miscs'
-import { PeerTubePlugin } from '@shared/models/plugins/peertube-plugin.model'
-import { PluginType } from '@shared/models/plugins/plugin.type'
+import { PeerTubePlugin, PluginType } from '@shared/models'
 
 @Component({
   selector: 'my-plugin-list-installed',
index d2c179aba2e464fd86561ee3d8fa54bd69673a1f..0a6e57904a82e2cddcef4436ffdfe4a42dace750 100644 (file)
@@ -4,8 +4,7 @@ import { Component, OnInit } from '@angular/core'
 import { ActivatedRoute, Router } from '@angular/router'
 import { PluginApiService } from '@app/+admin/plugins/shared/plugin-api.service'
 import { ComponentPagination, ConfirmService, hasMoreItems, Notifier, PluginService } from '@app/core'
-import { PeerTubePluginIndex } from '@shared/models/plugins/peertube-plugin-index.model'
-import { PluginType } from '@shared/models/plugins/plugin.type'
+import { PeerTubePluginIndex, PluginType } from '@shared/models'
 
 @Component({
   selector: 'my-plugin-search',
index 34119f7abc5dd35ac620ffc19fe249704bf512d0..3d916dbce933441c521d707502eac9d3e3f3228c 100644 (file)
@@ -21,8 +21,15 @@ import {
 import { FormReactiveValidationMessages, FormValidatorService } from '@app/shared/shared-forms'
 import { InstanceService } from '@app/shared/shared-instance'
 import { VideoCaptionEdit, VideoEdit, VideoService } from '@app/shared/shared-main'
-import { LiveVideo, ServerConfig, VideoConstant, VideoDetails, VideoPrivacy } from '@shared/models'
-import { RegisterClientFormFieldOptions, RegisterClientVideoFieldOptions } from '@shared/models/plugins/register-client-form-field.model'
+import {
+  LiveVideo,
+  RegisterClientFormFieldOptions,
+  RegisterClientVideoFieldOptions,
+  ServerConfig,
+  VideoConstant,
+  VideoDetails,
+  VideoPrivacy
+} from '@shared/models'
 import { I18nPrimengCalendarService } from './i18n-primeng-calendar.service'
 import { VideoCaptionAddModalComponent } from './video-caption-add-modal.component'
 import { VideoEditType } from './video-edit.type'
index 5344c046833282623d28026b8f0384b2e2b28483..8c1c858b724c8d4d2b2f92fff02af75e76e067d7 100644 (file)
@@ -1,14 +1,15 @@
 import { RegisterClientHelpers } from 'src/types/register-client-option.model'
 import { getHookType, internalRunHook } from '@shared/core-utils/plugins/hooks'
-import { RegisterClientFormFieldOptions, RegisterClientVideoFieldOptions } from '@shared/models/plugins/register-client-form-field.model'
 import {
   ClientHookName,
   clientHookObject,
   ClientScript,
   PluginType,
+  RegisterClientFormFieldOptions,
   RegisterClientHookOptions,
-  ServerConfigPlugin,
-  RegisterClientSettingsScript
+  RegisterClientSettingsScript,
+  RegisterClientVideoFieldOptions,
+  ServerConfigPlugin
 } from '../../../shared/models'
 import { ClientScript as ClientScriptModule } from '../types/client-script.model'
 import { importModule } from './utils'
index a186de0102fd9e9fa7254e601c467d7db8628486..e18eed332765e7905b1efbcfc146dccb0c81a803 100644 (file)
@@ -1,16 +1,18 @@
 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 {
   asyncMiddleware,
   authenticate,
+  availablePluginsSortValidator,
   ensureUserHasRight,
   paginationValidator,
+  pluginsSortValidator,
   setDefaultPagination,
   setDefaultSort
-} from '../../middlewares'
-import { availablePluginsSortValidator, pluginsSortValidator } from '../../middlewares/validators'
-import { PluginModel } from '../../models/server/plugin'
-import { UserRight } from '../../../shared/models/users'
+} from '@server/middlewares'
 import {
   existingPluginValidator,
   installOrUpdatePluginValidator,
@@ -18,16 +20,17 @@ import {
   listPluginsValidator,
   uninstallPluginValidator,
   updatePluginSettingsValidator
-} from '../../middlewares/validators/plugins'
-import { PluginManager } from '../../lib/plugins/plugin-manager'
-import { InstallOrUpdatePlugin } from '../../../shared/models/plugins/install-plugin.model'
-import { ManagePlugin } from '../../../shared/models/plugins/manage-plugin.model'
-import { logger } from '../../helpers/logger'
-import { listAvailablePluginsFromIndex } from '../../lib/plugins/plugin-index'
-import { PeertubePluginIndexList } from '../../../shared/models/plugins/peertube-plugin-index-list.model'
-import { RegisteredServerSettings } from '../../../shared/models/plugins/register-server-setting.model'
-import { PublicServerSetting } from '../../../shared/models/plugins/public-server.setting'
-import { HttpStatusCode } from '../../../shared/core-utils/miscs/http-error-codes'
+} from '@server/middlewares/validators/plugins'
+import { PluginModel } from '@server/models/server/plugin'
+import { HttpStatusCode } from '@shared/core-utils'
+import {
+  InstallOrUpdatePlugin,
+  ManagePlugin,
+  PeertubePluginIndexList,
+  PublicServerSetting,
+  RegisteredServerSettings,
+  UserRight
+} from '@shared/models'
 
 const pluginRouter = express.Router()
 
index aa92f03cc09ff0aa6fd23a85b8e7ccc3407d1064..5e97b52a01f6f393984897bfae003fa8cbbae6da 100644 (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 { 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 RawFunction <U, T> = (params: U) => T
index 165bc91b358bfad9fb497e401a1d6673c99a3992..119cee8e0647e9fef5a0d941a791d4974dcadddf 100644 (file)
@@ -1,16 +1,16 @@
 import { sanitizeUrl } from '@server/helpers/core-utils'
-import { ResultList } from '../../../shared/models'
-import { PeertubePluginIndexList } from '../../../shared/models/plugins/peertube-plugin-index-list.model'
-import { PeerTubePluginIndex } from '../../../shared/models/plugins/peertube-plugin-index.model'
+import { logger } from '@server/helpers/logger'
+import { doJSONRequest } from '@server/helpers/requests'
+import { CONFIG } from '@server/initializers/config'
+import { PEERTUBE_VERSION } from '@server/initializers/constants'
+import { PluginModel } from '@server/models/server/plugin'
 import {
+  PeerTubePluginIndex,
+  PeertubePluginIndexList,
   PeertubePluginLatestVersionRequest,
-  PeertubePluginLatestVersionResponse
-} from '../../../shared/models/plugins/peertube-plugin-latest-version.model'
-import { logger } from '../../helpers/logger'
-import { doJSONRequest } from '../../helpers/requests'
-import { CONFIG } from '../../initializers/config'
-import { PEERTUBE_VERSION } from '../../initializers/constants'
-import { PluginModel } from '../../models/server/plugin'
+  PeertubePluginLatestVersionResponse,
+  ResultList
+} from '@shared/models'
 import { PluginManager } from './plugin-manager'
 
 async function listAvailablePluginsFromIndex (options: PeertubePluginIndexList) {
index ba9814383f19eeb028b136a9f8ae77ce635e566c..6b9a255a4bd2d182fce90031ad3eb06e53439aa0 100644 (file)
@@ -4,16 +4,11 @@ import { createReadStream, createWriteStream } from 'fs'
 import { ensureDir, outputFile, readJSON } from 'fs-extra'
 import { basename, join } from 'path'
 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 {
-  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 { 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 { logger } from '../../helpers/logger'
 import { CONFIG } from '../../initializers/config'
@@ -23,7 +18,6 @@ import { PluginLibrary, RegisterServerAuthExternalOptions, RegisterServerAuthPas
 import { ClientHtml } from '../client-html'
 import { RegisterHelpers } from './register-helpers'
 import { installNpmPlugin, installNpmPluginFromDisk, removeNpmPlugin } from './yarn'
-import { getCompleteLocale } from '@shared/core-utils'
 
 export interface RegisteredPlugin {
   npmName: string
@@ -443,7 +437,7 @@ export class PluginManager implements ServerHook {
 
   // ###################### 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)) {
       const path = translationPaths[locale]
       const json = await readJSON(join(this.getPluginPath(plugin.name, plugin.type), path))
index 203217b7028c99b9cb0f91670cbd4a61a9ef4ca8..f5b5733702105ad1a53d0cf029c61deb8b5ccf20 100644 (file)
@@ -26,9 +26,9 @@ import {
   PluginVideoLicenceManager,
   PluginVideoPrivacyManager,
   RegisterServerHookOptions,
-  RegisterServerSettingOptions
+  RegisterServerSettingOptions,
+  serverHookObject
 } from '@shared/models'
-import { serverHookObject } from '@shared/models/plugins/server-hook.model'
 import { VideoTranscodingProfilesManager } from '../transcoding/video-transcoding-profiles'
 import { buildPluginHelpers } from './plugin-helpers-builder'
 
index ab87fe720c87b428717f05939f5cd49068fe3e62..2c47ec5bbd03aef78f0a852c98cae228d2f7357a 100644 (file)
@@ -1,15 +1,15 @@
 import * as express from 'express'
 import { body, param, query, ValidationChain } from 'express-validator'
-import { logger } from '../../helpers/logger'
-import { areValidationErrors } from './utils'
+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 { 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 { areValidationErrors } from './utils'
 
 const getPluginValidator = (pluginType: PluginType, withVersion = true) => {
   const validators: (ValidationChain | express.Handler)[] = [
index 82387af6ad09922d3930d536d7ae32aabce0f7cf..94c9b04bf130790554030fb8c289823853a3a41f 100644 (file)
@@ -1,9 +1,7 @@
 import { FindAndCountOptions, json, QueryTypes } from 'sequelize'
 import { AllowNull, Column, CreatedAt, DataType, DefaultScope, Is, Model, Table, UpdatedAt } from 'sequelize-typescript'
 import { MPlugin, MPluginFormattable } from '@server/types/models'
-import { PeerTubePlugin } from '../../../shared/models/plugins/peertube-plugin.model'
-import { PluginType } from '../../../shared/models/plugins/plugin.type'
-import { RegisterServerSettingOptions } from '../../../shared/models/plugins/register-server-setting.model'
+import { PeerTubePlugin, PluginType, RegisterServerSettingOptions } from '../../../shared/models'
 import {
   isPluginDescriptionValid,
   isPluginHomepage,
index 6e540bcbbf1ece86c6c67bf34c554a0aaf3a252d..a833fe6ffe03fdccb4b2c3ee828acf47603ddd24 100644 (file)
@@ -1,7 +1,7 @@
 /* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
 
 import 'mocha'
-
+import { HttpStatusCode } from '@shared/core-utils'
 import {
   checkBadCountPagination,
   checkBadSortPagination,
@@ -11,14 +11,14 @@ import {
   flushAndRunServer,
   immutableAssign,
   installPlugin,
-  makeGetRequest, makePostBodyRequest, makePutBodyRequest,
+  makeGetRequest,
+  makePostBodyRequest,
+  makePutBodyRequest,
   ServerInfo,
   setAccessTokensToServers,
   userLogin
-} from '../../../../shared/extra-utils'
-import { PluginType } from '../../../../shared/models/plugins/plugin.type'
-import { PeerTubePlugin } from '../../../../shared/models/plugins/peertube-plugin.model'
-import { HttpStatusCode } from '../../../../shared/core-utils/miscs/http-error-codes'
+} from '@shared/extra-utils'
+import { PeerTubePlugin, PluginType } from '@shared/models'
 
 describe('Test server plugins API validators', function () {
   let server: ServerInfo
index 1c6eabe6d6cb5f0f4910377b29562e3771137dfd..3c09acc9a5ece9607f378673ad8a8374903a1373 100644 (file)
@@ -28,14 +28,8 @@ import {
   updatePluginSettings,
   wait,
   waitUntilLog
-} from '../../../../shared/extra-utils'
-import { PeerTubePluginIndex } from '../../../../shared/models/plugins/peertube-plugin-index.model'
-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'
+} from '@shared/extra-utils'
+import { PeerTubePlugin, PeerTubePluginIndex, PluginPackageJson, PluginType, PublicServerSetting, ServerConfig, User } from '@shared/models'
 
 const expect = chai.expect
 
index c8a5768448c2fd3f1648cb293e4a4f197455b8a9..cb591377ba29d7ed48a8c02dd05fa79270e9a7f2 100644 (file)
@@ -4,10 +4,9 @@ import { registerTSPaths } from '../helpers/register-ts-paths'
 registerTSPaths()
 
 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 { getAdminTokenOrDie, getServerCredentials } from './cli'
-import { PeerTubePlugin } from '../../shared/models/plugins/peertube-plugin.model'
+import { PeerTubePlugin, PluginType } from '../../shared/models'
 import { isAbsolute } from 'path'
 import * as CliTable3 from 'cli-table3'
 import commander = require('commander')
index 864954ee78f011a2256d2055e1a6d830f8850553..d53e5b3828090165b0524711ee7986686c2837ab 100644 (file)
@@ -4,12 +4,12 @@ import { expect } from 'chai'
 import { readJSON, writeJSON } from 'fs-extra'
 import { join } from 'path'
 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 { buildServerDirectory, root } from '../miscs/miscs'
 import { makeGetRequest, makePostBodyRequest, makePutBodyRequest } from '../requests/requests'
 import { ServerInfo } from './servers'
-import { HttpStatusCode } from '../../../shared/core-utils/miscs/http-error-codes'
 
 function listPlugins (parameters: {
   url: string
diff --git a/shared/models/plugins/client/index.ts b/shared/models/plugins/client/index.ts
new file mode 100644 (file)
index 0000000..6dfc635
--- /dev/null
@@ -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'
similarity index 69%
rename from shared/models/plugins/register-client-settings-script.model.ts
rename to shared/models/plugins/client/register-client-settings-script.model.ts
index ac16af3666a6840b223c5023aef0d2c63f86b576..481ceef96ee6ce9e7001a169416b431fbfad28f0 100644 (file)
@@ -1,4 +1,4 @@
-import { RegisterServerSettingOptions } from "./register-server-setting.model"
+import { RegisterServerSettingOptions } from '../server'
 
 export interface RegisterClientSettingsScript {
   isSettingHidden (options: {
index 03b27f90751412b1e5ad114af91d5030348fc469..cbbe4916ef08b520e56efbca6cb050741280c823 100644 (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 './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-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 './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'
diff --git a/shared/models/plugins/plugin-index/index.ts b/shared/models/plugins/plugin-index/index.ts
new file mode 100644 (file)
index 0000000..9138466
--- /dev/null
@@ -0,0 +1,3 @@
+export * from './peertube-plugin-index-list.model'
+export * from './peertube-plugin-index.model'
+export * from './peertube-plugin-latest-version.model'
similarity index 79%
rename from shared/models/plugins/peertube-plugin-index-list.model.ts
rename to shared/models/plugins/plugin-index/peertube-plugin-index-list.model.ts
index 817bac31efc7f4a2224286e3f25f57bceef48f32..ecb46482ea11e047de69fc639ff252bc77a7ff8c 100644 (file)
@@ -1,4 +1,4 @@
-import { PluginType } from './plugin.type'
+import { PluginType } from '../plugin.type'
 
 export interface PeertubePluginIndexList {
   start: number
index c26e9ae5b55dcca60ee67be8c9a385f7146f9372..b2f92af80b82de62408da925d11327ea78a104d1 100644 (file)
@@ -1,4 +1,4 @@
-import { PluginClientScope } from './plugin-client-scope.type'
+import { PluginClientScope } from './client/plugin-client-scope.type'
 
 export type PluginTranslationPaths = {
   [ locale: string ]: string
diff --git a/shared/models/plugins/server/api/index.ts b/shared/models/plugins/server/api/index.ts
new file mode 100644 (file)
index 0000000..eb59a03
--- /dev/null
@@ -0,0 +1,3 @@
+export * from './install-plugin.model'
+export * from './manage-plugin.model'
+export * from './peertube-plugin.model'
similarity index 86%
rename from shared/models/plugins/peertube-plugin.model.ts
rename to shared/models/plugins/server/api/peertube-plugin.model.ts
index 2b0bb8cfa2ba284ded61a732995809fae2c12672..54c383f57bd52a4f68c0affa3caf750a6cb3e650 100644 (file)
@@ -1,4 +1,4 @@
-import { PluginType } from './plugin.type'
+import { PluginType } from '../../plugin.type'
 
 export interface PeerTubePlugin {
   name: string
diff --git a/shared/models/plugins/server/index.ts b/shared/models/plugins/server/index.ts
new file mode 100644 (file)
index 0000000..d3ff49d
--- /dev/null
@@ -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'
diff --git a/shared/models/plugins/server/managers/index.ts b/shared/models/plugins/server/managers/index.ts
new file mode 100644 (file)
index 0000000..49365a8
--- /dev/null
@@ -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'
similarity index 65%
rename from shared/models/plugins/plugin-playlist-privacy-manager.model.ts
rename to shared/models/plugins/server/managers/plugin-playlist-privacy-manager.model.ts
index d1823ef4e6d1179b5cb3ae8456a0c21feac36e2d..4703c0a8bb11d3a971df126cf3d12369015b83c8 100644 (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 {
   // PUBLIC = 1,
similarity index 85%
rename from shared/models/plugins/plugin-transcoding-manager.model.ts
rename to shared/models/plugins/server/managers/plugin-transcoding-manager.model.ts
index 8babccd4eb02ab11aee89434b89da1409b70457e..a0422a46021452305862bd216c1e47d32eb71090 100644 (file)
@@ -1,4 +1,4 @@
-import { EncoderOptionsBuilder } from '../videos/video-transcoding.model'
+import { EncoderOptionsBuilder } from '../../../videos/video-transcoding.model'
 
 export interface PluginTranscodingManager {
   addLiveProfile (encoder: string, profile: string, builder: EncoderOptionsBuilder): boolean
similarity index 72%
rename from shared/models/plugins/plugin-video-privacy-manager.model.ts
rename to shared/models/plugins/server/managers/plugin-video-privacy-manager.model.ts
index 3ada99608ccd0fb2a45f2e1a00b6e7aec7385c3a..7717115e3e24ed52751819145f29fb0a0a363f70 100644 (file)
@@ -1,4 +1,4 @@
-import { VideoPrivacy } from '../videos/video-privacy.enum'
+import { VideoPrivacy } from '../../../videos/video-privacy.enum'
 
 export interface PluginVideoPrivacyManager {
   // PUBLIC = 1
diff --git a/shared/models/plugins/server/settings/index.ts b/shared/models/plugins/server/settings/index.ts
new file mode 100644 (file)
index 0000000..b456de0
--- /dev/null
@@ -0,0 +1,2 @@
+export * from './public-server.setting'
+export * from './register-server-setting.model'
similarity index 83%
rename from shared/models/plugins/register-server-setting.model.ts
rename to shared/models/plugins/server/settings/register-server-setting.model.ts
index 9f45c3c370f781a4310466b5cd7dd77d49b0f29b..d9a798cac0f1227bf3a849fa3d36e71c8fca1f6f 100644 (file)
@@ -1,4 +1,4 @@
-import { RegisterClientFormFieldOptions } from './register-client-form-field.model'
+import { RegisterClientFormFieldOptions } from '../../client'
 
 export type RegisterServerSettingOptions = RegisterClientFormFieldOptions & {
   // If the setting is not private, anyone can view its value (client code included)