validate user data in gridftp
[qcg-portal.git] / filex / uploadhandler.py
1 from functools import wraps
2 import os
3
4 from django.core.files.uploadedfile import UploadedFile
5 from django.core.files.uploadhandler import FileUploadHandler, StopUpload, StopFutureHandlers
6 from django.views.decorators.csrf import csrf_exempt, csrf_protect
7
8 from filex.forms import HostPathForm
9 from filex.ftp import FTPOperation
10
11
12 class FtpUploadHandler(FileUploadHandler):
13     ftp = None
14     url = None
15     tmp_url = None
16
17     def new_file(self, file_name, *args, **kwargs):
18         super(FtpUploadHandler, self).new_file(file_name, *args, **kwargs)
19
20         form = HostPathForm(self.request.GET)
21
22         if self.request.user.is_anonymous() or not form.is_valid():
23             raise StopUpload(connection_reset=True)
24
25         if self.ftp is None:
26             self.ftp = FTPOperation(self.request.session['proxy'], self.chunk_size)
27
28         self.url = 'gsiftp://' + form.cleaned_data['host'] + os.path.join(form.cleaned_data['path'], self.file_name)
29         self.tmp_url = self.url + '.part'
30
31         self.ftp.put(self.tmp_url)
32
33         StopFutureHandlers()
34
35     def receive_data_chunk(self, raw_data, start):
36         self.ftp.stream.put(raw_data)
37
38     def file_complete(self, file_size):
39         # signal end of data and wait for finish
40         self.ftp.stream.put(None)
41         self.ftp.wait()
42
43         self.ftp.move(self.tmp_url, self.url)
44
45         return UploadedFile(name=self.file_name, size=file_size, charset=self.charset,
46                             content_type=self.content_type, content_type_extra=self.content_type_extra)
47
48
49 def with_ftp_upload_handler(view_func):
50     @wraps(view_func)
51     def wrapped_view(request, *args, **kwargs):
52         request.upload_handlers = [FtpUploadHandler(request)]
53
54         return csrf_protect(view_func)(request, *args, **kwargs)
55
56     return csrf_exempt(wrapped_view)