2022-12-08 19:14:06 +01:00
import { Prisma , PrismaClient } from "@prisma/client" ;
2022-12-02 15:10:49 +01:00
import * as crypto from "crypto" ;
2022-12-08 19:14:06 +01:00
const configVariables : Prisma.ConfigCreateInput [ ] = [
2022-12-02 15:10:49 +01:00
{
2023-01-26 14:06:25 +01:00
order : 0 ,
2022-12-05 16:53:52 +01:00
key : "SETUP_FINISHED" ,
2023-01-26 14:06:25 +01:00
description : "Status of the setup wizard" ,
2022-12-02 15:10:49 +01:00
type : "boolean" ,
value : "false" ,
2022-12-30 14:40:23 +01:00
category : "internal" ,
2022-12-02 15:10:49 +01:00
secret : false ,
locked : true ,
} ,
{
2023-01-26 14:06:25 +01:00
order : 0 ,
key : "JWT_SECRET" ,
description : "Long random string used to sign JWT tokens" ,
type : "string" ,
value : crypto.randomBytes ( 256 ) . toString ( "base64" ) ,
category : "internal" ,
locked : true ,
} ,
{
order : 0 ,
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 ,
} ,
{
order : 1 ,
2022-12-05 16:53:52 +01:00
key : "APP_URL" ,
2022-12-02 15:10:49 +01:00
description : "On which URL Pingvin Share is available" ,
type : "string" ,
value : "http://localhost:3000" ,
2022-12-30 14:40:23 +01:00
category : "general" ,
2022-12-02 15:10:49 +01:00
secret : false ,
} ,
{
2023-01-26 14:06:25 +01:00
order : 2 ,
2022-12-05 16:53:52 +01:00
key : "SHOW_HOME_PAGE" ,
2022-12-02 15:10:49 +01:00
description : "Whether to show the home page" ,
type : "boolean" ,
value : "true" ,
2022-12-30 14:40:23 +01:00
category : "general" ,
2022-12-02 15:10:49 +01:00
secret : false ,
} ,
{
2023-01-26 14:06:25 +01:00
order : 3 ,
2022-12-05 16:53:52 +01:00
key : "ALLOW_REGISTRATION" ,
2022-12-02 15:10:49 +01:00
description : "Whether registration is allowed" ,
type : "boolean" ,
value : "true" ,
2022-12-30 14:40:23 +01:00
category : "share" ,
2022-12-02 15:10:49 +01:00
secret : false ,
} ,
{
2023-01-26 14:06:25 +01:00
order : 4 ,
2022-12-05 16:53:52 +01:00
key : "ALLOW_UNAUTHENTICATED_SHARES" ,
2022-12-02 15:10:49 +01:00
description : "Whether unauthorized users can create shares" ,
type : "boolean" ,
value : "false" ,
2022-12-30 14:40:23 +01:00
category : "share" ,
2022-12-02 15:10:49 +01:00
secret : false ,
} ,
{
2023-01-26 14:06:25 +01:00
order : 5 ,
2023-01-26 13:44:04 +01:00
2023-01-09 11:43:48 +01:00
key : "MAX_SHARE_SIZE" ,
description : "Maximum share size in bytes" ,
2022-12-02 15:10:49 +01:00
type : "number" ,
2023-01-09 11:43:48 +01:00
value : "1073741824" ,
2022-12-30 14:40:23 +01:00
category : "share" ,
2022-12-02 15:10:49 +01:00
secret : false ,
} ,
2023-01-26 14:06:25 +01:00
2022-12-02 15:10:49 +01:00
{
2023-01-26 14:06:25 +01:00
order : 6 ,
2023-01-26 13:44:04 +01:00
key : "ENABLE_SHARE_EMAIL_RECIPIENTS" ,
2022-12-02 15:10:49 +01:00
description :
2023-01-26 13:44:04 +01:00
"Whether to allow emails to share recipients. Only enable this if you have enabled SMTP." ,
2022-12-02 15:10:49 +01:00
type : "boolean" ,
value : "false" ,
2022-12-30 14:40:23 +01:00
category : "email" ,
2022-12-02 15:10:49 +01:00
secret : false ,
} ,
2022-12-15 21:44:04 +01:00
{
2023-01-26 14:06:25 +01:00
order : 7 ,
2023-01-26 13:44:04 +01:00
key : "SHARE_RECEPIENTS_EMAIL_MESSAGE" ,
2022-12-23 10:57:09 +01:00
description :
2023-01-26 13:44:04 +01:00
"Message which gets sent to the share recipients. {creator} and {shareUrl} will be replaced with the creator's name and the share URL." ,
2022-12-15 21:44:04 +01:00
type : "text" ,
2022-12-23 10:57:09 +01:00
value :
"Hey!\n{creator} shared some files with you. View or download the files with this link: {shareUrl}\nShared securely with Pingvin Share 🐧" ,
2023-01-26 13:44:04 +01:00
category : "email" ,
2022-12-23 10:57:09 +01:00
} ,
{
2023-01-26 14:06:25 +01:00
order : 8 ,
2023-01-26 13:44:04 +01:00
key : "SHARE_RECEPIENTS_EMAIL_SUBJECT" ,
description :
"Subject of the email which gets sent to the share recipients." ,
2022-12-23 10:57:09 +01:00
type : "string" ,
value : "Files shared with you" ,
2022-12-30 14:40:23 +01:00
category : "email" ,
2022-12-15 21:44:04 +01:00
} ,
2022-12-02 15:10:49 +01:00
{
2023-01-26 14:06:25 +01:00
order : 9 ,
2023-01-26 13:44:04 +01:00
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" ,
} ,
{
2023-01-26 14:06:25 +01:00
order : 10 ,
2023-01-26 13:44:04 +01:00
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" ,
} ,
{
2023-01-26 14:06:25 +01:00
order : 11 ,
2023-01-26 13:44:04 +01:00
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 ,
} ,
{
2023-01-26 14:06:25 +01:00
order : 12 ,
2022-12-05 16:53:52 +01:00
key : "SMTP_HOST" ,
2022-12-02 15:10:49 +01:00
description : "Host of the SMTP server" ,
type : "string" ,
value : "" ,
2023-01-26 13:44:04 +01:00
category : "smtp" ,
2022-12-02 15:10:49 +01:00
} ,
{
2023-01-26 14:06:25 +01:00
order : 13 ,
2022-12-05 16:53:52 +01:00
key : "SMTP_PORT" ,
2022-12-02 15:10:49 +01:00
description : "Port of the SMTP server" ,
type : "number" ,
2022-12-30 14:40:23 +01:00
value : "0" ,
2023-01-26 13:44:04 +01:00
category : "smtp" ,
2022-12-02 15:10:49 +01:00
} ,
{
2023-01-26 14:06:25 +01:00
order : 14 ,
2022-12-05 16:53:52 +01:00
key : "SMTP_EMAIL" ,
2022-12-08 20:00:04 +01:00
description : "Email address which the emails get sent from" ,
type : "string" ,
value : "" ,
2023-01-26 13:44:04 +01:00
category : "smtp" ,
2022-12-08 20:00:04 +01:00
} ,
{
2023-01-26 14:06:25 +01:00
order : 15 ,
2022-12-08 20:00:04 +01:00
key : "SMTP_USERNAME" ,
description : "Username of the SMTP server" ,
2022-12-02 15:10:49 +01:00
type : "string" ,
value : "" ,
2023-01-26 13:44:04 +01:00
category : "smtp" ,
2022-12-02 15:10:49 +01:00
} ,
{
2023-01-26 14:06:25 +01:00
order : 16 ,
2022-12-05 16:53:52 +01:00
key : "SMTP_PASSWORD" ,
2022-12-02 15:10:49 +01:00
description : "Password of the SMTP server" ,
type : "string" ,
value : "" ,
2022-12-08 19:14:06 +01:00
obscured : true ,
2023-01-26 13:44:04 +01:00
category : "smtp" ,
2022-12-02 15:10:49 +01:00
} ,
] ;
2022-11-28 15:04:32 +01:00
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 ( ) ;
2022-12-08 20:00:04 +01:00
// Delete the config variable if it doesn't exist anymore
2022-11-28 15:04:32 +01:00
for ( const configVariableFromDatabase of configVariablesFromDatabase ) {
2022-12-08 20:00:04 +01:00
const configVariable = configVariables . find (
( v ) = > v . key == configVariableFromDatabase . key
) ;
if ( ! configVariable ) {
2022-11-28 15:04:32 +01:00
await prisma . config . delete ( {
where : { key : configVariableFromDatabase.key } ,
} ) ;
2022-12-08 20:00:04 +01:00
// Update the config variable if the metadata changed
} else if (
JSON . stringify ( {
2022-12-08 21:58:58 +01:00
. . . configVariable ,
2022-12-08 20:00:04 +01:00
key : configVariableFromDatabase.key ,
value : configVariableFromDatabase.value ,
} ) != JSON . stringify ( configVariableFromDatabase )
) {
await prisma . config . update ( {
where : { key : configVariableFromDatabase.key } ,
2022-12-08 21:58:58 +01:00
data : {
. . . configVariable ,
key : configVariableFromDatabase.key ,
value : configVariableFromDatabase.value ,
} ,
2022-12-08 20:00:04 +01:00
} ) ;
2022-11-28 15:04:32 +01:00
}
}
}
main ( )
. then ( async ( ) = > {
await prisma . $disconnect ( ) ;
} )
. catch ( async ( e ) = > {
console . error ( e ) ;
await prisma . $disconnect ( ) ;
process . exit ( 1 ) ;
} ) ;