OLD | NEW |
1 # coding: utf-8 | 1 # coding: utf-8 |
2 | 2 |
3 # This Source Code is subject to the terms of the Mozilla Public License | 3 # This Source Code is subject to the terms of the Mozilla Public License |
4 # version 2.0 (the "License"). You can obtain a copy of the License at | 4 # version 2.0 (the "License"). You can obtain a copy of the License at |
5 # http://mozilla.org/MPL/2.0/. | 5 # http://mozilla.org/MPL/2.0/. |
6 | 6 |
| 7 import base64 |
| 8 from sitescripts.utils import get_config |
| 9 |
7 handlers = {} | 10 handlers = {} |
| 11 authenticated_users = {} |
8 | 12 |
9 def url_handler(url): | 13 def url_handler(url): |
10 def decorator(func): | 14 def decorator(func): |
11 registerUrlHandler(url, func) | 15 registerUrlHandler(url, func) |
12 return func | 16 return func |
13 return decorator | 17 return decorator |
14 | 18 |
15 def registerUrlHandler(url, func): | 19 def registerUrlHandler(url, func): |
16 if url in handlers: | 20 if url in handlers: |
17 raise Exception('A handler for url %s is already registered' % url) | 21 raise Exception('A handler for url %s is already registered' % url) |
18 handlers[url] = func | 22 handlers[url] = func |
19 | 23 |
| 24 def basic_auth(config_section = "DEFAULT"): |
| 25 def decorator(function): |
| 26 def authenticating_wrapper(environ, start_response): |
| 27 return authenticate(function, environ, start_response, config_section) |
| 28 return authenticating_wrapper |
| 29 return decorator |
| 30 |
| 31 def authenticate(f, environ, start_response, config_section): |
| 32 if "HTTP_AUTHORIZATION" in environ: |
| 33 auth = environ["HTTP_AUTHORIZATION"].split() |
| 34 if len(auth) == 2: |
| 35 if auth[0].lower() == "basic": |
| 36 username, password = base64.b64decode(auth[1]).split(":") |
| 37 config = get_config() |
| 38 expected_username = config.get(config_section, "basic_auth_username") |
| 39 expected_password = config.get(config_section, "basic_auth_password") |
| 40 if username == expected_username and password == expected_password: |
| 41 return f(environ, start_response) |
| 42 |
| 43 realm = get_config().get("DEFAULT", "basic_auth_realm") |
| 44 start_response("401 UNAUTHORIZED", |
| 45 [("WWW-Authenticate", 'Basic realm="%s"' % realm)]) |
| 46 return "" |
| 47 |
20 import openid.web.server | 48 import openid.web.server |
21 import subscriptions.web.fallback | 49 import subscriptions.web.fallback |
| 50 import crashes.web.submitCrash |
22 import reports.web.submitReport | 51 import reports.web.submitReport |
23 import reports.web.updateReport | 52 import reports.web.updateReport |
24 import reports.web.showDigest | 53 import reports.web.showDigest |
25 import extensions.web.translationCheck | 54 import extensions.web.translationCheck |
26 import tasks.web.tasks | 55 import tasks.web.tasks |
27 import formmail.web.formmail | 56 import formmail.web.formmail |
28 import crawler.web.crawler | 57 import crawler.web.crawler |
OLD | NEW |