X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fhelpers%2Futils.ts;h=b61d6e3fa034baab0ab3120ba0a92864d09ce206;hb=265ba139ebf56bbdc1c65f6ea4f367774c691fc0;hp=cb5e536b8bcdc04d4dc167c6bc1a66fd9beee45d;hpb=3fd3ab2d34d512b160a5e6084d7609be7b4f4452;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/helpers/utils.ts b/server/helpers/utils.ts index cb5e536b8..b61d6e3fa 100644 --- a/server/helpers/utils.ts +++ b/server/helpers/utils.ts @@ -1,17 +1,56 @@ import * as express from 'express' +import * as multer from 'multer' import { Model } from 'sequelize-typescript' import { ResultList } from '../../shared' import { VideoResolution } from '../../shared/models/videos' -import { CONFIG } from '../initializers' -import { AccountModel } from '../models/account/account' +import { CONFIG, REMOTE_SCHEME } from '../initializers' import { UserModel } from '../models/account/user' +import { ActorModel } from '../models/activitypub/actor' +import { ApplicationModel } from '../models/application/application' import { pseudoRandomBytesPromise } from './core-utils' import { logger } from './logger' +function getHostWithPort (host: string) { + const splitted = host.split(':') + + // The port was not specified + if (splitted.length === 1) { + if (REMOTE_SCHEME.HTTP === 'https') return host + ':443' + + return host + ':80' + } + + return host +} + function badRequest (req: express.Request, res: express.Response, next: express.NextFunction) { return res.type('json').status(400).end() } +function createReqFiles (fieldName: string, storageDir: string, mimeTypes: { [ id: string ]: string }) { + const storage = multer.diskStorage({ + destination: (req, file, cb) => { + cb(null, storageDir) + }, + + filename: async (req, file, cb) => { + const extension = mimeTypes[file.mimetype] + let randomString = '' + + try { + randomString = await generateRandomString(16) + } catch (err) { + logger.error('Cannot generate random string for file name.', err) + randomString = 'fake-random-string' + } + + cb(null, randomString + extension) + } + }) + + return multer({ storage }).fields([{ name: fieldName, maxCount: 1 }]) +} + async function generateRandomString (size: number) { const raw = await pseudoRandomBytesPromise(size) @@ -80,18 +119,19 @@ function resetSequelizeInstance (instance: Model, savedFields: object) { }) } -let serverAccount: AccountModel -async function getServerAccount () { - if (serverAccount === undefined) { - serverAccount = await AccountModel.loadApplication() +let serverActor: ActorModel +async function getServerActor () { + if (serverActor === undefined) { + const application = await ApplicationModel.load() + serverActor = application.Account.Actor } - if (!serverAccount) { - logger.error('Cannot load server account.') + if (!serverActor) { + logger.error('Cannot load server actor.') process.exit(0) } - return Promise.resolve(serverAccount) + return Promise.resolve(serverActor) } type SortType = { sortModel: any, sortValue: string } @@ -105,6 +145,8 @@ export { isSignupAllowed, computeResolutionsToTranscode, resetSequelizeInstance, - getServerAccount, - SortType + getServerActor, + SortType, + getHostWithPort, + createReqFiles }