mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-09-22 06:00:56 +02:00
🧪 refactor(isDomainAllowed): change directory, add tests (#2539)
This commit is contained in:
parent
099aa9dead
commit
11d5e232b3
4 changed files with 84 additions and 63 deletions
|
@ -1,8 +1,7 @@
|
||||||
const crypto = require('crypto');
|
const crypto = require('crypto');
|
||||||
const bcrypt = require('bcryptjs');
|
const bcrypt = require('bcryptjs');
|
||||||
const { errorsToString } = require('librechat-data-provider');
|
const { registerSchema, errorsToString } = require('~/strategies/validators');
|
||||||
const { registerSchema } = require('~/strategies/validators');
|
const isDomainAllowed = require('./isDomainAllowed');
|
||||||
const getCustomConfig = require('~/server/services/Config/getCustomConfig');
|
|
||||||
const Token = require('~/models/schema/tokenSchema');
|
const Token = require('~/models/schema/tokenSchema');
|
||||||
const { sendEmail } = require('~/server/utils');
|
const { sendEmail } = require('~/server/utils');
|
||||||
const Session = require('~/models/Session');
|
const Session = require('~/models/Session');
|
||||||
|
@ -14,27 +13,6 @@ const domains = {
|
||||||
server: process.env.DOMAIN_SERVER,
|
server: process.env.DOMAIN_SERVER,
|
||||||
};
|
};
|
||||||
|
|
||||||
async function isDomainAllowed(email) {
|
|
||||||
if (!email) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
const domain = email.split('@')[1];
|
|
||||||
|
|
||||||
if (!domain) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
const customConfig = await getCustomConfig();
|
|
||||||
if (!customConfig) {
|
|
||||||
return true;
|
|
||||||
} else if (!customConfig?.registration?.allowedDomains) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return customConfig.registration.allowedDomains.includes(domain);
|
|
||||||
}
|
|
||||||
|
|
||||||
const isProduction = process.env.NODE_ENV === 'production';
|
const isProduction = process.env.NODE_ENV === 'production';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -1,39 +0,0 @@
|
||||||
const getCustomConfig = require('~/server/services/Config/getCustomConfig');
|
|
||||||
const { isDomainAllowed } = require('./AuthService');
|
|
||||||
|
|
||||||
jest.mock('~/server/services/Config/getCustomConfig', () => jest.fn());
|
|
||||||
|
|
||||||
describe('isDomainAllowed', () => {
|
|
||||||
it('should allow domain when customConfig is not available', async () => {
|
|
||||||
getCustomConfig.mockResolvedValue(null);
|
|
||||||
await expect(isDomainAllowed('test@domain1.com')).resolves.toBe(true);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should allow domain when allowedDomains is not defined in customConfig', async () => {
|
|
||||||
getCustomConfig.mockResolvedValue({});
|
|
||||||
await expect(isDomainAllowed('test@domain1.com')).resolves.toBe(true);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should reject an email if it is falsy', async () => {
|
|
||||||
getCustomConfig.mockResolvedValue({});
|
|
||||||
await expect(isDomainAllowed('')).resolves.toBe(false);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should allow a domain if it is included in the allowedDomains', async () => {
|
|
||||||
getCustomConfig.mockResolvedValue({
|
|
||||||
registration: {
|
|
||||||
allowedDomains: ['domain1.com', 'domain2.com'],
|
|
||||||
},
|
|
||||||
});
|
|
||||||
await expect(isDomainAllowed('user@domain1.com')).resolves.toBe(true);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should reject a domain if it is not included in the allowedDomains', async () => {
|
|
||||||
getCustomConfig.mockResolvedValue({
|
|
||||||
registration: {
|
|
||||||
allowedDomains: ['domain1.com', 'domain2.com'],
|
|
||||||
},
|
|
||||||
});
|
|
||||||
await expect(isDomainAllowed('user@domain3.com')).resolves.toBe(false);
|
|
||||||
});
|
|
||||||
});
|
|
24
api/server/services/isDomainAllowed.js
Normal file
24
api/server/services/isDomainAllowed.js
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
const getCustomConfig = require('~/server/services/Config/getCustomConfig');
|
||||||
|
|
||||||
|
async function isDomainAllowed(email) {
|
||||||
|
if (!email) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
const domain = email.split('@')[1];
|
||||||
|
|
||||||
|
if (!domain) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
const customConfig = await getCustomConfig();
|
||||||
|
if (!customConfig) {
|
||||||
|
return true;
|
||||||
|
} else if (!customConfig?.registration?.allowedDomains) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return customConfig.registration.allowedDomains.includes(domain);
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = isDomainAllowed;
|
58
api/server/services/isDomainAllowed.spec.js
Normal file
58
api/server/services/isDomainAllowed.spec.js
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
const getCustomConfig = require('~/server/services/Config/getCustomConfig');
|
||||||
|
const isDomainAllowed = require('./isDomainAllowed');
|
||||||
|
|
||||||
|
jest.mock('~/server/services/Config/getCustomConfig', () => jest.fn());
|
||||||
|
|
||||||
|
describe('isDomainAllowed', () => {
|
||||||
|
afterEach(() => {
|
||||||
|
jest.clearAllMocks();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return false if email is falsy', async () => {
|
||||||
|
const email = '';
|
||||||
|
const result = await isDomainAllowed(email);
|
||||||
|
expect(result).toBe(false);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return false if domain is not present in the email', async () => {
|
||||||
|
const email = 'test';
|
||||||
|
const result = await isDomainAllowed(email);
|
||||||
|
expect(result).toBe(false);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return true if customConfig is not available', async () => {
|
||||||
|
const email = 'test@domain1.com';
|
||||||
|
getCustomConfig.mockResolvedValue(null);
|
||||||
|
const result = await isDomainAllowed(email);
|
||||||
|
expect(result).toBe(true);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return true if allowedDomains is not defined in customConfig', async () => {
|
||||||
|
const email = 'test@domain1.com';
|
||||||
|
getCustomConfig.mockResolvedValue({});
|
||||||
|
const result = await isDomainAllowed(email);
|
||||||
|
expect(result).toBe(true);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return true if domain is included in the allowedDomains', async () => {
|
||||||
|
const email = 'user@domain1.com';
|
||||||
|
getCustomConfig.mockResolvedValue({
|
||||||
|
registration: {
|
||||||
|
allowedDomains: ['domain1.com', 'domain2.com'],
|
||||||
|
},
|
||||||
|
});
|
||||||
|
const result = await isDomainAllowed(email);
|
||||||
|
expect(result).toBe(true);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return false if domain is not included in the allowedDomains', async () => {
|
||||||
|
const email = 'user@domain3.com';
|
||||||
|
getCustomConfig.mockResolvedValue({
|
||||||
|
registration: {
|
||||||
|
allowedDomains: ['domain1.com', 'domain2.com'],
|
||||||
|
},
|
||||||
|
});
|
||||||
|
const result = await isDomainAllowed(email);
|
||||||
|
expect(result).toBe(false);
|
||||||
|
});
|
||||||
|
});
|
Loading…
Add table
Add a link
Reference in a new issue