feat: page duplicate + code styling fixes

vega
NGPixel 3 weeks ago
parent 1a6b5851b3
commit 7425a74b6a
No known key found for this signature in database
GPG Key ID: B755FB6870B30F63

@ -12,7 +12,7 @@ export default {
fdCache: {}, fdCache: {},
async serve (pkgName, req, res, next) { async serve (pkgName, req, res, next) {
const packages = { const packages = {
'twemoji': path.join(WIKI.ROOTPATH, `assets/svg/twemoji.asar`) twemoji: path.join(WIKI.ROOTPATH, 'assets/svg/twemoji.asar')
} }
const file = this.readFilesystemSync(packages[pkgName]) const file = this.readFilesystemSync(packages[pkgName])
const { filesystem, fd } = file const { filesystem, fd } = file
@ -74,7 +74,7 @@ export default {
filesystem.headerSize = header.headerSize filesystem.headerSize = header.headerSize
this.fdCache[archive] = { this.fdCache[archive] = {
fd, fd,
filesystem: filesystem filesystem
} }
} }

@ -31,13 +31,15 @@ export default {
// Fetch DB Config // Fetch DB Config
this.config = (!isEmpty(process.env.DATABASE_URL)) ? process.env.DATABASE_URL : { this.config = (!isEmpty(process.env.DATABASE_URL))
host: WIKI.config.db.host.toString(), ? process.env.DATABASE_URL
user: WIKI.config.db.user.toString(), : {
password: WIKI.config.db.pass.toString(), host: WIKI.config.db.host.toString(),
database: WIKI.config.db.db.toString(), user: WIKI.config.db.user.toString(),
port: WIKI.config.db.port password: WIKI.config.db.pass.toString(),
} database: WIKI.config.db.db.toString(),
port: WIKI.config.db.port
}
// Handle SSL Options // Handle SSL Options
@ -88,16 +90,17 @@ export default {
connection: this.config, connection: this.config,
searchPath: [WIKI.config.db.schema], searchPath: [WIKI.config.db.schema],
pool: { pool: {
...workerMode ? { min: 0, max: 1 } : WIKI.config.pool, ...workerMode ? { min: 0, max: 1 } : WIKI.config.pool
async afterCreate(conn, done) { // FIXME: Throws DeprecatingWarning because Knex encapsulates this into a promisify...
// -> Set Connection App Name // async afterCreate (conn, done) {
if (workerMode) { // // -> Set Connection App Name
await conn.query(`set application_name = 'Wiki.js - ${WIKI.INSTANCE_ID}'`) // if (workerMode) {
} else { // await conn.query(`set application_name = 'Wiki.js - ${WIKI.INSTANCE_ID}'`)
await conn.query(`set application_name = 'Wiki.js - ${WIKI.INSTANCE_ID}:MAIN'`) // } else {
} // await conn.query(`set application_name = 'Wiki.js - ${WIKI.INSTANCE_ID}:MAIN'`)
done() // }
} // done()
// }
}, },
debug: WIKI.IS_DEBUG debug: WIKI.IS_DEBUG
}) })
@ -170,7 +173,7 @@ export default {
WIKI.configSvc.subscribeToEvents() WIKI.configSvc.subscribeToEvents()
WIKI.db.pages.subscribeToEvents() WIKI.db.pages.subscribeToEvents()
WIKI.logger.info(`PG PubSub Listener initialized successfully: [ OK ]`) WIKI.logger.info('PG PubSub Listener initialized successfully: [ OK ]')
}, },
/** /**
* Unsubscribe from database LISTEN / NOTIFY * Unsubscribe from database LISTEN / NOTIFY

@ -106,9 +106,9 @@ export default {
throw new Error('ERR_FORBIDDEN') throw new Error('ERR_FORBIDDEN')
} }
const results = args.states?.length > 0 ? const results = args.states?.length > 0
await WIKI.db.knex('jobHistory').whereIn('state', args.states.map(s => s.toLowerCase())).orderBy('startedAt', 'desc') : ? await WIKI.db.knex('jobHistory').whereIn('state', args.states.map(s => s.toLowerCase())).orderBy('startedAt', 'desc')
await WIKI.db.knex('jobHistory').orderBy('startedAt', 'desc') : await WIKI.db.knex('jobHistory').orderBy('startedAt', 'desc')
return results.map(r => ({ return results.map(r => ({
...r, ...r,
state: r.state.toUpperCase() state: r.state.toUpperCase()

@ -1,5 +1,5 @@
// =========================================== // ===========================================
// Wiki.js | Server // Wiki.js Server
// Licensed under AGPLv3 // Licensed under AGPLv3
// =========================================== // ===========================================
@ -14,8 +14,8 @@ import logger from './core/logger.mjs'
const nanoid = customAlphabet('1234567890abcdef', 10) const nanoid = customAlphabet('1234567890abcdef', 10)
if (!semver.satisfies(process.version, '>=18')) { if (!semver.satisfies(process.version, '>=20')) {
console.error('ERROR: Node.js 18.x or later required!') console.error('ERROR: Node.js 20.x or later required!')
process.exit(1) process.exit(1)
} }
@ -41,6 +41,12 @@ const WIKI = {
} }
global.WIKI = WIKI global.WIKI = WIKI
if (WIKI.IS_DEBUG) {
process.on('warning', (warning) => {
console.log(warning.stack)
})
}
await WIKI.configSvc.init() await WIKI.configSvc.init()
// ---------------------------------------- // ----------------------------------------

@ -36,8 +36,8 @@
"node": ">=18.0" "node": ">=18.0"
}, },
"dependencies": { "dependencies": {
"@apollo/server": "4.11.0", "@apollo/server": "4.11.2",
"@azure/storage-blob": "12.25.0", "@azure/storage-blob": "12.26.0",
"@exlinc/keycloak-passport": "1.0.2", "@exlinc/keycloak-passport": "1.0.2",
"@graphql-tools/schema": "10.0.7", "@graphql-tools/schema": "10.0.7",
"@graphql-tools/utils": "10.5.5", "@graphql-tools/utils": "10.5.5",
@ -51,7 +51,7 @@
"@vue-email/compiler": "0.8.14", "@vue-email/compiler": "0.8.14",
"acme": "3.0.3", "acme": "3.0.3",
"akismet-api": "6.0.0", "akismet-api": "6.0.0",
"aws-sdk": "2.1691.0", "aws-sdk": "2.1692.0",
"bcryptjs": "2.4.3", "bcryptjs": "2.4.3",
"chalk": "5.3.0", "chalk": "5.3.0",
"cheerio": "1.0.0", "cheerio": "1.0.0",
@ -59,7 +59,7 @@
"chromium-pickle-js": "0.2.0", "chromium-pickle-js": "0.2.0",
"clean-css": "5.3.3", "clean-css": "5.3.3",
"command-exists": "1.2.9", "command-exists": "1.2.9",
"compression": "1.7.4", "compression": "1.7.5",
"connect-session-knex": "5.0.0", "connect-session-knex": "5.0.0",
"cookie-parser": "1.4.7", "cookie-parser": "1.4.7",
"cors": "2.8.5", "cors": "2.8.5",
@ -69,11 +69,11 @@
"dependency-graph": "1.0.0", "dependency-graph": "1.0.0",
"diff": "7.0.0", "diff": "7.0.0",
"diff2html": "3.4.48", "diff2html": "3.4.48",
"dompurify": "3.1.7", "dompurify": "3.2.2",
"dotize": "0.3.0", "dotize": "0.3.0",
"emoji-regex": "10.4.0", "emoji-regex": "10.4.0",
"eventemitter2": "6.4.9", "eventemitter2": "6.4.9",
"express": "4.21.1", "express": "4.21.2",
"express-brute": "1.0.1", "express-brute": "1.0.1",
"express-session": "1.18.1", "express-session": "1.18.1",
"file-type": "19.6.0", "file-type": "19.6.0",
@ -82,7 +82,7 @@
"getos": "3.2.1", "getos": "3.2.1",
"graphql": "16.9.0", "graphql": "16.9.0",
"graphql-list-fields": "2.0.4", "graphql-list-fields": "2.0.4",
"graphql-rate-limit-directive": "2.0.5", "graphql-rate-limit-directive": "2.0.6",
"graphql-tools": "9.0.2", "graphql-tools": "9.0.2",
"graphql-upload": "17.0.0", "graphql-upload": "17.0.0",
"gray-matter": "4.0.3", "gray-matter": "4.0.3",
@ -102,7 +102,7 @@
"luxon": "3.5.0", "luxon": "3.5.0",
"markdown-it": "14.1.0", "markdown-it": "14.1.0",
"markdown-it-abbr": "2.0.0", "markdown-it-abbr": "2.0.0",
"markdown-it-attrs": "4.2.0", "markdown-it-attrs": "4.3.0",
"markdown-it-decorate": "1.2.2", "markdown-it-decorate": "1.2.2",
"markdown-it-emoji": "3.0.0", "markdown-it-emoji": "3.0.0",
"markdown-it-expand-tabs": "1.0.13", "markdown-it-expand-tabs": "1.0.13",
@ -118,10 +118,10 @@
"mime-types": "2.1.35", "mime-types": "2.1.35",
"ms": "2.1.3", "ms": "2.1.3",
"multer": "1.4.5-lts.1", "multer": "1.4.5-lts.1",
"nanoid": "5.0.7", "nanoid": "5.0.9",
"node-2fa": "2.0.3", "node-2fa": "2.0.3",
"node-cache": "5.1.2", "node-cache": "5.1.2",
"nodemailer": "6.9.15", "nodemailer": "6.9.16",
"objection": "3.1.5", "objection": "3.1.5",
"octokit": "4.0.2", "octokit": "4.0.2",
"passport": "0.7.0", "passport": "0.7.0",
@ -144,15 +144,15 @@
"passport-slack-oauth2": "1.2.0", "passport-slack-oauth2": "1.2.0",
"passport-twitch-strategy": "2.2.0", "passport-twitch-strategy": "2.2.0",
"pem-jwk": "2.0.0", "pem-jwk": "2.0.0",
"pg": "8.13.0", "pg": "8.13.1",
"pg-hstore": "2.3.4", "pg-hstore": "2.3.4",
"pg-pubsub": "0.8.1", "pg-pubsub": "0.8.1",
"pg-query-stream": "4.7.0", "pg-query-stream": "4.7.1",
"pg-tsquery": "8.4.2", "pg-tsquery": "8.4.2",
"poolifier": "4.3.0", "poolifier": "4.4.5",
"prom-client": "15.1.3", "prom-client": "15.1.3",
"punycode": "2.3.1", "punycode": "2.3.1",
"puppeteer-core": "23.6.0", "puppeteer-core": "23.10.1",
"qr-image": "3.2.0", "qr-image": "3.2.0",
"remove-markdown": "0.5.5", "remove-markdown": "0.5.5",
"safe-regex": "2.1.1", "safe-regex": "2.1.1",
@ -162,25 +162,25 @@
"serve-favicon": "2.5.0", "serve-favicon": "2.5.0",
"sharp": "0.33.5", "sharp": "0.33.5",
"simple-git": "3.27.0", "simple-git": "3.27.0",
"socket.io": "4.8.0", "socket.io": "4.8.1",
"striptags": "3.2.0", "striptags": "3.2.0",
"tar-fs": "3.0.6", "tar-fs": "3.0.6",
"turndown": "7.2.0", "turndown": "7.2.0",
"twemoji": "14.0.2", "twemoji": "14.0.2",
"ufo": "1.5.4", "ufo": "1.5.4",
"uslug": "1.0.4", "uslug": "1.0.4",
"uuid": "10.0.0", "uuid": "11.0.3",
"validate.js": "0.13.1", "validate.js": "0.13.1",
"vue": "3.5.12", "vue": "3.5.13",
"xss": "1.0.15", "xss": "1.0.15",
"yargs": "17.7.2" "yargs": "17.7.2"
}, },
"devDependencies": { "devDependencies": {
"eslint": "9.13.0", "eslint": "9.16.0",
"eslint-plugin-import": "2.31.0", "eslint-plugin-import": "2.31.0",
"eslint-plugin-node": "11.1.0", "eslint-plugin-node": "11.1.0",
"eslint-plugin-promise": "7.1.0", "eslint-plugin-promise": "7.2.1",
"neostandard": "0.11.6", "neostandard": "0.11.9",
"nodemon": "3.1.7" "nodemon": "3.1.7"
}, },
"overrides": { "overrides": {

File diff suppressed because it is too large Load Diff

@ -229,8 +229,8 @@ function duplicatePage () {
itemTitle: pageStore.title, itemTitle: pageStore.title,
itemFileName: pageStore.path itemFileName: pageStore.path
} }
}).onOk(() => { }).onOk((newPageOpts) => {
// TODO: change route to new location pageStore.pageDuplicate({ sourecePageId: pageStore.id, path: newPageOpts.path, title: newPageOpts.title })
}) })
} }

@ -380,6 +380,48 @@ export const usePageStore = defineStore('page', {
mode: 'edit' mode: 'edit'
}) })
}, },
/**
* PAGE - DUPLICATE
*/
async pageDuplicate ({ sourecePageId, title, path }) {
try {
const resp = await APOLLO_CLIENT.query({
query: gql`
query loadPageSource (
$id: UUID!
) {
pageById(
id: $id
) {
id
content
contentType
description
editor
}
}
`,
variables: {
id: sourecePageId ?? pageStore.id
},
fetchPolicy: 'network-only'
})
const pageData = cloneDeep(resp?.data?.pageById ?? {})
if (!pageData?.id) {
throw new Error('ERR_PAGE_NOT_FOUND')
}
this.pageCreate({
editor: pageData.editor,
title,
path,
content: pageData.content,
description: pageData.description
})
} catch (err) {
console.warn(err)
throw err
}
},
/** /**
* PAGE - EDIT * PAGE - EDIT
*/ */

Loading…
Cancel
Save