Show More
@@ -67,6 +67,11 b' class NamedNotebookHandler(IPythonHandler):' | |||
|
67 | 67 | mathjax_url=self.mathjax_url, |
|
68 | 68 | ) |
|
69 | 69 | ) |
|
70 | ||
|
71 | @web.authenticated | |
|
72 | def post(self, notebook_path): | |
|
73 | nbm =self.notebook_manager | |
|
74 | notebook_name = nbm.new_notebook() | |
|
70 | 75 | |
|
71 | 76 | |
|
72 | 77 | class NotebookCopyHandler(IPythonHandler): |
@@ -6,7 +6,7 b' Authors:' | |||
|
6 | 6 | """ |
|
7 | 7 | |
|
8 | 8 | #----------------------------------------------------------------------------- |
|
9 |
# Copyright (C) 201 |
|
|
9 | # Copyright (C) 2013 The IPython Development Team | |
|
10 | 10 | # |
|
11 | 11 | # Distributed under the terms of the BSD License. The full license is in |
|
12 | 12 | # the file COPYING, distributed as part of this software. |
@@ -44,25 +44,32 b' class ContentManager(LoggingConfigurable):' | |||
|
44 | 44 | contents = List() |
|
45 | 45 | |
|
46 | 46 | def get_content_names(self, content_path): |
|
47 | """List of dicts of files in content_path""" | |
|
47 | 48 | names = glob.glob(os.path.join(self.content_dir, content_path,'*')) |
|
48 |
content |
|
|
49 |
dir |
|
|
49 | contents = list() | |
|
50 | dirs = list() | |
|
51 | notebooks = list() | |
|
50 | 52 | for name in names: |
|
51 | 53 | if os.path.isdir(name) == True: |
|
52 |
dir |
|
|
53 |
elif os.path.splitext( |
|
|
54 |
|
|
|
55 | return dir_names, content_names | |
|
56 | ||
|
54 | dirs.append(os.path.split(name)[1]) | |
|
55 | elif os.path.splitext(name)[1] == '.ipynb': | |
|
56 | notebooks.append(os.path.split(name)[1]) | |
|
57 | else: | |
|
58 | contents.append(os.path.split(name)[1]) | |
|
59 | return dirs, notebooks, contents | |
|
60 | ||
|
57 | 61 | def list_contents(self, content_path): |
|
58 | 62 | """List all contents in the named path.""" |
|
59 | dir_names, content_names = self.get_content_names(content_path) | |
|
63 | dir_names, notebook_names, content_names = self.get_content_names(content_path) | |
|
60 | 64 | content_mapping = [] |
|
61 | 65 | for name in dir_names: |
|
62 |
model = self. |
|
|
66 | model = self.content_model(name, content_path, type='dir') | |
|
63 | 67 | content_mapping.append(model) |
|
64 | 68 | for name in content_names: |
|
65 | model = self.content_model(name, content_path) | |
|
69 | model = self.content_model(name, content_path, type='file') | |
|
70 | content_mapping.append(model) | |
|
71 | for name in notebook_names: | |
|
72 | model = self.content_model(name, content_path, type='notebook') | |
|
66 | 73 | content_mapping.append(model) |
|
67 | 74 | return content_mapping |
|
68 | 75 | |
@@ -71,32 +78,27 b' class ContentManager(LoggingConfigurable):' | |||
|
71 | 78 | path = os.path.join(self.content_dir, content_path, name) |
|
72 | 79 | return path |
|
73 | 80 | |
|
74 |
def |
|
|
81 | def content_info(self, name, content_path): | |
|
82 | """Read the content of a named file""" | |
|
75 | 83 | file_type = os.path.splitext(os.path.basename(name))[1] |
|
76 | #Collect contents of file | |
|
77 | with open(name, 'rb') as file_content: | |
|
78 | contents = file_content.read() | |
|
79 | 84 | full_path = self.get_path_by_name(name, content_path) |
|
80 | 85 | info = os.stat(full_path) |
|
81 | 86 | size = info.st_size |
|
82 | 87 | last_modified = tz.utcfromtimestamp(info.st_mtime) |
|
83 |
return last_modified, file_type, |
|
|
84 | ||
|
85 | def directory_model(self, name, content_path): | |
|
86 | model = {"name": name, | |
|
87 | "path": content_path, | |
|
88 | "type": 'tree'} | |
|
89 | return model | |
|
88 | return last_modified, file_type, size | |
|
90 | 89 | |
|
91 | def content_model(self, name, content_path): | |
|
92 | last_modified, file_type, contents, size = self.read_content(name, content_path) | |
|
90 | def content_model(self, name, content_path, type=None): | |
|
91 | """Create a dict standard model for any file (other than notebooks)""" | |
|
92 | last_modified, file_type, size = self.content_info(name, content_path) | |
|
93 | 93 | model = {"name": name, |
|
94 | 94 | "path": content_path, |
|
95 |
"type": |
|
|
95 | "type": type, | |
|
96 | "MIME-type": "", | |
|
96 | 97 | "last_modified": last_modified.ctime(), |
|
97 | 98 | "size": size} |
|
98 | 99 | return model |
|
99 | 100 | |
|
100 | 101 | def delete_content(self, content_path): |
|
102 | """Delete a file""" | |
|
101 | 103 | os.unlink(os.path.join(self.content_dir, content_path)) |
|
102 | 104 | No newline at end of file |
@@ -6,7 +6,7 b' Authors:' | |||
|
6 | 6 | """ |
|
7 | 7 | |
|
8 | 8 | #----------------------------------------------------------------------------- |
|
9 |
# Copyright (C) 20 |
|
|
9 | # Copyright (C) 2013 The IPython Development Team | |
|
10 | 10 | # |
|
11 | 11 | # Distributed under the terms of the BSD License. The full license is in |
|
12 | 12 | # the file COPYING, distributed as part of this software. |
@@ -89,7 +89,7 b' class FileNotebookManager(NotebookManager):' | |||
|
89 | 89 | notebook_names = self.get_notebook_names(path) |
|
90 | 90 | notebook_mapping = [] |
|
91 | 91 | for name in notebook_names: |
|
92 | model = self.notebook_model(name, path) | |
|
92 | model = self.notebook_model(name, path, content=False) | |
|
93 | 93 | notebook_mapping.append(model) |
|
94 | 94 | return notebook_mapping |
|
95 | 95 |
@@ -114,13 +114,15 b' class NotebookManager(LoggingConfigurable):' | |||
|
114 | 114 | def notebook_exists(self, notebook_path): |
|
115 | 115 | """Does a notebook exist?""" |
|
116 | 116 | |
|
117 | def notebook_model(self, notebook_name, notebook_path=None): | |
|
117 | ||
|
118 | def notebook_model(self, notebook_name, notebook_path=None, content=True): | |
|
118 | 119 | """ Creates the standard notebook model """ |
|
119 | last_modified, content = self.read_notebook_object(notebook_name, notebook_path) | |
|
120 | last_modified, contents = self.read_notebook_object(notebook_name, notebook_path) | |
|
120 | 121 | model = {"notebook_name": notebook_name, |
|
121 | 122 | "notebook_path": notebook_path, |
|
122 | "content": content, | |
|
123 | 123 | "last_modified": last_modified.ctime()} |
|
124 | if content == True: | |
|
125 | model['content'] = contents | |
|
124 | 126 | return model |
|
125 | 127 | |
|
126 | 128 | def get_notebook(self, notebook_name, notebook_path=None, format=u'json'): |
@@ -143,7 +145,7 b' class NotebookManager(LoggingConfigurable):' | |||
|
143 | 145 | raise NotImplementedError('must be implemented in a subclass') |
|
144 | 146 | |
|
145 | 147 | def save_new_notebook(self, data, notebook_path = None, name=None, format=u'json'): |
|
146 |
"""Save a new notebook and return its n |
|
|
148 | """Save a new notebook and return its name. | |
|
147 | 149 | |
|
148 | 150 | If a name is passed in, it overrides any values in the notebook data |
|
149 | 151 | and the value in the data is updated to use that value. |
@@ -1,4 +1,4 b'' | |||
|
1 |
"""Tornado handlers for the |
|
|
1 | """Tornado handlers for the sessions web service. | |
|
2 | 2 | |
|
3 | 3 | Authors: |
|
4 | 4 | |
@@ -6,7 +6,7 b' Authors:' | |||
|
6 | 6 | """ |
|
7 | 7 | |
|
8 | 8 | #----------------------------------------------------------------------------- |
|
9 |
# Copyright (C) 20 |
|
|
9 | # Copyright (C) 2013 The IPython Development Team | |
|
10 | 10 | # |
|
11 | 11 | # Distributed under the terms of the BSD License. The full license is in |
|
12 | 12 | # the file COPYING, distributed as part of this software. |
@@ -6,7 +6,7 b' Authors:' | |||
|
6 | 6 | """ |
|
7 | 7 | |
|
8 | 8 | #----------------------------------------------------------------------------- |
|
9 |
# Copyright (C) 201 |
|
|
9 | # Copyright (C) 2013 The IPython Development Team | |
|
10 | 10 | # |
|
11 | 11 | # Distributed under the terms of the BSD License. The full license is in |
|
12 | 12 | # the file COPYING, distributed as part of this software. |
@@ -53,6 +53,8 b' class SessionManager(LoggingConfigurable):' | |||
|
53 | 53 | notebook_name=notebook_name, |
|
54 | 54 | notebook_path=notebook_path, |
|
55 | 55 | kernel=kernel) |
|
56 | if notebook_path == None: | |
|
57 | model['notebook_path']="" | |
|
56 | 58 | self.sessions.append(model) |
|
57 | 59 | return model |
|
58 | 60 |
General Comments 0
You need to be logged in to leave comments.
Login now