Show More
@@ -1,57 +1,51 | |||||
1 | """Base Tornado handlers for the notebook server.""" |
|
1 | """Base Tornado handlers for the notebook server.""" | |
2 |
|
2 | |||
3 | # Copyright (c) IPython Development Team. |
|
3 | # Copyright (c) IPython Development Team. | |
4 | # Distributed under the terms of the Modified BSD License. |
|
4 | # Distributed under the terms of the Modified BSD License. | |
5 |
|
5 | |||
6 | import logging |
|
6 | import logging | |
7 | import os |
|
7 | import os | |
8 | import mimetypes |
|
8 | import mimetypes | |
9 | import json |
|
9 | import json | |
10 | import base64 |
|
10 | import base64 | |
11 |
|
11 | |||
12 | try: |
|
|||
13 | # py3 |
|
|||
14 | from http.client import responses |
|
|||
15 | except ImportError: |
|
|||
16 | from httplib import responses |
|
|||
17 |
|
||||
18 | from tornado import web |
|
12 | from tornado import web | |
19 |
|
13 | |||
20 | try: |
|
14 | try: | |
21 | from tornado.log import app_log |
|
15 | from tornado.log import app_log | |
22 | except ImportError: |
|
16 | except ImportError: | |
23 | app_log = logging.getLogger() |
|
17 | app_log = logging.getLogger() | |
24 |
|
18 | |||
25 | from IPython.html.base.handlers import IPythonHandler |
|
19 | from IPython.html.base.handlers import IPythonHandler | |
26 |
|
20 | |||
27 | class FilesHandler(IPythonHandler): |
|
21 | class FilesHandler(IPythonHandler): | |
28 | """serve files via ContentsManager""" |
|
22 | """serve files via ContentsManager""" | |
29 |
|
23 | |||
30 | @web.authenticated |
|
24 | @web.authenticated | |
31 | def get(self, path): |
|
25 | def get(self, path): | |
32 | cm = self.settings['contents_manager'] |
|
26 | cm = self.settings['contents_manager'] | |
33 | if cm.is_hidden(path): |
|
27 | if cm.is_hidden(path): | |
34 | self.log.info("Refusing to serve hidden file, via 404 Error") |
|
28 | self.log.info("Refusing to serve hidden file, via 404 Error") | |
35 | raise web.HTTPError(404) |
|
29 | raise web.HTTPError(404) | |
36 |
|
30 | |||
37 | path, name = os.path.split(path) |
|
31 | path, name = os.path.split(path) | |
38 | model = cm.get_model(name, path) |
|
32 | model = cm.get_model(name, path) | |
39 |
|
33 | |||
40 | if model['type'] == 'notebook': |
|
34 | if model['type'] == 'notebook': | |
41 | self.set_header('Content-Type', 'application/json') |
|
35 | self.set_header('Content-Type', 'application/json') | |
42 | else: |
|
36 | else: | |
43 | cur_mime = mimetypes.guess_type(name)[0] |
|
37 | cur_mime = mimetypes.guess_type(name)[0] | |
44 | if cur_mime is not None: |
|
38 | if cur_mime is not None: | |
45 | self.set_header('Content-Type', cur_mime) |
|
39 | self.set_header('Content-Type', cur_mime) | |
46 |
|
40 | |||
47 | self.set_header('Content-Disposition','attachment; filename="%s"' % name) |
|
41 | self.set_header('Content-Disposition','attachment; filename="%s"' % name) | |
48 |
|
42 | |||
49 | if model['format'] == 'base64': |
|
43 | if model['format'] == 'base64': | |
50 | b64_bytes = model['content'].encode('ascii') |
|
44 | b64_bytes = model['content'].encode('ascii') | |
51 | self.write(base64.decodestring(b64_bytes)) |
|
45 | self.write(base64.decodestring(b64_bytes)) | |
52 | elif model['format'] == 'json': |
|
46 | elif model['format'] == 'json': | |
53 | self.write(json.dumps(model['content'])) |
|
47 | self.write(json.dumps(model['content'])) | |
54 | else: |
|
48 | else: | |
55 | self.write(model['content']) |
|
49 | self.write(model['content']) | |
56 | self.flush() |
|
50 | self.flush() | |
57 |
|
51 |
General Comments 0
You need to be logged in to leave comments.
Login now