mirror of https://github.com/requarks/wiki
parent
2883437a0f
commit
38c33c58bb
@ -0,0 +1,63 @@
|
|||||||
|
const _ = require('lodash')
|
||||||
|
|
||||||
|
/* global WIKI */
|
||||||
|
|
||||||
|
module.exports = async (pageId) => {
|
||||||
|
WIKI.logger.info(`Rebuilding page tree...`)
|
||||||
|
|
||||||
|
try {
|
||||||
|
WIKI.models = require('../core/db').init()
|
||||||
|
await WIKI.configSvc.loadFromDb()
|
||||||
|
await WIKI.configSvc.applyFlags()
|
||||||
|
|
||||||
|
await WIKI.models.knex.table('pageTree').truncate()
|
||||||
|
const pages = await WIKI.models.pages.query().select('id', 'path', 'localeCode', 'title', 'isPrivate', 'privateNS').orderBy(['localeCode', 'path'])
|
||||||
|
let tree = []
|
||||||
|
let pik = 0
|
||||||
|
|
||||||
|
for (const page of pages) {
|
||||||
|
const pagePaths = page.path.split('/')
|
||||||
|
let currentPath = ''
|
||||||
|
let depth = 0
|
||||||
|
let parentId = null
|
||||||
|
for (const part of pagePaths) {
|
||||||
|
depth++
|
||||||
|
const isFolder = (depth < pagePaths.length)
|
||||||
|
currentPath = currentPath ? `${currentPath}/${part}` : part
|
||||||
|
const found = _.find(tree, {
|
||||||
|
localeCode: page.localeCode,
|
||||||
|
path: currentPath
|
||||||
|
})
|
||||||
|
if (!found) {
|
||||||
|
pik++
|
||||||
|
tree.push({
|
||||||
|
id: pik,
|
||||||
|
localeCode: page.localeCode,
|
||||||
|
path: currentPath,
|
||||||
|
depth: depth,
|
||||||
|
title: isFolder ? part : page.title,
|
||||||
|
isFolder: isFolder,
|
||||||
|
isPrivate: !isFolder && page.isPrivate,
|
||||||
|
privateNS: !isFolder ? page.privateNS : null,
|
||||||
|
parent: parentId,
|
||||||
|
pageId: isFolder ? null : page.id
|
||||||
|
})
|
||||||
|
parentId = pik
|
||||||
|
} else {
|
||||||
|
parentId = found.id
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (tree.length > 0) {
|
||||||
|
await WIKI.models.knex.table('pageTree').insert(tree)
|
||||||
|
}
|
||||||
|
|
||||||
|
await WIKI.models.knex.destroy()
|
||||||
|
|
||||||
|
WIKI.logger.info(`Rebuilding page tree: [ COMPLETED ]`)
|
||||||
|
} catch (err) {
|
||||||
|
WIKI.logger.error(`Rebuilding page tree: [ FAILED ]`)
|
||||||
|
WIKI.logger.error(err.message)
|
||||||
|
}
|
||||||
|
}
|
@ -1,69 +0,0 @@
|
|||||||
'use strict'
|
|
||||||
|
|
||||||
// /* global WIKI */
|
|
||||||
|
|
||||||
// const Promise = require('bluebird')
|
|
||||||
// const fs = Promise.promisifyAll(require('fs-extra'))
|
|
||||||
// const klaw = require('klaw')
|
|
||||||
// const moment = require('moment')
|
|
||||||
// const path = require('path')
|
|
||||||
// const entryHelper = require('../helpers/entry')
|
|
||||||
|
|
||||||
module.exports = (job) => {
|
|
||||||
return true
|
|
||||||
// return WIKI.git.resync().then(() => {
|
|
||||||
// // -> Stream all documents
|
|
||||||
|
|
||||||
// let cacheJobs = []
|
|
||||||
// let jobCbStreamDocsResolve = null
|
|
||||||
// let jobCbStreamDocs = new Promise((resolve, reject) => {
|
|
||||||
// jobCbStreamDocsResolve = resolve
|
|
||||||
// })
|
|
||||||
|
|
||||||
// klaw(WIKI.REPOPATH).on('data', function (item) {
|
|
||||||
// if (path.extname(item.path) === '.md' && path.basename(item.path) !== 'README.md') {
|
|
||||||
// let entryPath = entryHelper.parsePath(entryHelper.getEntryPathFromFullPath(item.path))
|
|
||||||
// let cachePath = entryHelper.getCachePath(entryPath)
|
|
||||||
|
|
||||||
// // -> Purge outdated cache
|
|
||||||
|
|
||||||
// cacheJobs.push(
|
|
||||||
// fs.statAsync(cachePath).then((st) => {
|
|
||||||
// return moment(st.mtime).isBefore(item.stats.mtime) ? 'expired' : 'active'
|
|
||||||
// }).catch((err) => {
|
|
||||||
// return (err.code !== 'EEXIST') ? err : 'new'
|
|
||||||
// }).then((fileStatus) => {
|
|
||||||
// // -> Delete expired cache file
|
|
||||||
|
|
||||||
// if (fileStatus === 'expired') {
|
|
||||||
// return fs.unlinkAsync(cachePath).return(fileStatus)
|
|
||||||
// }
|
|
||||||
|
|
||||||
// return fileStatus
|
|
||||||
// }).then((fileStatus) => {
|
|
||||||
// // -> Update cache and search index
|
|
||||||
|
|
||||||
// if (fileStatus !== 'active') {
|
|
||||||
// return global.entries.updateCache(entryPath).then(entry => {
|
|
||||||
// process.send({
|
|
||||||
// action: 'searchAdd',
|
|
||||||
// content: entry
|
|
||||||
// })
|
|
||||||
// return true
|
|
||||||
// })
|
|
||||||
// }
|
|
||||||
|
|
||||||
// return true
|
|
||||||
// })
|
|
||||||
// )
|
|
||||||
// }
|
|
||||||
// }).on('end', () => {
|
|
||||||
// jobCbStreamDocsResolve(Promise.all(cacheJobs))
|
|
||||||
// })
|
|
||||||
|
|
||||||
// return jobCbStreamDocs
|
|
||||||
// }).then(() => {
|
|
||||||
// WIKI.logger.info('Git remote repository sync: DONE')
|
|
||||||
// return true
|
|
||||||
// })
|
|
||||||
}
|
|
Loading…
Reference in new issue