add helpdesk article parsing
This commit is contained in:
49
liberals/directoryparsing.js
Normal file
49
liberals/directoryparsing.js
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
import { fs } from "../index.js"
|
||||||
|
|
||||||
|
function parsePosts() {
|
||||||
|
let files = fs.readdirSync(process.cwd()+"/website/posts")
|
||||||
|
let result = ""
|
||||||
|
|
||||||
|
for (let x in files) {
|
||||||
|
if (files[x].endsWith(".html") === false && files[x].endsWith(".md") === false ) { break } // If file/dir is not .html or .md then ignore
|
||||||
|
|
||||||
|
let date = files[x].split("-")[0]
|
||||||
|
if (date < 10000000 || date > 99999999) { break } // If date does not fit ISO8601 format then ignore
|
||||||
|
|
||||||
|
date = date.replace(/.{2}/g,"$&-").replace("-","").slice(0,-1) // Insert a dash every 2 characters, remove the first dash, remove the last character
|
||||||
|
|
||||||
|
let name = files[x].slice(9).replace(/-/g," ").replace(".html","").replace(".md","") // Strip Date, replace seperator with space & remove file extension
|
||||||
|
|
||||||
|
result = `<li>${date} <a href="/posts/${files[x]}">${name}</a></li>`+result
|
||||||
|
}
|
||||||
|
|
||||||
|
return result
|
||||||
|
}
|
||||||
|
|
||||||
|
function parseKbas() {
|
||||||
|
let files = fs.readdirSync(process.cwd()+"/website/helpdesk/kbas")
|
||||||
|
let pages = {}
|
||||||
|
let result = ""
|
||||||
|
|
||||||
|
for (let x in files) {
|
||||||
|
if (files[x].endsWith(".html") === false && files[x].endsWith(".md") === false ) { break } // If file/dir is not .html or .md then ignore
|
||||||
|
|
||||||
|
if (!Array.isArray(pages[files[x].split("-")[0]])) { // check if category array does not exist
|
||||||
|
pages[files[x].split("-")[0]] = [] // create it
|
||||||
|
}
|
||||||
|
|
||||||
|
pages[files[x].split("-")[0]].push(files[x])
|
||||||
|
}
|
||||||
|
|
||||||
|
for (let y in pages) {
|
||||||
|
result += `<h1>${y}</h1><div class="linkColumn">`
|
||||||
|
for (let z in pages[y]) {
|
||||||
|
result += `<a href="/helpdesk/articles/${pages[y][z]}"><img src="/dynamic/icon/post/366FFF">${pages[y][z].split("-")[1].split(".")[0].replace(/_/g," ")}</a>`
|
||||||
|
}
|
||||||
|
result += `</div>`
|
||||||
|
}
|
||||||
|
|
||||||
|
return result
|
||||||
|
}
|
||||||
|
|
||||||
|
export { parseKbas, parsePosts}
|
||||||
@@ -1,7 +1,5 @@
|
|||||||
import { app, globalConfig, fs, globalVersion } from "../index.js" // Get globals from index
|
import { app, globalConfig, fs, globalVersion } from "../index.js" // Get globals from index
|
||||||
import { execSync } from 'child_process'
|
import { parsePosts } from "../liberals/directoryparsing.js"
|
||||||
import { checkToken } from "../liberals/auth.js"
|
|
||||||
import { logRequest } from "../liberals/logging.js"
|
|
||||||
import { marked } from "marked"
|
import { marked } from "marked"
|
||||||
|
|
||||||
var timeSinceLastQuery = Date.now()-10000
|
var timeSinceLastQuery = Date.now()-10000
|
||||||
@@ -12,7 +10,7 @@ app.get("/", (rreq, rres) => {
|
|||||||
rres.send(cachedResult)
|
rres.send(cachedResult)
|
||||||
} else {
|
} else {
|
||||||
let indexFile = fs.readFileSync(process.cwd()+"/website/templates/newindextemplate.html","utf-8")
|
let indexFile = fs.readFileSync(process.cwd()+"/website/templates/newindextemplate.html","utf-8")
|
||||||
cachedResult = indexFile.replace("<!--SSR_BLOGPOSTS-->",parseFiles()).replace("<!--SSR_APIVERSION-->",`<sup>API Version ${globalVersion}</sup>`)
|
cachedResult = indexFile.replace("<!--SSR_BLOGPOSTS-->",parsePosts()).replace("<!--SSR_APIVERSION-->",`<sup>API Version ${globalVersion}</sup>`)
|
||||||
rres.send(cachedResult)
|
rres.send(cachedResult)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
@@ -43,24 +41,4 @@ app.get("/posts/*", (rreq,rres) => {
|
|||||||
|
|
||||||
})
|
})
|
||||||
|
|
||||||
function parseFiles() {
|
|
||||||
let files = fs.readdirSync(process.cwd()+"/website/posts")
|
|
||||||
let result = ""
|
|
||||||
|
|
||||||
for (let x in files) {
|
|
||||||
if (files[x].endsWith(".html") === false && files[x].endsWith(".md") === false ) { break } // If file/dir is not .html or .md then ignore
|
|
||||||
|
|
||||||
let date = files[x].split("-")[0]
|
|
||||||
if (date < 10000000 || date > 99999999) { break } // If date does not fit ISO8601 format then ignore
|
|
||||||
|
|
||||||
date = date.replace(/.{2}/g,"$&-").replace("-","").slice(0,-1) // Insert a dash every 2 characters, remove the first dash, remove the last character
|
|
||||||
|
|
||||||
let name = files[x].slice(9).replace(/-/g," ").replace(".html","").replace(".md","") // Strip Date, replace seperator with space & remove file extension
|
|
||||||
|
|
||||||
result = `<li>${date} <a href="/posts/${files[x]}">${name}</a></li>`+result
|
|
||||||
}
|
|
||||||
|
|
||||||
return result
|
|
||||||
}
|
|
||||||
|
|
||||||
export {app}
|
export {app}
|
||||||
@@ -1,4 +1,5 @@
|
|||||||
import { app, fs } from "../index.js"
|
import { app, fs } from "../index.js"
|
||||||
|
import { parseKbas } from "../liberals/directoryparsing.js"
|
||||||
import { marked } from "marked"
|
import { marked } from "marked"
|
||||||
|
|
||||||
app.get("/helpdesk", (rreq, rres) => {
|
app.get("/helpdesk", (rreq, rres) => {
|
||||||
@@ -6,7 +7,11 @@ app.get("/helpdesk", (rreq, rres) => {
|
|||||||
})
|
})
|
||||||
|
|
||||||
app.get("/helpdesk/articles", (rreq, rres) => {
|
app.get("/helpdesk/articles", (rreq, rres) => {
|
||||||
rres.send("miau")
|
let file = fs.readFileSync(process.cwd() + "/website/helpdesk/templates/article.html", "utf-8")
|
||||||
|
file = file.replace("<!--SSR_REPLACE_URL-->", `https://enstrayed.com${rreq.url}`)
|
||||||
|
file = file.replaceAll("<!--SSR_REPLACE_TITLE-->", "Knowledgebase")
|
||||||
|
file = file.replace("<!--SSR_REPLACE_BODY-->", parseKbas())
|
||||||
|
rres.send(file)
|
||||||
})
|
})
|
||||||
|
|
||||||
app.get("/helpdesk/articles/*", (rreq, rres) => {
|
app.get("/helpdesk/articles/*", (rreq, rres) => {
|
||||||
|
|||||||
@@ -20,6 +20,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="maincontent">
|
<div class="maincontent">
|
||||||
<div class="articlecontent">
|
<div class="articlecontent">
|
||||||
|
<a href="/helpdesk/articles">Return to Knowledgebase</a>
|
||||||
<!--SSR_REPLACE_BODY-->
|
<!--SSR_REPLACE_BODY-->
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
Reference in New Issue
Block a user