##// END OF EJS Templates
path with spaces completely fixed
path with spaces completely fixed

File last commit:

r13011:f6e0ae2c
r13013:15d695b1
Show More
contentmanager.py
103 lines | 3.7 KiB | text/x-python | PythonLexer
"""A base class contents manager.
Authors:
* Zach Sailer
"""
#-----------------------------------------------------------------------------
# Copyright (C) 2013 The IPython Development Team
#
# Distributed under the terms of the BSD License. The full license is in
# the file COPYING, distributed as part of this software.
#-----------------------------------------------------------------------------
#-----------------------------------------------------------------------------
# Imports
#-----------------------------------------------------------------------------
import datetime
import io
import os
import glob
import shutil
import ast
import base64
from tornado import web
from IPython.config.configurable import LoggingConfigurable
from IPython.nbformat import current
from IPython.utils.traitlets import List, Dict, Unicode, TraitError
from IPython.utils import tz
#-----------------------------------------------------------------------------
# Classes
#-----------------------------------------------------------------------------
class ContentManager(LoggingConfigurable):
content_dir = Unicode(os.getcwdu(), config=True, help="""
The directory to use for contents.
""")
contents = List()
def get_content_names(self, content_path):
"""List of dicts of files in content_path"""
names = glob.glob(os.path.join(self.content_dir, content_path,'*'))
contents = list()
dirs = list()
notebooks = list()
for name in names:
if os.path.isdir(name) == True:
dirs.append(os.path.split(name)[1])
elif os.path.splitext(name)[1] == '.ipynb':
notebooks.append(os.path.split(name)[1])
else:
contents.append(os.path.split(name)[1])
return dirs, notebooks, contents
def list_contents(self, content_path):
"""List all contents in the named path."""
dir_names, notebook_names, content_names = self.get_content_names(content_path)
content_mapping = []
for name in dir_names:
model = self.content_model(name, content_path, type='dir')
content_mapping.append(model)
for name in content_names:
model = self.content_model(name, content_path, type='file')
content_mapping.append(model)
for name in notebook_names:
model = self.content_model(name, content_path, type='notebook')
content_mapping.append(model)
return content_mapping
def get_path_by_name(self, name, content_path):
"""Return a full path to content"""
path = os.path.join(self.content_dir, content_path, name)
return path
def content_info(self, name, content_path):
"""Read the content of a named file"""
file_type = os.path.splitext(os.path.basename(name))[1]
full_path = self.get_path_by_name(name, content_path)
info = os.stat(full_path)
size = info.st_size
last_modified = tz.utcfromtimestamp(info.st_mtime)
return last_modified, file_type, size
def content_model(self, name, content_path, type=None):
"""Create a dict standard model for any file (other than notebooks)"""
last_modified, file_type, size = self.content_info(name, content_path)
model = {"name": name,
"path": content_path,
"type": type,
"MIME-type": "",
"last_modified": last_modified.ctime(),
"size": size}
return model
def delete_content(self, content_path):
"""Delete a file"""
os.unlink(os.path.join(self.content_dir, content_path))