Browse Source

Extra safety for safe_join. Does not look exploitable but better safe than sorry. Fixes #501

pull/609/head
Armin Ronacher 12 years ago
parent
commit
3afcbf160e
  1. 4
      flask/helpers.py
  2. 6
      flask/testsuite/regression.py

4
flask/helpers.py

@ -604,7 +604,9 @@ def safe_join(directory, filename):
for sep in _os_alt_seps: for sep in _os_alt_seps:
if sep in filename: if sep in filename:
raise NotFound() raise NotFound()
if os.path.isabs(filename) or filename.startswith('../'): if os.path.isabs(filename) or \
filename == '..' or \
filename.startswith('../'):
raise NotFound() raise NotFound()
return os.path.join(directory, filename) return os.path.join(directory, filename)

6
flask/testsuite/regression.py

@ -17,6 +17,7 @@ import flask
import threading import threading
import unittest import unittest
from werkzeug.test import run_wsgi_app, create_environ from werkzeug.test import run_wsgi_app, create_environ
from werkzeug.exceptions import NotFound
from flask.testsuite import FlaskTestCase from flask.testsuite import FlaskTestCase
@ -79,6 +80,11 @@ class MemoryTestCase(FlaskTestCase):
for x in xrange(10): for x in xrange(10):
fire() fire()
def test_safe_join_toplevel_pardir(self):
from flask.helpers import safe_join
with self.assert_raises(NotFound):
safe_join('/foo', '..')
def suite(): def suite():
suite = unittest.TestSuite() suite = unittest.TestSuite()

Loading…
Cancel
Save