Skip to content

Commit

Permalink
feat: context 中的 isSafeDomain() 函数增加自定义白名单参数 (#86)
Browse files Browse the repository at this point in the history
此前,`isSafeDomain()` 只有一个参数,无法自定义白名单。

为了在 egg-cors 或其他插件中可以复用该函数的逻辑,现在增加第二个参数,
使其更加灵活。
  • Loading branch information
yisibl authored Aug 9, 2023
1 parent 17ccfb5 commit a178552
Show file tree
Hide file tree
Showing 5 changed files with 101 additions and 2 deletions.
7 changes: 5 additions & 2 deletions app/extend/context.js
Original file line number Diff line number Diff line change
Expand Up @@ -38,11 +38,14 @@ module.exports = {
/**
* Check whether the specific `domain` is in / matches the whiteList or not.
* @param {string} domain The assigned domain.
* @param {Array<string>} customWhiteList The custom white list for domain.
* @return {boolean} If the domain is in / matches the whiteList, return true;
* otherwise false.
*/
isSafeDomain(domain) {
const domainWhiteList = this.app.config.security.domainWhiteList;
// TODO: add customWhiteList option document.
isSafeDomain(domain, customWhiteList) {
const domainWhiteList = customWhiteList && customWhiteList.length > 0 ? customWhiteList : this.app.config.security.domainWhiteList;
// const domainWhiteList = this.app.config.security.domainWhiteList;
return utils.isSafeDomain(domain, domainWhiteList);
},

Expand Down
31 changes: 31 additions & 0 deletions test/context.test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
const { strict: assert } = require('node:assert');
const mm = require('egg-mock');

describe('test/context.test.js', () => {
afterEach(mm.restore);
describe('context.isSafeDomain', () => {
let app;
before(() => {
app = mm.app({
baseDir: 'apps/isSafeDomain-custom',
});
return app.ready();
});

it('should return false when domains are not safe', async () => {
const res = await app.httpRequest()
.get('/unsafe')
.set('accept', 'text/html')
.expect(200);
assert(res.text === 'false');
});

it('should return true when domains are safe', async () => {
const res = await app.httpRequest()
.get('/safe')
.set('accept', 'text/html')
.expect(200);
assert(res.text === 'true');
});
});
});
54 changes: 54 additions & 0 deletions test/fixtures/apps/isSafeDomain-custom/app/router.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
module.exports = function (app) {
const customWhiteList = [
'*.foo.com',
'*.bar.net',
];

app.get('/unsafe', async function() {
const unsafeDomains = [
// unsafe
'aAa-domain.com',
'192.1.168.0',
'http://www.baidu.com/zh-CN',
'www.alimama.com',
'foo.com.cn',
'a.foo.com.cn',

// safe
'pre-www.foo.com',
'pre-www.bar.net',
];
let unsafeCounter = 0;
for (let unsafeDomain of unsafeDomains) {
if (!this.isSafeDomain(unsafeDomain, customWhiteList)) {
unsafeCounter++;
}
}

this.body = unsafeCounter === 6 ? false : true;
});

app.get('/safe', async function() {
const safeDomains = [
'a.foo.com',
'a.b.foo.com',
'a.b.c.foo.com',
'pre-www.foo.com',
'test.pre-www.foo.com',
'a.bar.net',
'a.b.bar.net',
'a.b.c.bar.net',
'pre-www.bar.net',
'test.pre-www.bar.net',
];
let safeCounter = 0;

for (const safeDomain of safeDomains) {
if (this.isSafeDomain(safeDomain, customWhiteList)) {
safeCounter++;
}
}

this.body = safeCounter === 10;
});
};
8 changes: 8 additions & 0 deletions test/fixtures/apps/isSafeDomain-custom/config/config.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
'use strict';

exports.keys = 'test key';

exports.security = {
defaultMiddleware: 'xframe',
domainWhiteList: ['.domain.com', 'http://www.baidu.com', '192.*.0.*', '*.alibaba.com'],
};
3 changes: 3 additions & 0 deletions test/fixtures/apps/isSafeDomain-custom/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
"name": "isSafeDomain"
}

0 comments on commit a178552

Please sign in to comment.