add email account validation

This commit is contained in:
andres
2023-06-13 01:39:33 +02:00
parent 59b4eb582e
commit 6c62d87ee6
40 changed files with 578 additions and 6453 deletions

View File

@@ -2,53 +2,44 @@
//по умолчанию переменные беруться сначала из ENV илм смотрят всегда на staging
//для подстановки локальных значений переменных использовать исключительно локальные env файлы env.development.local
//при необзодимости добавляем сюда нужные приложению переменные
import * as dotenv from 'dotenv';
dotenv.config();
import * as dotenv from 'dotenv'
dotenv.config()
export type EnvironmentVariable = { [key: string]: string | undefined };
export type EnvironmentsTypes =
| 'DEVELOPMENT'
| 'STAGING'
| 'PRODUCTION'
| 'TEST';
export type EnvironmentVariable = { [key: string]: string | undefined }
export type EnvironmentsTypes = 'DEVELOPMENT' | 'STAGING' | 'PRODUCTION' | 'TEST'
export class EnvironmentSettings {
constructor(private env: EnvironmentsTypes) {}
getEnv() {
return this.env;
return this.env
}
isProduction() {
return this.env === 'PRODUCTION';
return this.env === 'PRODUCTION'
}
isStaging() {
return this.env === 'STAGING';
return this.env === 'STAGING'
}
isDevelopment() {
return this.env === 'DEVELOPMENT';
return this.env === 'DEVELOPMENT'
}
isTesting() {
return this.env === 'TEST';
return this.env === 'TEST'
}
}
class AuthSettings {
public readonly BASE_AUTH_HEADER: string;
public readonly ACCESS_JWT_SECRET_KEY: string;
public readonly REFRESH_JWT_SECRET_KEY: string;
public readonly BASE_AUTH_HEADER: string
public readonly ACCESS_JWT_SECRET_KEY: string
public readonly REFRESH_JWT_SECRET_KEY: string
constructor(private envVariables: EnvironmentVariable) {
this.BASE_AUTH_HEADER =
envVariables.BASE_AUTH_HEADER || 'Basic YWRtaW46cXdlcnR5';
this.ACCESS_JWT_SECRET_KEY =
envVariables.ACCESS_JWT_SECRET_KEY || 'accessJwtSecret';
this.REFRESH_JWT_SECRET_KEY =
envVariables.REFRESH_JWT_SECRET_KEY || 'refreshJwtSecret';
this.BASE_AUTH_HEADER = envVariables.BASE_AUTH_HEADER || 'Basic YWRtaW46cXdlcnR5'
this.ACCESS_JWT_SECRET_KEY = envVariables.ACCESS_JWT_SECRET_KEY || 'accessJwtSecret'
this.REFRESH_JWT_SECRET_KEY = envVariables.REFRESH_JWT_SECRET_KEY || 'refreshJwtSecret'
}
}
export class AppSettings {
constructor(public env: EnvironmentSettings, public auth: AuthSettings) {}
}
const env = new EnvironmentSettings(
(process.env.NODE_ENV || 'DEVELOPMENT') as EnvironmentsTypes,
);
const auth = new AuthSettings(process.env);
export const appSettings = new AppSettings(env, auth);
const env = new EnvironmentSettings((process.env.NODE_ENV || 'DEVELOPMENT') as EnvironmentsTypes)
const auth = new AuthSettings(process.env)
export const appSettings = new AppSettings(env, auth)