mirror of
https://github.com/stonith404/pingvin-share.git
synced 2025-01-15 01:14:27 -05:00
4a5fb549c6
* add first concept * add reverse share funcionality to frontend * allow creator to limit share expiration * moved reverse share in seperate module * add table to manage reverse shares * delete complete share if reverse share was deleted * optimize function names * add db migration * enable reverse share email notifications * fix config variable descriptions * fix migration for new installations
235 lines
5.8 KiB
TypeScript
235 lines
5.8 KiB
TypeScript
import { Prisma, PrismaClient } from "@prisma/client";
|
|
import * as crypto from "crypto";
|
|
|
|
const configVariables: Prisma.ConfigCreateInput[] = [
|
|
{
|
|
id: 1,
|
|
key: "SETUP_FINISHED",
|
|
description: "Whether the setup has been finished",
|
|
type: "boolean",
|
|
value: "false",
|
|
category: "internal",
|
|
secret: false,
|
|
locked: true,
|
|
},
|
|
{
|
|
id: 2,
|
|
key: "APP_URL",
|
|
description: "On which URL Pingvin Share is available",
|
|
type: "string",
|
|
value: "http://localhost:3000",
|
|
category: "general",
|
|
secret: false,
|
|
},
|
|
{
|
|
id: 3,
|
|
key: "SHOW_HOME_PAGE",
|
|
description: "Whether to show the home page",
|
|
type: "boolean",
|
|
value: "true",
|
|
category: "general",
|
|
secret: false,
|
|
},
|
|
{
|
|
id: 4,
|
|
key: "ALLOW_REGISTRATION",
|
|
description: "Whether registration is allowed",
|
|
type: "boolean",
|
|
value: "true",
|
|
category: "share",
|
|
secret: false,
|
|
},
|
|
{
|
|
id: 5,
|
|
key: "ALLOW_UNAUTHENTICATED_SHARES",
|
|
description: "Whether unauthorized users can create shares",
|
|
type: "boolean",
|
|
value: "false",
|
|
category: "share",
|
|
secret: false,
|
|
},
|
|
{
|
|
id: 6,
|
|
|
|
key: "MAX_SHARE_SIZE",
|
|
description: "Maximum share size in bytes",
|
|
type: "number",
|
|
value: "1073741824",
|
|
category: "share",
|
|
secret: false,
|
|
},
|
|
{
|
|
id: 7,
|
|
key: "JWT_SECRET",
|
|
description: "Long random string used to sign JWT tokens",
|
|
type: "string",
|
|
value: crypto.randomBytes(256).toString("base64"),
|
|
category: "internal",
|
|
locked: true,
|
|
},
|
|
{
|
|
id: 8,
|
|
key: "TOTP_SECRET",
|
|
description: "A 16 byte random string used to generate TOTP secrets",
|
|
type: "string",
|
|
value: crypto.randomBytes(16).toString("base64"),
|
|
category: "internal",
|
|
locked: true,
|
|
},
|
|
{
|
|
id: 9,
|
|
key: "ENABLE_SHARE_EMAIL_RECIPIENTS",
|
|
description:
|
|
"Whether to allow emails to share recipients. Only enable this if you have enabled SMTP.",
|
|
type: "boolean",
|
|
value: "false",
|
|
category: "email",
|
|
secret: false,
|
|
},
|
|
{
|
|
id: 10,
|
|
key: "SHARE_RECEPIENTS_EMAIL_MESSAGE",
|
|
description:
|
|
"Message which gets sent to the share recipients. {creator} and {shareUrl} will be replaced with the creator's name and the share URL.",
|
|
type: "text",
|
|
value:
|
|
"Hey!\n{creator} shared some files with you. View or download the files with this link: {shareUrl}\nShared securely with Pingvin Share 🐧",
|
|
category: "email",
|
|
},
|
|
{
|
|
id: 11,
|
|
key: "SHARE_RECEPIENTS_EMAIL_SUBJECT",
|
|
description:
|
|
"Subject of the email which gets sent to the share recipients.",
|
|
type: "string",
|
|
value: "Files shared with you",
|
|
category: "email",
|
|
},
|
|
{
|
|
id: 12,
|
|
key: "REVERSE_SHARE_EMAIL_MESSAGE",
|
|
description:
|
|
"Message which gets sent when someone created a share with your reverse share link. {shareUrl} will be replaced with the creator's name and the share URL.",
|
|
type: "text",
|
|
value:
|
|
"Hey!\nA share was just created with your reverse share link: {shareUrl}\nShared securely with Pingvin Share 🐧",
|
|
category: "email",
|
|
},
|
|
{
|
|
id: 13,
|
|
key: "REVERSE_SHARE_EMAIL_SUBJECT",
|
|
description:
|
|
"Subject of the email which gets sent when someone created a share with your reverse share link.",
|
|
type: "string",
|
|
value: "Reverse share link used",
|
|
category: "email",
|
|
},
|
|
{
|
|
id: 14,
|
|
key: "SMTP_ENABLED",
|
|
description:
|
|
"Whether SMTP is enabled. Only set this to true if you entered the host, port, email, user and password of your SMTP server.",
|
|
type: "boolean",
|
|
value: "false",
|
|
category: "smtp",
|
|
secret: false,
|
|
},
|
|
{
|
|
id: 15,
|
|
key: "SMTP_HOST",
|
|
description: "Host of the SMTP server",
|
|
type: "string",
|
|
value: "",
|
|
category: "smtp",
|
|
},
|
|
{
|
|
id: 16,
|
|
key: "SMTP_PORT",
|
|
description: "Port of the SMTP server",
|
|
type: "number",
|
|
value: "0",
|
|
category: "smtp",
|
|
},
|
|
{
|
|
id: 17,
|
|
key: "SMTP_EMAIL",
|
|
description: "Email address which the emails get sent from",
|
|
type: "string",
|
|
value: "",
|
|
category: "smtp",
|
|
},
|
|
{
|
|
id: 18,
|
|
key: "SMTP_USERNAME",
|
|
description: "Username of the SMTP server",
|
|
type: "string",
|
|
value: "",
|
|
category: "smtp",
|
|
},
|
|
{
|
|
id: 19,
|
|
key: "SMTP_PASSWORD",
|
|
description: "Password of the SMTP server",
|
|
type: "string",
|
|
value: "",
|
|
obscured: true,
|
|
category: "smtp",
|
|
},
|
|
];
|
|
|
|
const prisma = new PrismaClient();
|
|
|
|
async function main() {
|
|
for (const variable of configVariables) {
|
|
const existingConfigVariable = await prisma.config.findUnique({
|
|
where: { key: variable.key },
|
|
});
|
|
|
|
// Create a new config variable if it doesn't exist
|
|
if (!existingConfigVariable) {
|
|
await prisma.config.create({
|
|
data: variable,
|
|
});
|
|
}
|
|
}
|
|
|
|
const configVariablesFromDatabase = await prisma.config.findMany();
|
|
|
|
// Delete the config variable if it doesn't exist anymore
|
|
for (const configVariableFromDatabase of configVariablesFromDatabase) {
|
|
const configVariable = configVariables.find(
|
|
(v) => v.key == configVariableFromDatabase.key
|
|
);
|
|
if (!configVariable) {
|
|
await prisma.config.delete({
|
|
where: { key: configVariableFromDatabase.key },
|
|
});
|
|
|
|
// Update the config variable if the metadata changed
|
|
} else if (
|
|
JSON.stringify({
|
|
...configVariable,
|
|
key: configVariableFromDatabase.key,
|
|
value: configVariableFromDatabase.value,
|
|
}) != JSON.stringify(configVariableFromDatabase)
|
|
) {
|
|
await prisma.config.update({
|
|
where: { key: configVariableFromDatabase.key },
|
|
data: {
|
|
...configVariable,
|
|
key: configVariableFromDatabase.key,
|
|
value: configVariableFromDatabase.value,
|
|
},
|
|
});
|
|
}
|
|
}
|
|
}
|
|
main()
|
|
.then(async () => {
|
|
await prisma.$disconnect();
|
|
})
|
|
.catch(async (e) => {
|
|
console.error(e);
|
|
await prisma.$disconnect();
|
|
process.exit(1);
|
|
});
|