feat: browse page by ID
This commit is contained in:
		| @@ -16,6 +16,8 @@ defaults: | ||||
|       db: wiki | ||||
|       ssl: false | ||||
|       storage: ./db.sqlite | ||||
|       sslOptions: | ||||
|         auto: true | ||||
|     ssl: | ||||
|       enabled: false | ||||
|     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 | ||||
|  */ | ||||
|   | ||||
| @@ -136,7 +136,7 @@ module.exports = { | ||||
|    * Close all active connections | ||||
|    */ | ||||
|   closeConnections () { | ||||
|     for (const conn of this.connections) { | ||||
|     for (const conn of this.connections.values()) { | ||||
|       conn.destroy() | ||||
|     } | ||||
|     this.connections.clear() | ||||
|   | ||||
| @@ -80,6 +80,12 @@ module.exports = async () => { | ||||
|   app.use(WIKI.auth.passport.initialize()) | ||||
|   app.use(WIKI.auth.authenticate) | ||||
|  | ||||
|   // ---------------------------------------- | ||||
|   // GraphQL Server | ||||
|   // ---------------------------------------- | ||||
|  | ||||
|   await WIKI.servers.startGraphQL() | ||||
|  | ||||
|   // ---------------------------------------- | ||||
|   // SEO | ||||
|   // ---------------------------------------- | ||||
| @@ -173,7 +179,6 @@ module.exports = async () => { | ||||
|   // Start HTTP Server(s) | ||||
|   // ---------------------------------------- | ||||
|  | ||||
|   await WIKI.servers.startGraphQL() | ||||
|   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') { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user