Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
D
debomatic-webui
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
debomatic-webui-admins
debomatic-webui
Commits
a9c973b9
Commit
a9c973b9
authored
Jul 05, 2014
by
Leo Iannacone
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
filter out request to chroots - send back 403 HTTP status
parent
00932aff
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
25 additions
and
7 deletions
+25
-7
debomatic-webui/debomatic-webui
debomatic-webui/debomatic-webui
+25
-7
No files found.
debomatic-webui/debomatic-webui
View file @
a9c973b9
...
@@ -34,26 +34,44 @@ if ('development' == env) {
...
@@ -34,26 +34,44 @@ if ('development' == env) {
app.set('views', __dirname + '/views');
app.set('views', __dirname + '/views');
app.set('view engine', 'ejs');
app.set('view engine', 'ejs');
//
Routes
//
index page
app.get('/', routes.index);
app.get('/', routes.index);
// distibution page
// distibution page
app.get(config.routes.distribution, routes.distribution);
app.get(config.routes.distribution, routes.distribution);
// parefernces page
// parefernces page
if (config.routes.preferences)
if (config.routes.preferences)
app.get(config.routes.preferences, routes.preferences);
app.get(config.routes.preferences, routes.preferences);
// commands page
// commands page
if (config.routes.commands)
if (config.routes.commands)
app.get(config.routes.commands, routes.commands);
app.get(config.routes.commands, routes.commands);
// debomatic static page
// debomatic static page
if (config.routes.debomatic) {
if (config.routes.debomatic) {
app.all(config.routes.debomatic + '*', function (req, res, next) {
// send 403 status when users want to browse the chroots:
// - unstable/unstable
// - unstable/build/*
// this prevents system crashes
var base = config.routes.debomatic;
base += base[base.length - 1] != '/' ? '/' : ''; // append /
var match = req.url.replace(base, '').split('/');
if (match[match.length - 1] === '') match.pop();
if (match.length >= 2 && (
(match[0] == match[1]) || /* case unstable/unstable */
(match[1] == 'build' && match.length > 2) /* case unstable/build/* */
)) {
res.status(403).send('<h1>403 Forbidden</h1>');
} else
next(); // call next() here to move on to next middleware/router
});
app.use(config.routes.debomatic, serve_static(config.debomatic.path));
app.use(config.routes.debomatic, serve_static(config.debomatic.path));
app.use(config.routes.debomatic, serve_index(config.debomatic.path, {
app.use(config.routes.debomatic, serve_index(config.debomatic.path));
filter: function (filename) {
// do not show these files and directories
return ['dev', 'sys'].indexOf(filename) < 0;
}
}));
}
}
// serve stylesheet-javascript
// serve stylesheet-javascript
app.use(serve_static(__dirname + '/public'));
app.use(serve_static(__dirname + '/public'));
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment