Shit ton of changes in changing and upgrading to use svk's modern features (observability, remote functions)
This commit is contained in:
@@ -16,6 +16,7 @@ export const settingsSchema = v.object({
|
||||
databaseUrl: v.string(),
|
||||
|
||||
internalApiKey: v.string(),
|
||||
debugKey: v.string(),
|
||||
|
||||
processorApiUrl: v.string(),
|
||||
|
||||
@@ -27,33 +28,10 @@ export const settingsSchema = v.object({
|
||||
twofaRequiredHours: v.optional(v.number()),
|
||||
|
||||
defaultAdminEmail: v.string(),
|
||||
defaultAdminPassword: v.string(),
|
||||
|
||||
googleClientId: v.string(),
|
||||
googleClientSecret: v.string(),
|
||||
|
||||
resendApiKey: v.string(),
|
||||
fromEmail: v.string(),
|
||||
|
||||
qstashUrl: v.string(),
|
||||
qstashToken: v.string(),
|
||||
qstashCurrentSigningKey: v.string(),
|
||||
qstashNextSigningKey: v.string(),
|
||||
|
||||
axiomDatasetName: v.string(),
|
||||
axiomApiToken: v.string(),
|
||||
|
||||
// R2/Object Storage settings
|
||||
r2BucketName: v.string(),
|
||||
r2Region: v.string(),
|
||||
r2Endpoint: v.string(),
|
||||
r2AccessKey: v.string(),
|
||||
r2SecretKey: v.string(),
|
||||
r2PublicUrl: v.optional(v.string()),
|
||||
|
||||
// File upload settings
|
||||
maxFileSize: v.number(),
|
||||
allowedMimeTypes: v.array(v.string()),
|
||||
allowedExtensions: v.array(v.string()),
|
||||
otelServiceName: v.string(),
|
||||
otelExporterOtlpHttpEndpoint: v.string(),
|
||||
});
|
||||
|
||||
export type Settings = v.InferOutput<typeof settingsSchema>;
|
||||
@@ -75,16 +53,6 @@ function getEnvNumber(key: string, defaultValue: number): number {
|
||||
return Number.isNaN(parsed) ? defaultValue : parsed;
|
||||
}
|
||||
|
||||
/**
|
||||
* Parse comma-separated string into array
|
||||
*/
|
||||
function parseCommaSeparated(value: string): string[] {
|
||||
return value
|
||||
.split(",")
|
||||
.map((item) => item.trim())
|
||||
.filter((item) => item.length > 0);
|
||||
}
|
||||
|
||||
/**
|
||||
* Load and validate settings from environment variables
|
||||
*/
|
||||
@@ -116,39 +84,11 @@ function loadSettings(): Settings {
|
||||
twofaRequiredHours: getEnvNumber("TWOFA_REQUIRED_HOURS", 24),
|
||||
|
||||
defaultAdminEmail: getEnv("DEFAULT_ADMIN_EMAIL"),
|
||||
defaultAdminPassword: getEnv("DEFAULT_ADMIN_PASSWORD"),
|
||||
|
||||
googleClientId: getEnv("GOOGLE_CLIENT_ID"),
|
||||
googleClientSecret: getEnv("GOOGLE_CLIENT_SECRET"),
|
||||
|
||||
resendApiKey: getEnv("RESEND_API_KEY"),
|
||||
fromEmail: getEnv("FROM_EMAIL"),
|
||||
|
||||
qstashUrl: getEnv("QSTASH_URL"),
|
||||
qstashToken: getEnv("QSTASH_TOKEN"),
|
||||
qstashCurrentSigningKey: getEnv("QSTASH_CURRENT_SIGNING_KEY"),
|
||||
qstashNextSigningKey: getEnv("QSTASH_NEXT_SIGNING_KEY"),
|
||||
|
||||
axiomDatasetName: getEnv("AXIOM_DATASET_NAME"),
|
||||
axiomApiToken: getEnv("AXIOM_API_TOKEN"),
|
||||
|
||||
// R2/Object Storage settings
|
||||
r2BucketName: getEnv("R2_BUCKET_NAME"),
|
||||
r2Region: getEnv("R2_REGION", "auto"),
|
||||
r2Endpoint: getEnv("R2_ENDPOINT"),
|
||||
r2AccessKey: getEnv("R2_ACCESS_KEY"),
|
||||
r2SecretKey: getEnv("R2_SECRET_KEY"),
|
||||
r2PublicUrl: getEnv("R2_PUBLIC_URL") || undefined,
|
||||
|
||||
// File upload settings
|
||||
maxFileSize: getEnvNumber("MAX_FILE_SIZE", 10485760), // 10MB default
|
||||
allowedMimeTypes: parseCommaSeparated(
|
||||
getEnv(
|
||||
"ALLOWED_MIME_TYPES",
|
||||
"image/jpeg,image/png,image/webp,image/gif,application/pdf,text/plain",
|
||||
),
|
||||
),
|
||||
allowedExtensions: parseCommaSeparated(
|
||||
getEnv("ALLOWED_EXTENSIONS", "jpg,jpeg,png,webp,gif,pdf,txt"),
|
||||
otelServiceName: getEnv("OTEL_SERVICE_NAME"),
|
||||
otelExporterOtlpHttpEndpoint: getEnv(
|
||||
"OTEL_EXPORTER_OTLP_HTTP_ENDPOINT",
|
||||
),
|
||||
};
|
||||
|
||||
|
||||
Reference in New Issue
Block a user