~loggerhead-team/loggerhead/trunk-rich

« back to all changes in this revision

Viewing changes to loggerhead/controllers/download_ui.py

  • Committer: Michael Hudson
  • Date: 2008-06-23 02:07:08 UTC
  • mfrom: (166.1.3 config-vhost)
  • Revision ID: michael.hudson@canonical.com-20080623020708-eiwjeg8bhjxxnyvj
more compatible handling of server.webpath from loggerhead.conf files

Show diffs side-by-side

added added

removed removed

Lines of Context:
19
19
 
20
20
import logging
21
21
import mimetypes
22
 
import urllib
 
22
import time
23
23
 
24
24
from paste import httpexceptions
25
25
from paste.request import path_info_pop
26
26
 
27
 
from loggerhead.controllers import TemplatedBranchView
28
 
 
29
27
log = logging.getLogger("loggerhead.controllers")
30
28
 
31
29
 
32
 
class DownloadUI (TemplatedBranchView):
33
 
 
34
 
    def __call__(self, environ, start_response):
 
30
class DownloadUI (object):
 
31
 
 
32
    def __init__(self, branch):
 
33
        # BranchView object
 
34
        self._branch = branch
 
35
        self.log = branch.log
 
36
 
 
37
    def default(self, request, response):
35
38
        # /download/<rev_id>/<file_id>/[filename]
36
 
 
37
 
        h = self._history
38
 
 
39
 
        args = []
40
 
        while True:
41
 
            arg = path_info_pop(environ)
42
 
            if arg is None:
43
 
                break
44
 
            args.append(arg)
45
 
 
46
 
        if len(args) < 2:
47
 
            raise httpexceptions.HTTPMovedPermanently(
48
 
                self._branch.absolute_url('/changes'))
49
 
 
50
 
        revid = h.fix_revid(args[0])
51
 
        file_id = args[1]
52
 
        path, filename, content = h.get_file(file_id, revid)
53
 
        mime_type, encoding = mimetypes.guess_type(filename)
54
 
        if mime_type is None:
55
 
            mime_type = 'application/octet-stream'
56
 
 
57
 
        self.log.info('/download %s @ %s (%d bytes)',
58
 
                      path,
59
 
                      h.get_revno(revid),
60
 
                      len(content))
61
 
        encoded_filename = urllib.quote(filename.encode('utf-8'))
62
 
        headers = [
63
 
            ('Content-Type', mime_type),
64
 
            ('Content-Length', str(len(content))),
65
 
            ('Content-Disposition',
66
 
             "attachment; filename*=utf-8''%s" % (encoded_filename,)),
67
 
            ]
68
 
        start_response('200 OK', headers)
69
 
        return [content]
 
39
        z = time.time()
 
40
        h = self._branch.history
 
41
 
 
42
        h._branch.lock_read()
 
43
        try:
 
44
            args = []
 
45
            while 1:
 
46
                arg = path_info_pop(request.environ)
 
47
                if arg is None:
 
48
                    break
 
49
                args.append(arg)
 
50
 
 
51
            if len(args) < 2:
 
52
                raise httpexceptions.HTTPMovedPermanently(self._branch.url('../changes'))
 
53
 
 
54
            revid = h.fix_revid(args[0])
 
55
            file_id = args[1]
 
56
            path, filename, content = h.get_file(file_id, revid)
 
57
            mime_type, encoding = mimetypes.guess_type(filename)
 
58
            if mime_type is None:
 
59
                mime_type = 'application/octet-stream'
 
60
 
 
61
            self.log.info('/download %s @ %s (%d bytes)', path, h.get_revno(revid), len(content))
 
62
            response.headers['Content-Type'] = mime_type
 
63
            response.headers['Content-Length'] = len(content)
 
64
            response.headers['Content-Disposition'] = 'attachment; filename=%s'%(filename,)
 
65
            response.write(content)
 
66
        finally:
 
67
            h._branch.unlock()