webish: fix ?t=manifest, ?t=xml so they don't throw exceptions, prune directory.xhtml
This commit is contained in:
parent
0cd730a7b3
commit
10a5ff3767
|
@ -13,13 +13,23 @@
|
||||||
|
|
||||||
<div><a href=".">Refresh this view</a></div>
|
<div><a href=".">Refresh this view</a></div>
|
||||||
<div><a href="..">Parent Directory</a></div>
|
<div><a href="..">Parent Directory</a></div>
|
||||||
<div><a href="@manifest">Manifest for this directory</a></div>
|
<div>Other representations of this directory:
|
||||||
|
<a href="?t=manifest">manifest</a>,
|
||||||
|
<a href="?t=uri">URI</a>,
|
||||||
|
<a href="?t=readonly-uri">read-only URI</a>,
|
||||||
|
<a href="?t=json">JSON</a>,
|
||||||
|
<a href="?t=xml">XML</a>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!--
|
||||||
<div>To share this directory, paste the following URI string into an
|
<div>To share this directory, paste the following URI string into an
|
||||||
"Add Shared Directory" box:
|
"Add Shared Directory" box:
|
||||||
<pre class="overflow" n:render="string" n:data="share_uri" /></div>
|
<pre class="overflow" n:render="string" n:data="share_uri" /></div>
|
||||||
<div>To share a transitively read-only copy, use the following URI instead:
|
<div>To share a transitively read-only copy, use the following URI instead:
|
||||||
<pre class="overflow" n:render="string" n:data="share_readonly_uri" /></div>
|
<pre class="overflow" n:render="string" n:data="share_readonly_uri" /></div>
|
||||||
|
-->
|
||||||
|
|
||||||
|
<div>
|
||||||
<table n:render="sequence" n:data="children" border="1">
|
<table n:render="sequence" n:data="children" border="1">
|
||||||
<tr n:pattern="header">
|
<tr n:pattern="header">
|
||||||
<td>Filename</td>
|
<td>Filename</td>
|
||||||
|
@ -39,6 +49,7 @@
|
||||||
<tr n:pattern="empty"><td>directory is empty!</td></tr>
|
<tr n:pattern="empty"><td>directory is empty!</td></tr>
|
||||||
|
|
||||||
</table>
|
</table>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div n:render="forms"/>
|
<div n:render="forms"/>
|
||||||
|
|
||||||
|
|
|
@ -31,38 +31,39 @@ class Directory(rend.Page):
|
||||||
addSlash = True
|
addSlash = True
|
||||||
docFactory = getxmlfile("directory.xhtml")
|
docFactory = getxmlfile("directory.xhtml")
|
||||||
|
|
||||||
def __init__(self, dirnode, dirname):
|
def __init__(self, dirnode, dirpath):
|
||||||
self._dirnode = dirnode
|
self._dirnode = dirnode
|
||||||
self._dirname = dirname
|
self._dirpath = dirpath
|
||||||
|
|
||||||
def childFactory(self, ctx, name):
|
def childFactory(self, ctx, name):
|
||||||
print "Directory.childFactory", name
|
print "Directory.childFactory", name
|
||||||
if name.startswith("freeform"): # ick
|
if name.startswith("freeform"): # ick
|
||||||
return None
|
return None
|
||||||
if name == "@manifest": # ick, this time it's my fault
|
#if name == "@manifest": # ick, this time it's my fault
|
||||||
return Manifest(self._dirnode, self._dirname)
|
# return Manifest(self._dirnode, self._dirpath)
|
||||||
return rend.NotFound
|
return rend.NotFound
|
||||||
|
|
||||||
|
def dirpath_as_string(self):
|
||||||
|
return "/" + "/".join(self._dirpath)
|
||||||
|
|
||||||
def render_title(self, ctx, data):
|
def render_title(self, ctx, data):
|
||||||
print "DIRECTORY.render_title"
|
print "DIRECTORY.render_title"
|
||||||
return ctx.tag["Directory '%s':" % self._dirname]
|
return ctx.tag["Directory '%s':" % self.dirpath_as_string()]
|
||||||
|
|
||||||
def render_header(self, ctx, data):
|
def render_header(self, ctx, data):
|
||||||
parent_directories = self._dirname.split("/")
|
parent_directories = ("<root>",) + self._dirpath
|
||||||
num_dirs = len(parent_directories)
|
num_dirs = len(parent_directories)
|
||||||
|
|
||||||
header = ["Directory '"]
|
header = ["Directory '"]
|
||||||
for i,d in enumerate(parent_directories):
|
for i,d in enumerate(parent_directories):
|
||||||
if d == "":
|
upness = num_dirs - i - 1
|
||||||
link = "/".join([".."] * (num_dirs - i))
|
if upness:
|
||||||
header.append(T.a(href=link)["/"])
|
link = "/".join( ("..",) * upness )
|
||||||
else:
|
else:
|
||||||
if i == num_dirs-1:
|
|
||||||
link = "."
|
link = "."
|
||||||
else:
|
print "LINK", link, d
|
||||||
link = "/".join([".."] * (num_dirs - i - 1))
|
|
||||||
header.append(T.a(href=link)[d])
|
header.append(T.a(href=link)[d])
|
||||||
if i < num_dirs - 1:
|
if upness != 0:
|
||||||
header.append("/")
|
header.append("/")
|
||||||
header.append("'")
|
header.append("'")
|
||||||
|
|
||||||
|
@ -363,7 +364,12 @@ class FileJSONMetadata(rend.Page):
|
||||||
self._filenode = filenode
|
self._filenode = filenode
|
||||||
|
|
||||||
def renderHTTP(self, ctx):
|
def renderHTTP(self, ctx):
|
||||||
file_uri = self._filenode.get_uri()
|
req = inevow.IRequest(ctx)
|
||||||
|
req.setHeader("content-type", "text/plain")
|
||||||
|
return self.renderNode(self._filenode)
|
||||||
|
|
||||||
|
def renderNode(self, filenode):
|
||||||
|
file_uri = filenode.get_uri()
|
||||||
pieces = unpack_uri(file_uri)
|
pieces = unpack_uri(file_uri)
|
||||||
data = "filenode\n"
|
data = "filenode\n"
|
||||||
data += "JSONny stuff here\n"
|
data += "JSONny stuff here\n"
|
||||||
|
@ -371,8 +377,8 @@ class FileJSONMetadata(rend.Page):
|
||||||
return data
|
return data
|
||||||
|
|
||||||
class FileXMLMetadata(FileJSONMetadata):
|
class FileXMLMetadata(FileJSONMetadata):
|
||||||
def renderHTTP(self, ctx):
|
def renderNode(self, filenode):
|
||||||
file_uri = self._filenode.get_uri()
|
file_uri = filenode.get_uri()
|
||||||
pieces = unpack_uri(file_uri)
|
pieces = unpack_uri(file_uri)
|
||||||
data = "<xmlish>\n"
|
data = "<xmlish>\n"
|
||||||
data += "filenode\n"
|
data += "filenode\n"
|
||||||
|
@ -381,8 +387,8 @@ class FileXMLMetadata(FileJSONMetadata):
|
||||||
return data
|
return data
|
||||||
|
|
||||||
class FileURI(FileJSONMetadata):
|
class FileURI(FileJSONMetadata):
|
||||||
def renderHTTP(self, ctx):
|
def renderNode(self, filenode):
|
||||||
file_uri = self._filenode.get_uri()
|
file_uri = filenode.get_uri()
|
||||||
return file_uri
|
return file_uri
|
||||||
|
|
||||||
class DirnodeWalkerMixin:
|
class DirnodeWalkerMixin:
|
||||||
|
@ -453,10 +459,14 @@ class DirectoryJSONMetadata(rend.Page):
|
||||||
self._dirnode = dirnode
|
self._dirnode = dirnode
|
||||||
|
|
||||||
def renderHTTP(self, ctx):
|
def renderHTTP(self, ctx):
|
||||||
file_uri = self._dirnode.get_uri()
|
req = inevow.IRequest(ctx)
|
||||||
|
req.setHeader("content-type", "text/plain")
|
||||||
|
return self.renderNode(self._dirnode)
|
||||||
|
|
||||||
|
def renderNode(self, node):
|
||||||
data = "dirnode\n"
|
data = "dirnode\n"
|
||||||
data += "JSONny stuff here\n"
|
data += "JSONny stuff here\n"
|
||||||
d = self._dirnode.list()
|
d = node.list()
|
||||||
def _got(children, data):
|
def _got(children, data):
|
||||||
for name, childnode in children.iteritems():
|
for name, childnode in children.iteritems():
|
||||||
data += "name=%s, child_uri=%s" % (name, childnode.get_uri())
|
data += "name=%s, child_uri=%s" % (name, childnode.get_uri())
|
||||||
|
@ -469,18 +479,16 @@ class DirectoryJSONMetadata(rend.Page):
|
||||||
return d
|
return d
|
||||||
|
|
||||||
class DirectoryXMLMetadata(DirectoryJSONMetadata):
|
class DirectoryXMLMetadata(DirectoryJSONMetadata):
|
||||||
def renderHTTP(self, ctx):
|
def renderNode(self, node):
|
||||||
file_uri = self._dirnode.get_uri()
|
|
||||||
pieces = unpack_uri(file_uri)
|
|
||||||
data = "<xmlish>\n"
|
data = "<xmlish>\n"
|
||||||
data += "dirnode\n"
|
data += "dirnode\n"
|
||||||
data += "stuff here\n"
|
data += "stuff here\n"
|
||||||
d = self._dirnode.list()
|
d = node.list()
|
||||||
def _got(children, data):
|
def _got(children, data):
|
||||||
for name, childnode in children:
|
for name, childnode in children.iteritems():
|
||||||
data += "name=%s, child_uri=%s" % (name, childnode.get_uri())
|
data += "name=%s, child_uri=%s" % (name, childnode.get_uri())
|
||||||
return data
|
return data
|
||||||
d.addCallback(_got)
|
d.addCallback(_got, data)
|
||||||
def _done(data):
|
def _done(data):
|
||||||
data += "</done>\n"
|
data += "</done>\n"
|
||||||
return data
|
return data
|
||||||
|
@ -488,14 +496,12 @@ class DirectoryXMLMetadata(DirectoryJSONMetadata):
|
||||||
return d
|
return d
|
||||||
|
|
||||||
class DirectoryURI(DirectoryJSONMetadata):
|
class DirectoryURI(DirectoryJSONMetadata):
|
||||||
def renderHTTP(self, ctx):
|
def renderNode(self, node):
|
||||||
dir_uri = self._dirnode.get_uri()
|
return node.get_uri()
|
||||||
return dir_uri
|
|
||||||
|
|
||||||
class DirectoryReadonlyURI(DirectoryJSONMetadata):
|
class DirectoryReadonlyURI(DirectoryJSONMetadata):
|
||||||
def renderHTTP(self, ctx):
|
def renderNode(self, node):
|
||||||
dir_uri = self._dirnode.get_immutable_uri()
|
return node.get_immutable_uri()
|
||||||
return dir_uri
|
|
||||||
|
|
||||||
class POSTHandler(rend.Page):
|
class POSTHandler(rend.Page):
|
||||||
def __init__(self, node):
|
def __init__(self, node):
|
||||||
|
@ -658,15 +664,18 @@ class PUTHandler(rend.Page):
|
||||||
|
|
||||||
class Manifest(rend.Page):
|
class Manifest(rend.Page):
|
||||||
docFactory = getxmlfile("manifest.xhtml")
|
docFactory = getxmlfile("manifest.xhtml")
|
||||||
def __init__(self, dirnode, dirname):
|
def __init__(self, dirnode, dirpath):
|
||||||
self._dirnode = dirnode
|
self._dirnode = dirnode
|
||||||
self._dirname = dirname
|
self._dirpath = dirpath
|
||||||
|
|
||||||
|
def dirpath_as_string(self):
|
||||||
|
return "/" + "/".join(self._dirpath)
|
||||||
|
|
||||||
def render_title(self, ctx):
|
def render_title(self, ctx):
|
||||||
return T.title["Manifest of %s" % self._dirname]
|
return T.title["Manifest of %s" % self.dirpath_as_string()]
|
||||||
|
|
||||||
def render_header(self, ctx):
|
def render_header(self, ctx):
|
||||||
return T.p["Manifest of %s" % self._dirname]
|
return T.p["Manifest of %s" % self.dirpath_as_string()]
|
||||||
|
|
||||||
def data_items(self, ctx, data):
|
def data_items(self, ctx, data):
|
||||||
return self._dirnode.build_manifest()
|
return self._dirnode.build_manifest()
|
||||||
|
@ -721,7 +730,6 @@ class VDrive(rend.Page):
|
||||||
if method == "GET":
|
if method == "GET":
|
||||||
# the node must exist, and our operation will be performed on the
|
# the node must exist, and our operation will be performed on the
|
||||||
# node itself.
|
# node itself.
|
||||||
name = path[-1]
|
|
||||||
d = self.get_child_at_path(path)
|
d = self.get_child_at_path(path)
|
||||||
def file_or_dir(node):
|
def file_or_dir(node):
|
||||||
if IFileNode.providedBy(node):
|
if IFileNode.providedBy(node):
|
||||||
|
@ -731,7 +739,7 @@ class VDrive(rend.Page):
|
||||||
elif t == "":
|
elif t == "":
|
||||||
# send contents as the result
|
# send contents as the result
|
||||||
print "FileDownloader"
|
print "FileDownloader"
|
||||||
return FileDownloader(name, node), ()
|
return FileDownloader(path[-1], node), ()
|
||||||
elif t == "json":
|
elif t == "json":
|
||||||
print "Localfilejsonmetadata"
|
print "Localfilejsonmetadata"
|
||||||
return FileJSONMetadata(node), ()
|
return FileJSONMetadata(node), ()
|
||||||
|
@ -749,7 +757,7 @@ class VDrive(rend.Page):
|
||||||
elif t == "":
|
elif t == "":
|
||||||
# send an HTML representation of the directory
|
# send an HTML representation of the directory
|
||||||
print "GOT HTML DIR"
|
print "GOT HTML DIR"
|
||||||
return Directory(node, name), ()
|
return Directory(node, path), ()
|
||||||
elif t == "json":
|
elif t == "json":
|
||||||
return DirectoryJSONMetadata(node), ()
|
return DirectoryJSONMetadata(node), ()
|
||||||
elif t == "xml":
|
elif t == "xml":
|
||||||
|
@ -758,6 +766,8 @@ class VDrive(rend.Page):
|
||||||
return DirectoryURI(node), ()
|
return DirectoryURI(node), ()
|
||||||
elif t == "readonly-uri":
|
elif t == "readonly-uri":
|
||||||
return DirectoryReadonlyURI(node), ()
|
return DirectoryReadonlyURI(node), ()
|
||||||
|
elif t == "manifest":
|
||||||
|
return Manifest(node, path), ()
|
||||||
else:
|
else:
|
||||||
raise RuntimeError("bad t=%s" % t)
|
raise RuntimeError("bad t=%s" % t)
|
||||||
else:
|
else:
|
||||||
|
@ -847,9 +857,9 @@ class Root(rend.Page):
|
||||||
child_webform_css = webform.defaultCSS
|
child_webform_css = webform.defaultCSS
|
||||||
child_tahoe_css = nevow_File(util.sibpath(__file__, "web/tahoe.css"))
|
child_tahoe_css = nevow_File(util.sibpath(__file__, "web/tahoe.css"))
|
||||||
|
|
||||||
#child_welcome = Welcome()
|
#NOTchild_welcome = Welcome()
|
||||||
|
|
||||||
def child_global_vdrive(self, ctx):
|
def NOTchild_global_vdrive(self, ctx):
|
||||||
client = IClient(ctx)
|
client = IClient(ctx)
|
||||||
vdrive = client.getServiceNamed("vdrive")
|
vdrive = client.getServiceNamed("vdrive")
|
||||||
if vdrive.have_public_root():
|
if vdrive.have_public_root():
|
||||||
|
@ -859,7 +869,7 @@ class Root(rend.Page):
|
||||||
else:
|
else:
|
||||||
return static.Data("sorry, still initializing", "text/plain")
|
return static.Data("sorry, still initializing", "text/plain")
|
||||||
|
|
||||||
def child_private_vdrive(self, ctx):
|
def NOTchild_private_vdrive(self, ctx):
|
||||||
client = IClient(ctx)
|
client = IClient(ctx)
|
||||||
vdrive = client.getServiceNamed("vdrive")
|
vdrive = client.getServiceNamed("vdrive")
|
||||||
if vdrive.have_private_root():
|
if vdrive.have_private_root():
|
||||||
|
@ -907,7 +917,7 @@ class Root(rend.Page):
|
||||||
def render_global_vdrive(self, ctx, data):
|
def render_global_vdrive(self, ctx, data):
|
||||||
if IClient(ctx).getServiceNamed("vdrive").have_public_root():
|
if IClient(ctx).getServiceNamed("vdrive").have_public_root():
|
||||||
return T.p["To view the global shared filestore, ",
|
return T.p["To view the global shared filestore, ",
|
||||||
T.a(href="../global_vdrive")["Click Here!"],
|
T.a(href="vdrive/global")["Click Here!"],
|
||||||
]
|
]
|
||||||
return T.p["vdrive.furl not specified (or vdrive server not "
|
return T.p["vdrive.furl not specified (or vdrive server not "
|
||||||
"responding), no vdrive available."]
|
"responding), no vdrive available."]
|
||||||
|
@ -915,7 +925,7 @@ class Root(rend.Page):
|
||||||
def render_private_vdrive(self, ctx, data):
|
def render_private_vdrive(self, ctx, data):
|
||||||
if IClient(ctx).getServiceNamed("vdrive").have_private_root():
|
if IClient(ctx).getServiceNamed("vdrive").have_private_root():
|
||||||
return T.p["To view your personal private non-shared filestore, ",
|
return T.p["To view your personal private non-shared filestore, ",
|
||||||
T.a(href="../private_vdrive")["Click Here!"],
|
T.a(href="vdrive/private")["Click Here!"],
|
||||||
]
|
]
|
||||||
return T.p["personal vdrive not available."]
|
return T.p["personal vdrive not available."]
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue