summaryrefslogtreecommitdiff
path: root/vendor/CherryPy-3.2.0/sphinx/source/progguide/files/downloading.rst
blob: d431134a4a8483c1628a3dd78b0f78d3f3f5fcd4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
*****************
Downloading files
*****************

CherryPy allows you to serve a file from your page handler. Here is a simple recipe to handle downloads::


	#!python
	import glob
	import os.path

	import cherrypy
	from cherrypy.lib.static import serve_file


	class Root:
	    def index(self, directory="."):
		html = """<html><body><h2>Here are the files in the selected directory:</h2>
		<a href="index?directory=%s">Up</a><br />
		""" % os.path.dirname(os.path.abspath(directory))

		for filename in glob.glob(directory + '/*'):
		    absPath = os.path.abspath(filename)
		    if os.path.isdir(absPath):
		        html += '<a href="/index?directory=' + absPath + '">' + os.path.basename(filename) + "</a> <br />"
		    else:
		        html += '<a href="/download/?filepath=' + absPath + '">' + os.path.basename(filename) + "</a> <br />"
		        
		html += """</body></html>"""
		return html
	    index.exposed = True

	class Download:
	    
	    def index(self, filepath):
		return serve_file(filepath, "application/x-download", "attachment")
	    index.exposed = True

	if __name__ == '__main__':
	    root = Root()
	    root.download = Download()
	    cherrypy.quickstart(root)


Note that `CherryPy <http://www.cherrypy.org/wiki/CherryPy>`_ is not the fastest for doing such things. If you think you'll have many and big downloads, put CP `BehindApache <http://www.cherrypy.org/wiki/BehindApache>`_ and let Apache serve those files.