mirror of
https://github.com/fallenbagel/jellyseerr.git
synced 2025-12-24 02:39:18 -05:00
* feat: add Overseerr migration * refactor: rename to Seerr * refactor: more rename to Seerr * feat: update the value of the MediaStatus.DELETED enum * fix: add more details in migration logs * fix: replace .update by .save for TypeORM hooks * fix: add fake migration to skip the duplicated UpdateWebPush migration * fix: rewrite the AddUserAvatarCacheFields migration for Overseerr merge * fix: replace jellyseerr migrations with a dedicated one for overseerr * fix: update overseerr migration * fix: update overseerr migration * fix: remove irrelevant changes * fix: typos * docs: update jsdoc comment * docs: update seerr description * docs: fix the contributing.md link * fix: remove unwanterd change on postgres dev datasource * docs: add latest tag to docker image * fix: migrate old deleted status for 4k media * fix: update Seerr version check
124 lines
3.5 KiB
TypeScript
124 lines
3.5 KiB
TypeScript
import fs from 'fs';
|
|
import type { TlsOptions } from 'tls';
|
|
import type { DataSourceOptions, EntityTarget, Repository } from 'typeorm';
|
|
import { DataSource } from 'typeorm';
|
|
|
|
const DB_SSL_PREFIX = 'DB_SSL_';
|
|
|
|
function boolFromEnv(envVar: string, defaultVal = false) {
|
|
if (process.env[envVar]) {
|
|
return process.env[envVar]?.toLowerCase() === 'true';
|
|
}
|
|
return defaultVal;
|
|
}
|
|
|
|
function stringOrReadFileFromEnv(envVar: string): Buffer | string | undefined {
|
|
if (process.env[envVar]) {
|
|
return process.env[envVar];
|
|
}
|
|
const filePath = process.env[`${envVar}_FILE`];
|
|
if (filePath) {
|
|
return fs.readFileSync(filePath);
|
|
}
|
|
return undefined;
|
|
}
|
|
|
|
function buildSslConfig(): TlsOptions | undefined {
|
|
if (process.env.DB_USE_SSL?.toLowerCase() !== 'true') {
|
|
return undefined;
|
|
}
|
|
return {
|
|
rejectUnauthorized: boolFromEnv(
|
|
`${DB_SSL_PREFIX}REJECT_UNAUTHORIZED`,
|
|
true
|
|
),
|
|
ca: stringOrReadFileFromEnv(`${DB_SSL_PREFIX}CA`),
|
|
key: stringOrReadFileFromEnv(`${DB_SSL_PREFIX}KEY`),
|
|
cert: stringOrReadFileFromEnv(`${DB_SSL_PREFIX}CERT`),
|
|
};
|
|
}
|
|
|
|
const devConfig: DataSourceOptions = {
|
|
type: 'sqlite',
|
|
database: process.env.CONFIG_DIRECTORY
|
|
? `${process.env.CONFIG_DIRECTORY}/db/db.sqlite3`
|
|
: 'config/db/db.sqlite3',
|
|
synchronize: true,
|
|
migrationsRun: false,
|
|
logging: boolFromEnv('DB_LOG_QUERIES'),
|
|
enableWAL: true,
|
|
entities: ['server/entity/**/*.ts'],
|
|
migrations: ['server/migration/sqlite/**/*.ts'],
|
|
subscribers: ['server/subscriber/**/*.ts'],
|
|
};
|
|
|
|
const prodConfig: DataSourceOptions = {
|
|
type: 'sqlite',
|
|
database: process.env.CONFIG_DIRECTORY
|
|
? `${process.env.CONFIG_DIRECTORY}/db/db.sqlite3`
|
|
: 'config/db/db.sqlite3',
|
|
synchronize: false,
|
|
migrationsRun: false,
|
|
logging: boolFromEnv('DB_LOG_QUERIES'),
|
|
enableWAL: true,
|
|
entities: ['dist/entity/**/*.js'],
|
|
migrations: ['dist/migration/sqlite/**/*.js'],
|
|
subscribers: ['dist/subscriber/**/*.js'],
|
|
};
|
|
|
|
const postgresDevConfig: DataSourceOptions = {
|
|
type: 'postgres',
|
|
host: process.env.DB_SOCKET_PATH || process.env.DB_HOST,
|
|
port: process.env.DB_SOCKET_PATH
|
|
? undefined
|
|
: parseInt(process.env.DB_PORT ?? '5432'),
|
|
username: process.env.DB_USER,
|
|
password: process.env.DB_PASS,
|
|
database: process.env.DB_NAME ?? 'seerr',
|
|
ssl: buildSslConfig(),
|
|
synchronize: false,
|
|
migrationsRun: true,
|
|
logging: boolFromEnv('DB_LOG_QUERIES'),
|
|
entities: ['server/entity/**/*.ts'],
|
|
migrations: ['server/migration/postgres/**/*.ts'],
|
|
subscribers: ['server/subscriber/**/*.ts'],
|
|
};
|
|
|
|
const postgresProdConfig: DataSourceOptions = {
|
|
type: 'postgres',
|
|
host: process.env.DB_SOCKET_PATH || process.env.DB_HOST,
|
|
port: process.env.DB_SOCKET_PATH
|
|
? undefined
|
|
: parseInt(process.env.DB_PORT ?? '5432'),
|
|
username: process.env.DB_USER,
|
|
password: process.env.DB_PASS,
|
|
database: process.env.DB_NAME ?? 'seerr',
|
|
ssl: buildSslConfig(),
|
|
synchronize: false,
|
|
migrationsRun: false,
|
|
logging: boolFromEnv('DB_LOG_QUERIES'),
|
|
entities: ['dist/entity/**/*.js'],
|
|
migrations: ['dist/migration/postgres/**/*.js'],
|
|
subscribers: ['dist/subscriber/**/*.js'],
|
|
};
|
|
|
|
export const isPgsql = process.env.DB_TYPE === 'postgres';
|
|
|
|
function getDataSource(): DataSourceOptions {
|
|
if (process.env.NODE_ENV === 'production') {
|
|
return isPgsql ? postgresProdConfig : prodConfig;
|
|
} else {
|
|
return isPgsql ? postgresDevConfig : devConfig;
|
|
}
|
|
}
|
|
|
|
const dataSource = new DataSource(getDataSource());
|
|
|
|
export const getRepository = <Entity extends object>(
|
|
target: EntityTarget<Entity>
|
|
): Repository<Entity> => {
|
|
return dataSource.getRepository(target);
|
|
};
|
|
|
|
export default dataSource;
|