Remove default values from cli and modify config.js file

This commit is contained in:
AbegaM
2024-05-08 10:51:33 +03:00
parent e838e41f07
commit d3edcebc98
4 changed files with 27 additions and 10 deletions

View File

@@ -20,7 +20,7 @@ const envVarsSchema = Joi.object()
VERBOSE: Joi.string().valid('console', null).default(null), VERBOSE: Joi.string().valid('console', null).default(null),
CORS_ORIGIN_WHITELIST: Joi.string().default('*'), CORS_ORIGIN_WHITELIST: Joi.string().default('*'),
AUTH: Joi.boolean().default(false), AUTH: Joi.boolean(),
RATE_LIMIT_ENABLED: Joi.boolean().default(false), RATE_LIMIT_ENABLED: Joi.boolean().default(false),
RATE_LIMIT_WINDOW_MS: Joi.number().positive().default(1000), RATE_LIMIT_WINDOW_MS: Joi.number().positive().default(1000),
@@ -33,9 +33,9 @@ const envVarsSchema = Joi.object()
INITIAL_USER_USERNAME: Joi.string(), INITIAL_USER_USERNAME: Joi.string(),
INITIAL_USER_PASSWORD: Joi.string(), INITIAL_USER_PASSWORD: Joi.string(),
TOKEN_SECRET: Joi.string().default(null), TOKEN_SECRET: Joi.string(),
ACCESS_TOKEN_EXPIRATION_TIME: Joi.string().default('5H'), ACCESS_TOKEN_EXPIRATION_TIME: Joi.string(),
REFRESH_TOKEN_EXPIRATION_TIME: Joi.string().default('3D'), REFRESH_TOKEN_EXPIRATION_TIME: Joi.string(),
}) })
.unknown(); .unknown();
@@ -113,12 +113,16 @@ module.exports = {
envVars.CORS_ORIGIN_WHITELIST?.split(',') || ['*'], envVars.CORS_ORIGIN_WHITELIST?.split(',') || ['*'],
}, },
auth: argv.auth || envVars.AUTH, auth: argv.auth || envVars.AUTH || false,
tokenSecret: argv.tokensecret || envVars.TOKEN_SECRET, tokenSecret: argv.tokensecret || envVars.TOKEN_SECRET || null,
accessTokenExpirationTime: accessTokenExpirationTime:
argv.accesstokenexpirationtime || envVars.ACCESS_TOKEN_EXPIRATION_TIME, argv.accesstokenexpirationtime ||
envVars.ACCESS_TOKEN_EXPIRATION_TIME ||
'5H',
refreshTokenExpirationTime: refreshTokenExpirationTime:
argv.refreshtokenexpirationtime || envVars.REFRESH_TOKEN_EXPIRATION_TIME, argv.refreshtokenexpirationtime ||
envVars.REFRESH_TOKEN_EXPIRATION_TIME ||
'3D',
initialUserUsername: initialUserUsername:
argv.initialuserusername || envVars.INITIAL_USER_USERNAME, argv.initialuserusername || envVars.INITIAL_USER_USERNAME,

View File

@@ -13,4 +13,12 @@ const isUsernameTaken = (username) => {
return users.length > 0; return users.length > 0;
}; };
module.exports = { isUsernameTaken }; const checkAuthConfigs = ({ auth, tokenSecret }) => {
if (auth && !tokenSecret) {
throw new Error(
'You need to provide a token secret either from the CLI or from your environment variables',
);
}
};
module.exports = { isUsernameTaken, checkAuthConfigs };

View File

@@ -1,5 +1,6 @@
const users = require('./user'); const users = require('./user');
const token = require('./token'); const token = require('./token');
const tables = require('./tables'); const tables = require('./tables');
const { checkAuthConfigs } = require('./common');
module.exports = { ...users, ...token, ...tables }; module.exports = { ...users, ...token, ...tables, checkAuthConfigs };

View File

@@ -23,6 +23,7 @@ const {
createDefaultTables, createDefaultTables,
createInitialUser, createInitialUser,
removeRevokedRefreshTokens, removeRevokedRefreshTokens,
checkAuthConfigs,
} = require('./controllers/auth'); } = require('./controllers/auth');
const { runCLICommands } = require('./commands'); const { runCLICommands } = require('./commands');
@@ -85,6 +86,9 @@ if (config.rateLimit.enabled) {
app.use(limiter); app.use(limiter);
} }
// If Auth mode is activated but if the tokenSecret value is undefined then throw an error
checkAuthConfigs({ auth: config.auth, tokenSecret: config.tokenSecret });
// If Auth mode is activated then create auth tables in the DB & create a super user if there are no users in the DB // If Auth mode is activated then create auth tables in the DB & create a super user if there are no users in the DB
if (config.auth) { if (config.auth) {
createDefaultTables(); createDefaultTables();