* add tenant config table * add encryption/decryption + env vars * generate secret and validate iv position is number * expect errors * remove TWILIO env vars * settings page impl * update schema definitions after Mostaphas Tenant impl * load user env * just return empty config * add Settings menu item * check if settings are present and provide warning if not * correct form item names * use correct locals value * ree * give twilio its own table * lock prisma version * event url is the correct param * load twilio config from db * commit migration * use test script not bun command
33 lines
767 B
TypeScript
33 lines
767 B
TypeScript
import { z } from 'zod';
|
|
|
|
const ValidateEnvironment = () => {
|
|
const { success, error } = z
|
|
.object({
|
|
SECRETS_PASSWORD: z.string().length(32),
|
|
SECRETS_SALT: z.string().min(16),
|
|
SECRETS_IV_POSITION: z.string().transform((val, ctx) => {
|
|
const parsed = parseInt(val);
|
|
if (isNaN(parsed)) {
|
|
ctx.addIssue({
|
|
code: z.ZodIssueCode.custom,
|
|
message: 'Not a number',
|
|
});
|
|
|
|
// This is a special symbol you can use to
|
|
// return early from the transform function.
|
|
// It has type `never` so it does not affect the
|
|
// inferred return type.
|
|
return z.NEVER;
|
|
}
|
|
return parsed;
|
|
}),
|
|
})
|
|
.safeParse(process.env);
|
|
|
|
if (!success) {
|
|
console.error(error.message);
|
|
process.exit(1);
|
|
}
|
|
};
|
|
|
|
ValidateEnvironment();
|