mirror of https://github.com/requarks/wiki
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
34 lines
1.1 KiB
34 lines
1.1 KiB
7 years ago
|
require('../core/worker')
|
||
|
|
||
|
/* global WIKI */
|
||
|
|
||
|
const Promise = require('bluebird')
|
||
|
const fs = Promise.promisifyAll(require('fs-extra'))
|
||
|
const moment = require('moment')
|
||
|
const path = require('path')
|
||
|
|
||
|
module.exports = async (job) => {
|
||
|
WIKI.logger.info('Purging orphaned upload files...')
|
||
|
|
||
|
try {
|
||
|
const uplTempPath = path.resolve(process.cwd(), WIKI.config.paths.data, 'temp-upload')
|
||
|
const ls = await fs.readdirAsync(uplTempPath)
|
||
|
const fifteenAgo = moment().subtract(15, 'minutes')
|
||
|
|
||
|
await Promise.map(ls, (f) => {
|
||
|
return fs.statAsync(path.join(uplTempPath, f)).then((s) => { return { filename: f, stat: s } })
|
||
|
}).filter((s) => { return s.stat.isFile() }).then((arrFiles) => {
|
||
|
return Promise.map(arrFiles, (f) => {
|
||
|
if (moment(f.stat.ctime).isBefore(fifteenAgo, 'minute')) {
|
||
|
return fs.unlinkAsync(path.join(uplTempPath, f.filename))
|
||
|
}
|
||
|
})
|
||
|
})
|
||
|
|
||
|
WIKI.logger.info('Purging orphaned upload files: [ COMPLETED ]')
|
||
|
} catch (err) {
|
||
|
WIKI.logger.error('Purging orphaned upload files: [ FAILED ]')
|
||
|
WIKI.logger.error(err.message)
|
||
|
}
|
||
|
}
|