feat: (WIP) git storage module
This commit is contained in:
parent
658c105ab5
commit
a113d1199d
@ -154,6 +154,7 @@
|
|||||||
"scim-query-filter-parser": "1.1.0",
|
"scim-query-filter-parser": "1.1.0",
|
||||||
"semver": "5.6.0",
|
"semver": "5.6.0",
|
||||||
"serve-favicon": "2.5.0",
|
"serve-favicon": "2.5.0",
|
||||||
|
"simple-git": "1.107.0",
|
||||||
"sqlite3": "4.0.6",
|
"sqlite3": "4.0.6",
|
||||||
"subscriptions-transport-ws": "0.9.15",
|
"subscriptions-transport-ws": "0.9.15",
|
||||||
"twemoji": "11.2.0",
|
"twemoji": "11.2.0",
|
||||||
|
@ -1,3 +1,47 @@
|
|||||||
|
const path = require('path')
|
||||||
|
const sgit = require('simple-git/promise')
|
||||||
|
const fs = require('fs-extra')
|
||||||
|
const _ = require('lodash')
|
||||||
|
|
||||||
|
const repoPath = path.join(WIKI.ROOTPATH, 'data/repo')
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get file extension based on content type
|
||||||
|
*/
|
||||||
|
const getFileExtension = (contentType) => {
|
||||||
|
switch (contentType) {
|
||||||
|
case 'markdown':
|
||||||
|
return 'md'
|
||||||
|
case 'html':
|
||||||
|
return 'html'
|
||||||
|
default:
|
||||||
|
return 'txt'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Inject page metadata into contents
|
||||||
|
*/
|
||||||
|
const injectMetadata = (page) => {
|
||||||
|
let meta = [
|
||||||
|
['title', page.title],
|
||||||
|
['description', page.description]
|
||||||
|
]
|
||||||
|
let metaFormatted = ''
|
||||||
|
switch (page.contentType) {
|
||||||
|
case 'markdown':
|
||||||
|
metaFormatted = meta.map(mt => `[//]: # ${mt[0]}: ${mt[1]}`).join('\n')
|
||||||
|
break
|
||||||
|
case 'html':
|
||||||
|
metaFormatted = meta.map(mt => `<!-- ${mt[0]}: ${mt[1]} -->`).join('\n')
|
||||||
|
break
|
||||||
|
default:
|
||||||
|
metaFormatted = meta.map(mt => `#WIKI ${mt[0]}: ${mt[1]}`).join('\n')
|
||||||
|
break
|
||||||
|
}
|
||||||
|
return `${metaFormatted}\n\n${page.content}`
|
||||||
|
}
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
async activated() {
|
async activated() {
|
||||||
|
|
||||||
@ -6,18 +50,65 @@ module.exports = {
|
|||||||
|
|
||||||
},
|
},
|
||||||
async init() {
|
async init() {
|
||||||
|
await fs.ensureDir(repoPath)
|
||||||
|
const git = sgit(repoPath)
|
||||||
|
|
||||||
|
// Initialize repo (if needed)
|
||||||
|
const isRepo = await git.checkIsRepo()
|
||||||
|
if (!isRepo) {
|
||||||
|
await git.init()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Checkout branch
|
||||||
|
await git.checkout(this.config.branch)
|
||||||
|
|
||||||
|
// Add remote
|
||||||
|
await git.raw(['config', '--local', '--bool', 'http.sslVerify', _.toString(this.config.verifySSL)])
|
||||||
|
switch (this.config.authType) {
|
||||||
|
case 'ssh':
|
||||||
|
await git.addConfig('core.sshCommand', `ssh -i "${this.config.sshPrivateKeyPath}" -o StrictHostKeyChecking=no`)
|
||||||
|
await git.addRemote('origin', this.config.repoUrl)
|
||||||
|
break
|
||||||
|
default:
|
||||||
|
await git.addRemote('origin', `https://${this.config.basicUsername}:${this.config.basicPassword}@${this.config.repoUrl}`)
|
||||||
|
break
|
||||||
|
}
|
||||||
},
|
},
|
||||||
async created() {
|
async created() {
|
||||||
|
const fileName = `${this.page.path}.${getFileExtension(this.page.contentType)}`
|
||||||
|
const filePath = path.join(repoPath, fileName)
|
||||||
|
await fs.outputFile(filePath, injectMetadata(this.page), 'utf8')
|
||||||
|
|
||||||
|
const git = sgit(repoPath)
|
||||||
|
await git.add(`./${fileName}`).commit(`docs: create ${this.page.path}`, fileName, {
|
||||||
|
'--author': `"${this.page.authorName} <${this.page.authorEmail}>"`
|
||||||
|
})
|
||||||
},
|
},
|
||||||
async updated() {
|
async updated() {
|
||||||
|
const fileName = `${this.page.path}.${getFileExtension(this.page.contentType)}`
|
||||||
|
const filePath = path.join(repoPath, fileName)
|
||||||
|
await fs.outputFile(filePath, injectMetadata(this.page), 'utf8')
|
||||||
|
|
||||||
|
const git = sgit(repoPath)
|
||||||
|
await git.add(`./${fileName}`).commit(`docs: update ${this.page.path}`, fileName, {
|
||||||
|
'--author': `"${this.page.authorName} <${this.page.authorEmail}>"`
|
||||||
|
})
|
||||||
},
|
},
|
||||||
async deleted() {
|
async deleted() {
|
||||||
|
const fileName = `${this.page.path}.${getFileExtension(this.page.contentType)}`
|
||||||
|
|
||||||
|
const git = sgit(repoPath)
|
||||||
|
await git.rm(`./${fileName}`).commit(`docs: delete ${this.page.path}`, fileName, {
|
||||||
|
'--author': `"${this.page.authorName} <${this.page.authorEmail}>"`
|
||||||
|
})
|
||||||
},
|
},
|
||||||
async renamed() {
|
async renamed() {
|
||||||
|
const sourceFilePath = `${this.page.sourcePath}.${getFileExtension(this.page.contentType)}`
|
||||||
|
const destinationFilePath = `${this.page.destinationPath}.${getFileExtension(this.page.contentType)}`
|
||||||
|
|
||||||
|
const git = sgit(repoPath)
|
||||||
|
await git.mv(`./${sourceFilePath}`, `./${destinationFilePath}`).commit(`docs: rename ${this.page.sourcePath} to ${destinationFilePath}`, destinationFilePath, {
|
||||||
|
'--author': `"${this.page.authorName} <${this.page.authorEmail}>"`
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user