mirror of
https://git.sr.ht/~cadence/bibliogram
synced 2025-12-16 03:08:47 +00:00
Redesign return from settings page
This commit is contained in:
@@ -4,6 +4,7 @@ const {fetchUser, getOrFetchShortcode, userRequestCache, history, assistantSwitc
|
||||
const {render, redirect, getStaticURL} = require("pinski/plugins")
|
||||
const {pugCache} = require("../passthrough")
|
||||
const {getSettings} = require("./utils/getsettings")
|
||||
const {getSettingsReferrer} = require("./utils/settingsreferrer")
|
||||
|
||||
/** @param {import("../../lib/structures/TimelineEntry")} post */
|
||||
function getPageTitle(post) {
|
||||
@@ -16,6 +17,7 @@ module.exports = [
|
||||
const settings = getSettings(req)
|
||||
return render(200, "pug/home.pug", {
|
||||
settings,
|
||||
settingsReferrer: getSettingsReferrer("/"),
|
||||
rssEnabled: constants.feeds.enabled,
|
||||
allUnblocked: history.testNoneBlocked() || assistantSwitcher.displaySomeUnblocked(),
|
||||
torAvailable: switcher.canUseTor(),
|
||||
@@ -76,7 +78,14 @@ module.exports = [
|
||||
|
||||
const settings = getSettings(req)
|
||||
|
||||
return render(200, "pug/user.pug", {url, user, followerCountsAvailable, constants, settings})
|
||||
return render(200, "pug/user.pug", {
|
||||
url,
|
||||
user,
|
||||
followerCountsAvailable,
|
||||
constants,
|
||||
settings,
|
||||
settingsReferrer: getSettingsReferrer(req.url)
|
||||
})
|
||||
}).catch(error => {
|
||||
if (error === constants.symbols.NOT_FOUND || error === constants.symbols.ENDPOINT_OVERRIDDEN) {
|
||||
return render(404, "pug/friendlyerror.pug", {
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
const constants = require("../../lib/constants")
|
||||
const {render, redirect} = require("pinski/plugins")
|
||||
const {getSettings, getToken, generateCSRF, checkCSRF} = require("./utils/getsettings")
|
||||
const {getSettingsReferrer} = require("./utils/settingsreferrer")
|
||||
const crypto = require("crypto")
|
||||
const db = require("../../lib/db")
|
||||
|
||||
@@ -12,11 +13,21 @@ module.exports = [
|
||||
const csrf = generateCSRF()
|
||||
const message = url.searchParams.get("message")
|
||||
const status = url.searchParams.get("status")
|
||||
return render(200, "pug/settings.pug", {constants, settings, csrf, status, message})
|
||||
return render(200, "pug/settings.pug", {
|
||||
stayAction: getSettingsReferrer(url.searchParams.get("referrer"), "/settings/stay"),
|
||||
returnAction: getSettingsReferrer(url.searchParams.get("referrer"), "/settings/return"),
|
||||
returnURL: url.searchParams.get("referrer") || "/",
|
||||
constants,
|
||||
settings,
|
||||
csrf,
|
||||
status,
|
||||
message
|
||||
})
|
||||
}
|
||||
},
|
||||
{
|
||||
route: "/settings", methods: ["POST"], upload: true, code: async ({req, body}) => {
|
||||
route: "/settings/(stay|return)", methods: ["POST"], upload: true, code: async ({req, body, fill, url}) => {
|
||||
const action = fill[0]
|
||||
const oldToken = getToken(req)
|
||||
const params = new URLSearchParams(body.toString())
|
||||
if (!checkCSRF(params.get("csrf"))) {
|
||||
@@ -53,10 +64,22 @@ module.exports = [
|
||||
db.prepare(`INSERT INTO UserSettings (token, created, ${fields.join(", ")}) VALUES (@token, @created, ${fields.map(f => "@"+f).join(", ")})`).run(prepared)
|
||||
db.prepare("DELETE FROM UserSettings WHERE token = ?").run(oldToken)
|
||||
const expires = new Date(Date.now() + 4000*24*60*60*1000).toUTCString()
|
||||
let location
|
||||
if (action === "return" && url.searchParams.has("referrer")) {
|
||||
location = url.searchParams.get("referrer")
|
||||
} else { // stay
|
||||
const newParams = new URLSearchParams()
|
||||
newParams.append("status", "success")
|
||||
newParams.append("message", "Saved.")
|
||||
if (url.searchParams.has("referrer")) {
|
||||
newParams.append("referrer", url.searchParams.get("referrer"))
|
||||
}
|
||||
location = "/settings?" + newParams.toString()
|
||||
}
|
||||
return {
|
||||
statusCode: 303,
|
||||
headers: {
|
||||
"Location": "/settings?status=success&message=Saved.",
|
||||
"Location": location,
|
||||
"Set-Cookie": `settings=${prepared.token}; Path=/; Expires=${expires}; SameSite=Lax`
|
||||
},
|
||||
contentType: "text/html; charset=UTF-8",
|
||||
|
||||
8
src/site/api/utils/settingsreferrer.js
Normal file
8
src/site/api/utils/settingsreferrer.js
Normal file
@@ -0,0 +1,8 @@
|
||||
function getSettingsReferrer(current, settingsURL = "/settings") {
|
||||
if (!current) return settingsURL
|
||||
const params = new URLSearchParams()
|
||||
params.append("referrer", current)
|
||||
return settingsURL + "?" + params.toString()
|
||||
}
|
||||
|
||||
module.exports.getSettingsReferrer = getSettingsReferrer
|
||||
Reference in New Issue
Block a user