X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Flib%2Fplugins%2Fplugin-index.ts;h=624f5da1df325fe7a317371b7463d293e3d763cd;hb=023edc8a54a58d15f8d4f00d7f76e0074d0d3a81;hp=63cd47e635d90150b07b800d6ffd0b65ff224b58;hpb=e0ce715a1ded6e84c877004dae3e354c8716fb06;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/lib/plugins/plugin-index.ts b/server/lib/plugins/plugin-index.ts index 63cd47e63..624f5da1d 100644 --- a/server/lib/plugins/plugin-index.ts +++ b/server/lib/plugins/plugin-index.ts @@ -1,38 +1,38 @@ -import { doRequest } from '../../helpers/requests' -import { CONFIG } from '../../initializers/config' +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 { PeertubePluginLatestVersionRequest, PeertubePluginLatestVersionResponse } from '../../../shared/models/plugins/peertube-plugin-latest-version.model' -import { PeertubePluginIndexList } from '../../../shared/models/plugins/peertube-plugin-index-list.model' -import { ResultList } from '../../../shared/models' -import { PeerTubePluginIndex } from '../../../shared/models/plugins/peertube-plugin-index.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' import { PluginManager } from './plugin-manager' -import { logger } from '../../helpers/logger' - -const packageJSON = require('../../../../package.json') async function listAvailablePluginsFromIndex (options: PeertubePluginIndexList) { const { start = 0, count = 20, search, sort = 'npmName', pluginType } = options - const qs: PeertubePluginIndexList = { + const searchParams: PeertubePluginIndexList & Record = { start, count, sort, pluginType, search, - currentPeerTubeEngine: packageJSON.version + currentPeerTubeEngine: options.currentPeerTubeEngine || PEERTUBE_VERSION } const uri = CONFIG.PLUGINS.INDEX.URL + '/api/v1/plugins' try { - const { body } = await doRequest({ uri, qs, json: true }) + const { body } = await doJSONRequest(uri, { searchParams }) logger.debug('Got result from PeerTube index.', { body }) - await addInstanceInformation(body) + addInstanceInformation(body) return body as ResultList } catch (err) { @@ -41,7 +41,7 @@ async function listAvailablePluginsFromIndex (options: PeertubePluginIndexList) } } -async function addInstanceInformation (result: ResultList) { +function addInstanceInformation (result: ResultList) { for (const d of result.data) { d.installed = PluginManager.Instance.isRegistered(d.npmName) d.name = PluginModel.normalizePluginName(d.npmName) @@ -53,12 +53,16 @@ async function addInstanceInformation (result: ResultList) async function getLatestPluginsVersion (npmNames: string[]): Promise { const bodyRequest: PeertubePluginLatestVersionRequest = { npmNames, - currentPeerTubeEngine: packageJSON.version + currentPeerTubeEngine: PEERTUBE_VERSION } - const uri = CONFIG.PLUGINS.INDEX.URL + '/api/v1/plugins/latest-version' + const uri = sanitizeUrl(CONFIG.PLUGINS.INDEX.URL) + '/api/v1/plugins/latest-version' - const { body } = await doRequest({ uri, body: bodyRequest, json: true, method: 'POST' }) + const options = { + json: bodyRequest, + method: 'POST' as 'POST' + } + const { body } = await doJSONRequest(uri, options) return body }