sitecheck
Version:
Open Source web application security scanner
196 lines (182 loc) • 7.36 kB
JavaScript
/**
* @license Apache-2.0
* Copyright (C) 2016 The Sitecheck Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
;
const CONSTANTS = require('../../../src/constants.js');
var Target = require('../../../src/target.js');
var http = require('http');
//var fs = require('fs-extra');
//var winston = require('winston');
//var randomstring = require("randomstring");
var CancellationToken = require('../../../src/cancellationToken.js');
var check_code_disclosure = require('../../../src/checks/server/check_code_disclosure.js');
var server = http.createServer(function (req, res) {
if (req.url == '/php_tag') {
res.writeHead(200, { 'Content-Type': 'text/plain' });
res.end('<?pHp this is a php tag ?>');
} else if (req.url == '/php_tag_backslash') {
res.writeHead(200, { 'Content-Type': 'text/plain' });
res.end('<?php\n this is a php tag\n?>');
}
else if (req.url == '/asp_jsp_code_tag') {
res.writeHead(200, { 'Content-Type': 'text/plain' });
res.end('<% test %>');
}
else if (req.url == '/aspx_code_tag') {
res.writeHead(200, { 'Content-Type': 'text/plain' });
res.end('<%@ test %>');
}
else if (req.url == '/java_import') {
res.writeHead(200, { 'Content-Type': 'text/plain' });
res.end('import java.util.swing');
}
else if (req.url == '/no_problem') {
res.writeHead(200, { 'Content-Type': 'text/plain' });
res.end('<div> This is a div </div>');
}
else if (req.url == '/not_found') {
res.writeHead(404, { 'Content-Type': 'text/plain' });
res.end('<?php 404 ?>');
}
else if (req.url == '/cancelled') {
res.writeHead(200, { 'Content-Type': 'text/plain' });
res.end('');
}
else if (req.url == '/blacklist') {
res.writeHead(200, { 'Content-Type': 'text/plain' });
res.end('<?php <?xml>this is a php tag ?>');
}
else {
res.writeHead(404, { 'Content-Type': 'text/plain' });
res.end('wrong request');
}
});
describe('checks/server/check_code_disclosure.js', function () {
before(function () {
server.listen(8000);
});
it('contains php tag', function (done) {
let check = new check_code_disclosure(new Target('http://localhost:8000/php_tag', CONSTANTS.TARGETTYPE.SERVER));
check.check(new CancellationToken()).then(() => {
done();
}).catch((issues) => {
if (issues && issues.length > 0 && issues[0].errorContent) {
done();
} else {
done(new Error("unexpected issue(s) raised"));
}
});
});
it('contains asp or jsp code tag', function (done) {
let check = new check_code_disclosure(new Target('http://localhost:8000/asp_jsp_code_tag', CONSTANTS.TARGETTYPE.SERVER));
check.check(new CancellationToken()).then(() => {
done();
}).catch((issues) => {
if (issues && issues.length > 0 && issues[0].errorContent) {
done();
} else {
done(new Error("unexpected issue(s) raised"));
}
});
});
it('contains aspx code tag', function (done) {
let check = new check_code_disclosure(new Target('http://localhost:8000/aspx_code_tag', CONSTANTS.TARGETTYPE.SERVER));
check.check(new CancellationToken()).then(() => {
done();
}).catch((issues) => {
if (issues && issues.length > 0 && issues[0].errorContent) {
done();
} else {
done(new Error("unexpected issue(s) raised"));
}
});
});
it('contains php tag backslash', function (done) {
let check = new check_code_disclosure(new Target('http://localhost:8000/php_tag_backslash', CONSTANTS.TARGETTYPE.SERVER));
check.check(new CancellationToken()).then(() => {
done();
}).catch((issues) => {
if (issues && issues.length > 0 && issues[0].errorContent) {
done();
} else {
done(new Error("unexpected issue(s) raised"));
}
});
});
it('contains java code', function (done) {
let check = new check_code_disclosure(new Target('http://localhost:8000/java_import', CONSTANTS.TARGETTYPE.SERVER));
check.check(new CancellationToken()).then(() => {
done();
}).catch((issues) => {
if (issues && issues.length > 0 && issues[0].errorContent) {
done();
} else {
done(new Error("unexpected issue(s) raised"));
}
});
});
it('works', function (done) {
let check = new check_code_disclosure(new Target('http://localhost:8000/no_problem', CONSTANTS.TARGETTYPE.SERVER));
check.check(new CancellationToken()).then(() => {
done();
}).catch((issues) => {
if (issues && issues.length > 0 && issues[0].errorContent) {
done();
} else {
done(new Error("unexpected issue(s) raised"));
}
});
});
it('is not found', function (done) {
let check = new check_code_disclosure(new Target('http://localhost:8000/not_found', CONSTANTS.TARGETTYPE.SERVER));
check.check(new CancellationToken()).then(() => {
done();
}).catch((issues) => {
if (issues && issues.length > 0 && issues[0].errorContent) {
done();
} else {
done(new Error("unexpected issue(s) raised"));
}
});
});
it('is cancellable', function (done) {
var ct = new CancellationToken();
let check = new check_code_disclosure(new Target('http://localhost:8000/cancelled', CONSTANTS.TARGETTYPE.SERVER));
check.check(ct)
.then(() => {
done();
})
.catch((e) => {
if (e.cancelled) done();
});
ct.cancel();
});
it('contains code in blacklist', function (done) {
let check = new check_code_disclosure(new Target('http://localhost:8000/blacklist', CONSTANTS.TARGETTYPE.SERVER));
check.check(new CancellationToken()).then(() => {
done();
}).catch((issues) => {
if (issues && issues.length > 0 && issues[0].errorContent) {
done();
} else {
done(new Error("unexpected issue(s) raised"));
}
});
});
after(function () {
server.close();
});
});