feat: browse page by ID
This commit is contained in:
parent
e836a49776
commit
b18dd29fa0
@ -16,6 +16,8 @@ defaults:
|
|||||||
db: wiki
|
db: wiki
|
||||||
ssl: false
|
ssl: false
|
||||||
storage: ./db.sqlite
|
storage: ./db.sqlite
|
||||||
|
sslOptions:
|
||||||
|
auto: true
|
||||||
ssl:
|
ssl:
|
||||||
enabled: false
|
enabled: false
|
||||||
pool:
|
pool:
|
||||||
|
@ -129,6 +129,39 @@ router.get(['/h', '/h/*'], async (req, res, next) => {
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Page ID redirection
|
||||||
|
*/
|
||||||
|
router.get(['/i', '/i/:id'], async (req, res, next) => {
|
||||||
|
const pageId = _.toSafeInteger(req.params.id)
|
||||||
|
if (pageId <= 0) {
|
||||||
|
return res.redirect('/')
|
||||||
|
}
|
||||||
|
|
||||||
|
const page = await WIKI.models.pages.query().column(['path', 'localeCode', 'isPrivate', 'privateNS']).findById(pageId)
|
||||||
|
if (!page) {
|
||||||
|
_.set(res.locals, 'pageMeta.title', 'Page Not Found')
|
||||||
|
return res.status(404).render('notfound', { action: 'view' })
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!WIKI.auth.checkAccess(req.user, ['read:pages'], {
|
||||||
|
locale: page.localeCode,
|
||||||
|
path: page.path,
|
||||||
|
private: page.isPrivate,
|
||||||
|
privateNS: page.privateNS,
|
||||||
|
explicitLocale: false
|
||||||
|
})) {
|
||||||
|
_.set(res.locals, 'pageMeta.title', 'Unauthorized')
|
||||||
|
return res.render('unauthorized', { action: 'view' })
|
||||||
|
}
|
||||||
|
|
||||||
|
if (WIKI.config.lang.namespacing) {
|
||||||
|
return res.redirect(`/${page.localeCode}/${page.path}`)
|
||||||
|
} else {
|
||||||
|
return res.redirect(`/${page.path}`)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Profile
|
* Profile
|
||||||
*/
|
*/
|
||||||
|
@ -136,7 +136,7 @@ module.exports = {
|
|||||||
* Close all active connections
|
* Close all active connections
|
||||||
*/
|
*/
|
||||||
closeConnections () {
|
closeConnections () {
|
||||||
for (const conn of this.connections) {
|
for (const conn of this.connections.values()) {
|
||||||
conn.destroy()
|
conn.destroy()
|
||||||
}
|
}
|
||||||
this.connections.clear()
|
this.connections.clear()
|
||||||
|
@ -80,6 +80,12 @@ module.exports = async () => {
|
|||||||
app.use(WIKI.auth.passport.initialize())
|
app.use(WIKI.auth.passport.initialize())
|
||||||
app.use(WIKI.auth.authenticate)
|
app.use(WIKI.auth.authenticate)
|
||||||
|
|
||||||
|
// ----------------------------------------
|
||||||
|
// GraphQL Server
|
||||||
|
// ----------------------------------------
|
||||||
|
|
||||||
|
await WIKI.servers.startGraphQL()
|
||||||
|
|
||||||
// ----------------------------------------
|
// ----------------------------------------
|
||||||
// SEO
|
// SEO
|
||||||
// ----------------------------------------
|
// ----------------------------------------
|
||||||
@ -173,7 +179,6 @@ module.exports = async () => {
|
|||||||
// Start HTTP Server(s)
|
// Start HTTP Server(s)
|
||||||
// ----------------------------------------
|
// ----------------------------------------
|
||||||
|
|
||||||
await WIKI.servers.startGraphQL()
|
|
||||||
await WIKI.servers.startHTTP()
|
await WIKI.servers.startHTTP()
|
||||||
|
|
||||||
if (WIKI.config.ssl.enabled === true || WIKI.config.ssl.enabled === 'true' || WIKI.config.ssl.enabled === 1 || WIKI.config.ssl.enabled === '1') {
|
if (WIKI.config.ssl.enabled === true || WIKI.config.ssl.enabled === 'true' || WIKI.config.ssl.enabled === 1 || WIKI.config.ssl.enabled === '1') {
|
||||||
|
Loading…
Reference in New Issue
Block a user