Initial work for upgrade feature
This commit is contained in:
parent
5223368e37
commit
391afc4d7a
@ -6,7 +6,7 @@ const Promise = require('bluebird')
|
|||||||
const validator = require('validator')
|
const validator = require('validator')
|
||||||
const _ = require('lodash')
|
const _ = require('lodash')
|
||||||
const axios = require('axios')
|
const axios = require('axios')
|
||||||
const moment = require('moment')
|
const path = require('path')
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Admin
|
* Admin
|
||||||
@ -234,4 +234,14 @@ router.get('/settings', (req, res) => {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
router.get('/settings/install', (req, res) => {
|
||||||
|
if (!res.locals.rights.manage) {
|
||||||
|
return res.render('error-forbidden')
|
||||||
|
}
|
||||||
|
|
||||||
|
let sysLib = require(path.join(ROOTPATH, 'libs/system.js'))
|
||||||
|
sysLib.install('v1.0-beta.5')
|
||||||
|
res.status(200).end()
|
||||||
|
})
|
||||||
|
|
||||||
module.exports = router
|
module.exports = router
|
||||||
|
@ -186,7 +186,7 @@ module.exports = {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
.catch((err) => {
|
.catch((err) => {
|
||||||
winston.error('[' + PROCNAME + '][GIT] Unable to push changes to remote!')
|
winston.error('[' + PROCNAME + '.Git] Unable to push changes to remote!')
|
||||||
throw err
|
throw err
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
42
libs/system.js
Normal file
42
libs/system.js
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
'use strict'
|
||||||
|
|
||||||
|
const Promise = require('bluebird')
|
||||||
|
const https = require('follow-redirects').https
|
||||||
|
const fs = Promise.promisifyAll(require('fs-extra'))
|
||||||
|
const path = require('path')
|
||||||
|
const tar = require('tar')
|
||||||
|
const zlib = require('zlib')
|
||||||
|
const _ = require('lodash')
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
|
||||||
|
_remoteFile: 'https://github.com/Requarks/wiki/releases/download/{0}/wiki-js.tar.gz',
|
||||||
|
_installDir: '',
|
||||||
|
|
||||||
|
install (targetTag) {
|
||||||
|
let self = this
|
||||||
|
|
||||||
|
self._installDir = path.resolve(ROOTPATH, appconfig.paths.data, 'install')
|
||||||
|
|
||||||
|
return fs.ensureDirAsync(self._installDir).then(() => {
|
||||||
|
let remoteURL = _.replace(self._remoteFile, '{0}', targetTag)
|
||||||
|
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
https.get(remoteURL, resp => {
|
||||||
|
if (resp.statusCode !== 200) {
|
||||||
|
return reject(new Error('Remote file not found'))
|
||||||
|
}
|
||||||
|
|
||||||
|
resp.pipe(zlib.createGunzip())
|
||||||
|
.pipe(tar.Extract({ path: self._installDir }))
|
||||||
|
.on('error', err => reject(err))
|
||||||
|
.on('end', () => {
|
||||||
|
resolve(true)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}).then(() => {
|
||||||
|
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
@ -52,6 +52,7 @@
|
|||||||
"farmhash": "^1.2.1",
|
"farmhash": "^1.2.1",
|
||||||
"file-type": "^4.0.0",
|
"file-type": "^4.0.0",
|
||||||
"filesize.js": "^1.0.2",
|
"filesize.js": "^1.0.2",
|
||||||
|
"follow-redirects": "^1.2.1",
|
||||||
"fs-extra": "^2.0.0",
|
"fs-extra": "^2.0.0",
|
||||||
"git-wrapper2-promise": "^0.2.9",
|
"git-wrapper2-promise": "^0.2.9",
|
||||||
"highlight.js": "^9.9.0",
|
"highlight.js": "^9.9.0",
|
||||||
@ -94,6 +95,7 @@
|
|||||||
"sticky-js": "^1.0.7",
|
"sticky-js": "^1.0.7",
|
||||||
"stopword": "^0.1.1",
|
"stopword": "^0.1.1",
|
||||||
"stream-to-promise": "^2.2.0",
|
"stream-to-promise": "^2.2.0",
|
||||||
|
"tar": "^2.2.1",
|
||||||
"validator": "^6.2.0",
|
"validator": "^6.2.0",
|
||||||
"validator-as-promised": "^1.0.2",
|
"validator-as-promised": "^1.0.2",
|
||||||
"winston": "^2.3.0"
|
"winston": "^2.3.0"
|
||||||
|
Loading…
Reference in New Issue
Block a user