X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fhelpers%2Fcore-utils.ts;h=65f18d6442ac34da6d8719e15a15cc18dfc838cb;hb=73c695919c6569bfb667c36fc5a6b9b862130a0d;hp=d8748e1d7e2c7c52060beaa73ae56639f653b383;hpb=e4f97babf701481b55cc10fb3448feab5f97c867;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/helpers/core-utils.ts b/server/helpers/core-utils.ts index d8748e1d7..65f18d644 100644 --- a/server/helpers/core-utils.ts +++ b/server/helpers/core-utils.ts @@ -3,26 +3,34 @@ Useful to avoid circular dependencies. */ -import { join } from 'path' -import { pseudoRandomBytes } from 'crypto' -import { - readdir, - readFile, - rename, - unlink, - writeFile, - access, - stat, - Stats -} from 'fs' -import * as mkdirp from 'mkdirp' import * as bcrypt from 'bcrypt' import * as createTorrent from 'create-torrent' -import * as rimraf from 'rimraf' +import { pseudoRandomBytes } from 'crypto' +import { readdir, readFile, rename, stat, Stats, unlink, writeFile } from 'fs' +import * as mkdirp from 'mkdirp' +import { isAbsolute, join } from 'path' import * as pem from 'pem' -import * as jsonld from 'jsonld' -import * as jsig from 'jsonld-signatures' -jsig.use('jsonld', jsonld) +import * as rimraf from 'rimraf' +import { URL } from 'url' + +function sanitizeUrl (url: string) { + const urlObject = new URL(url) + + if (urlObject.protocol === 'https:' && urlObject.port === '443') { + urlObject.port = '' + } else if (urlObject.protocol === 'http:' && urlObject.port === '80') { + urlObject.port = '' + } + + return urlObject.href.replace(/\/$/, '') +} + +// Don't import remote scheme from constants because we are in core utils +function sanitizeHost (host: string, remoteScheme: string) { + const toRemove = remoteScheme === 'https' ? 443 : 80 + + return host.replace(new RegExp(`:${toRemove}$`), '') +} function isTestInstance () { return process.env.NODE_ENV === 'test' @@ -42,6 +50,8 @@ function root () { // Thanks: https://stackoverflow.com/a/12034334 function escapeHTML (stringParam) { + if (!stringParam) return '' + const entityMap = { '&': '&', '<': '<', @@ -62,6 +72,12 @@ function pageToStartAndCount (page: number, itemsPerPage: number) { return { start, count: itemsPerPage } } +function buildPath (path: string) { + if (isAbsolute(path)) return path + + return join(root(), path) +} + function promisify0 (func: (cb: (err: any, result: A) => void) => void): () => Promise { return function promisified (): Promise { return new Promise((resolve: (arg: A) => void, reject: (err: any) => void) => { @@ -103,7 +119,6 @@ function promisify2WithVoid (func: (arg1: T, arg2: U, cb: (err: any) => vo } } -const readFilePromise = promisify2(readFile) const readFileBufferPromise = promisify1(readFile) const unlinkPromise = promisify1WithVoid(unlink) const renamePromise = promisify2WithVoid(rename) @@ -111,7 +126,6 @@ const writeFilePromise = promisify2WithVoid(writeFile) const readdirPromise = promisify1(readdir) const mkdirpPromise = promisify1(mkdirp) const pseudoRandomBytesPromise = promisify1(pseudoRandomBytes) -const accessPromise = promisify1WithVoid(access) const createPrivateKey = promisify1(pem.createPrivateKey) const getPublicKey = promisify1(pem.getPublicKey) const bcryptComparePromise = promisify2(bcrypt.compare) @@ -120,8 +134,6 @@ const bcryptHashPromise = promisify2(bcrypt.hash) const createTorrentPromise = promisify2(createTorrent) const rimrafPromise = promisify1WithVoid(rimraf) const statPromise = promisify1(stat) -const jsonldSignPromise = promisify2(jsig.sign) -const jsonldVerifyPromise = promisify2(jsig.verify) // --------------------------------------------------------------------------- @@ -130,19 +142,20 @@ export { root, escapeHTML, pageToStartAndCount, + sanitizeUrl, + sanitizeHost, + buildPath, promisify0, promisify1, readdirPromise, - readFilePromise, readFileBufferPromise, unlinkPromise, renamePromise, writeFilePromise, mkdirpPromise, pseudoRandomBytesPromise, - accessPromise, createPrivateKey, getPublicKey, bcryptComparePromise, @@ -150,7 +163,5 @@ export { bcryptHashPromise, createTorrentPromise, rimrafPromise, - statPromise, - jsonldSignPromise, - jsonldVerifyPromise + statPromise }