2017-07-05 07:26:25 -04:00
|
|
|
import { ResultList } from '../../shared'
|
2017-12-14 11:38:41 -05:00
|
|
|
import { ApplicationModel } from '../models/application/application'
|
2020-01-31 10:56:52 -05:00
|
|
|
import { execPromise, execPromise2, randomBytesPromise, sha256 } from './core-utils'
|
2017-11-16 05:08:25 -05:00
|
|
|
import { logger } from './logger'
|
2018-08-07 09:17:17 -04:00
|
|
|
import { join } from 'path'
|
2018-08-07 03:54:36 -04:00
|
|
|
import { Instance as ParseTorrent } from 'parse-torrent'
|
2018-08-27 10:23:34 -04:00
|
|
|
import { remove } from 'fs-extra'
|
2018-09-14 05:52:23 -04:00
|
|
|
import * as memoizee from 'memoizee'
|
2019-04-11 05:33:44 -04:00
|
|
|
import { CONFIG } from '../initializers/config'
|
2016-05-10 15:19:24 -04:00
|
|
|
|
2018-07-31 09:09:34 -04:00
|
|
|
function deleteFileAsync (path: string) {
|
2018-08-27 10:23:34 -04:00
|
|
|
remove(path)
|
2018-07-31 09:09:34 -04:00
|
|
|
.catch(err => logger.error('Cannot delete the file %s asynchronously.', path, { err }))
|
|
|
|
}
|
|
|
|
|
2017-10-25 10:03:33 -04:00
|
|
|
async function generateRandomString (size: number) {
|
2020-01-31 10:56:52 -05:00
|
|
|
const raw = await randomBytesPromise(size)
|
2017-10-25 10:03:33 -04:00
|
|
|
|
|
|
|
return raw.toString('hex')
|
2017-02-26 12:57:33 -05:00
|
|
|
}
|
|
|
|
|
2019-08-21 08:31:57 -04:00
|
|
|
interface FormattableToJSON<U, V> {
|
|
|
|
toFormattedJSON (args?: U): V
|
|
|
|
}
|
|
|
|
|
2019-07-23 03:48:48 -04:00
|
|
|
function getFormattedObjects<U, V, T extends FormattableToJSON<U, V>> (objects: T[], objectsTotal: number, formattedArg?: U) {
|
|
|
|
const formattedObjects = objects.map(o => o.toFormattedJSON(formattedArg))
|
2017-01-04 14:59:23 -05:00
|
|
|
|
2018-06-12 14:04:58 -04:00
|
|
|
return {
|
2017-01-04 14:59:23 -05:00
|
|
|
total: objectsTotal,
|
2017-08-25 05:45:31 -04:00
|
|
|
data: formattedObjects
|
2019-07-23 03:48:48 -04:00
|
|
|
} as ResultList<V>
|
2017-01-04 14:59:23 -05:00
|
|
|
}
|
|
|
|
|
2018-09-14 05:52:23 -04:00
|
|
|
const getServerActor = memoizee(async function () {
|
|
|
|
const application = await ApplicationModel.load()
|
|
|
|
if (!application) throw Error('Could not load Application from database.')
|
2018-07-26 04:45:10 -04:00
|
|
|
|
2018-10-12 09:26:04 -04:00
|
|
|
const actor = application.Account.Actor
|
|
|
|
actor.Account = application.Account
|
|
|
|
|
|
|
|
return actor
|
2020-01-03 07:47:45 -05:00
|
|
|
}, { promise: true })
|
2017-11-13 11:39:41 -05:00
|
|
|
|
2018-12-04 10:02:49 -05:00
|
|
|
function generateVideoImportTmpPath (target: string | ParseTorrent) {
|
2018-08-07 03:54:36 -04:00
|
|
|
const id = typeof target === 'string' ? target : target.infoHash
|
|
|
|
|
|
|
|
const hash = sha256(id)
|
2018-12-04 10:02:49 -05:00
|
|
|
return join(CONFIG.STORAGE.TMP_DIR, hash + '-import.mp4')
|
2018-08-06 11:13:39 -04:00
|
|
|
}
|
|
|
|
|
2018-08-07 03:54:36 -04:00
|
|
|
function getSecureTorrentName (originalName: string) {
|
|
|
|
return sha256(originalName) + '.torrent'
|
|
|
|
}
|
2017-09-22 03:13:43 -04:00
|
|
|
|
2018-11-23 05:06:10 -05:00
|
|
|
async function getServerCommit () {
|
2018-10-03 08:35:35 -04:00
|
|
|
try {
|
|
|
|
const tag = await execPromise2(
|
|
|
|
'[ ! -d .git ] || git name-rev --name-only --tags --no-undefined HEAD 2>/dev/null || true',
|
|
|
|
{ stdio: [ 0, 1, 2 ] }
|
|
|
|
)
|
|
|
|
|
|
|
|
if (tag) return tag.replace(/^v/, '')
|
|
|
|
} catch (err) {
|
|
|
|
logger.debug('Cannot get version from git tags.', { err })
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
const version = await execPromise('[ ! -d .git ] || git rev-parse --short HEAD')
|
|
|
|
|
|
|
|
if (version) return version.toString().trim()
|
|
|
|
} catch (err) {
|
|
|
|
logger.debug('Cannot get version from git HEAD.', { err })
|
|
|
|
}
|
2018-09-29 13:53:49 -04:00
|
|
|
|
2018-11-23 05:06:10 -05:00
|
|
|
return ''
|
2018-09-29 13:53:49 -04:00
|
|
|
}
|
|
|
|
|
2018-10-08 10:26:04 -04:00
|
|
|
/**
|
|
|
|
* From a filename like "ede4cba5-742b-46fa-a388-9a6eb3a3aeb3.mp4", returns
|
|
|
|
* only the "ede4cba5-742b-46fa-a388-9a6eb3a3aeb3" part. If the filename does
|
|
|
|
* not contain a UUID, returns null.
|
|
|
|
*/
|
|
|
|
function getUUIDFromFilename (filename: string) {
|
|
|
|
const regex = /[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}/
|
|
|
|
const result = filename.match(regex)
|
|
|
|
|
|
|
|
if (!result || Array.isArray(result) === false) return null
|
|
|
|
|
|
|
|
return result[0]
|
|
|
|
}
|
|
|
|
|
2016-02-07 05:23:23 -05:00
|
|
|
// ---------------------------------------------------------------------------
|
2016-01-31 05:23:52 -05:00
|
|
|
|
2017-05-15 16:22:03 -04:00
|
|
|
export {
|
2018-07-31 09:09:34 -04:00
|
|
|
deleteFileAsync,
|
2017-05-15 16:22:03 -04:00
|
|
|
generateRandomString,
|
2017-08-25 05:45:31 -04:00
|
|
|
getFormattedObjects,
|
2018-08-07 03:54:36 -04:00
|
|
|
getSecureTorrentName,
|
2017-12-14 11:38:41 -05:00
|
|
|
getServerActor,
|
2018-11-23 05:06:10 -05:00
|
|
|
getServerCommit,
|
2018-12-04 10:02:49 -05:00
|
|
|
generateVideoImportTmpPath,
|
2018-10-08 10:26:04 -04:00
|
|
|
getUUIDFromFilename
|
2017-05-15 16:22:03 -04:00
|
|
|
}
|