| author | rougeronj |
| Tue, 25 Sep 2012 11:07:13 +0200 | |
| changeset 795 | 923429f142ea |
| parent 791 | 12ba862f33fa |
| child 796 | 7d1267aa2f55 |
| permissions | -rw-r--r-- |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
1 |
from django.conf import settings |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
2 |
from django.contrib.auth.decorators import login_required |
| 319 | 3 |
from django.contrib.auth.models import Group |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
4 |
from django.core.urlresolvers import reverse |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
5 |
from django.forms.models import model_to_dict |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
6 |
from django.forms.util import ErrorList |
| 319 | 7 |
from django.http import HttpResponse |
|
791
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
8 |
from django.shortcuts import render_to_response, redirect |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
9 |
from django.template import RequestContext |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
10 |
from django.utils.translation import ugettext as _, ungettext |
| 319 | 11 |
from ldt.ldt_utils.forms import ContentForm, MediaForm |
12 |
from guardian.shortcuts import remove_perm |
|
| 404 | 13 |
from ldt.ldt_utils.models import Content, Media, Project |
| 384 | 14 |
from ldt.security.utils import assign_perm_to_obj, add_change_attr, get_userlist, get_userlist_model |
| 319 | 15 |
from ldt.security.cache import cached_assign |
| 325 | 16 |
from ldt.user.forms import PictureForm |
| 710 | 17 |
from tagging.models import Tag, TaggedItem |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
18 |
import ldt.utils.path as ldt_utils_path |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
19 |
import logging |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
20 |
import mimetypes |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
21 |
import os |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
22 |
import urllib2 |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
23 |
import subprocess |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
24 |
import re |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
25 |
import datetime |
|
644
94429061bbfa
First step of pagination for contents and projet in workspace home.
cavaliet
parents:
544
diff
changeset
|
26 |
import math |
|
779
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
27 |
import requests |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
28 |
import django.utils.simplejson as simplejson |
|
791
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
29 |
import urlparse |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
30 |
|
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
31 |
def write_content_base(request, iri_id=None): |
|
795
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
32 |
if iri_id: |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
33 |
instance_content = Content.safe_objects.get(iri_id=iri_id) #@UndefinedVariable |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
34 |
instance_media = instance_content.media_obj |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
35 |
logging.debug("write_content_base : valid form: for instance : media -> " + repr(instance_media) + " content : for instance : " + repr(instance_content)) #@UndefinedVariable |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
36 |
else: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
37 |
logging.debug("No iri_id") #@UndefinedVariable |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
38 |
instance_content = None |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
39 |
instance_media = None |
| 734 | 40 |
current_front_project = None |
41 |
if instance_content: |
|
42 |
current_front_project = instance_content.front_project |
|
|
795
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
43 |
form_status = 'none' |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
44 |
if request.method == "POST": |
|
781
f094e31cd30b
merge content.py des modifications de Louise et Julien
rougeronj
parents:
779
diff
changeset
|
45 |
|
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
46 |
if instance_content is not None: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
47 |
content_instance_val = model_to_dict(instance_content, exclude=ContentForm.Meta.exclude) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
48 |
else: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
49 |
content_instance_val = {} |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
50 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
51 |
if instance_media is not None: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
52 |
media_instance_val = model_to_dict(instance_media, exclude=MediaForm.Meta.exclude) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
53 |
else: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
54 |
media_instance_val = {} |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
55 |
#add prefix |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
56 |
|
|
782
dfc0cb4355f4
small correction to avoid warnings
ymh <ymh.work@gmail.com>
parents:
781
diff
changeset
|
57 |
def add_prefix(_dict, prefix): |
|
dfc0cb4355f4
small correction to avoid warnings
ymh <ymh.work@gmail.com>
parents:
781
diff
changeset
|
58 |
return dict([('%s-%s' % (prefix, key), value) for key,value in _dict.items()]) |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
59 |
|
|
782
dfc0cb4355f4
small correction to avoid warnings
ymh <ymh.work@gmail.com>
parents:
781
diff
changeset
|
60 |
content_instance_val = add_prefix(content_instance_val, "content") |
|
791
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
61 |
media_instance_val= add_prefix(media_instance_val, "media") |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
62 |
src_video=request.POST.get('media-src') |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
63 |
for k in request.POST.keys(): |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
64 |
value = request.POST.get(k) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
65 |
content_instance_val[k] = value |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
66 |
media_instance_val[k] = value |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
67 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
68 |
content_instance_val['read_list'] = request.POST.getlist('read_list') |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
69 |
content_instance_val['write_list'] = request.POST.getlist('write_list') |
|
779
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
70 |
content_instance_val['share'] = request.POST.get('share', True) |
|
791
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
71 |
|
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
72 |
content_form = ContentForm(content_instance_val, prefix="content", instance=instance_content) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
73 |
media_form = MediaForm(media_instance_val, request.FILES, prefix="media", instance=instance_media) |
|
333
4ddf8c0eeab4
Image size is checked before save + project image can be set manually
verrierj
parents:
327
diff
changeset
|
74 |
picture_form = PictureForm(None, request.POST, request.FILES) |
| 325 | 75 |
|
|
791
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
76 |
|
| 410 | 77 |
if request.user.is_staff: |
78 |
content_form.fields['front_project'].queryset = Project.objects.filter(contents__in=[instance_content]) |
|
| 544 | 79 |
|
| 410 | 80 |
|
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
81 |
media_valid = media_form.is_valid() |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
82 |
content_valid = content_form.is_valid() |
|
333
4ddf8c0eeab4
Image size is checked before save + project image can be set manually
verrierj
parents:
327
diff
changeset
|
83 |
picture_valid = picture_form.is_valid() |
|
4ddf8c0eeab4
Image size is checked before save + project image can be set manually
verrierj
parents:
327
diff
changeset
|
84 |
|
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
85 |
logging.debug("write_content_base : valid form: for instance : " + repr(instance_media) + " -> media " + str(media_valid) + " content : for instance : " + repr(instance_content) + " : " + str(content_valid)) #@UndefinedVariable |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
86 |
|
|
333
4ddf8c0eeab4
Image size is checked before save + project image can be set manually
verrierj
parents:
327
diff
changeset
|
87 |
if media_valid and content_valid and picture_valid: |
|
781
f094e31cd30b
merge content.py des modifications de Louise et Julien
rougeronj
parents:
779
diff
changeset
|
88 |
|
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
89 |
# see if media must be created |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
90 |
cleaned_data = {} |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
91 |
cleaned_data.update(media_form.cleaned_data) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
92 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
93 |
media_input_type = content_form.cleaned_data["media_input_type"] |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
94 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
95 |
if media_input_type == "none": |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
96 |
media = None |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
97 |
elif media_input_type == "link": |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
98 |
media = content_form.cleaned_data["media_obj"] |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
99 |
created = False |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
100 |
elif media_input_type == "create": |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
101 |
del cleaned_data["media_file"] |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
102 |
if not cleaned_data['videopath']: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
103 |
cleaned_data['videopath'] = settings.STREAM_URL |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
104 |
# if the source is already http:// or rtmp:// we don't have to add STREAM_URL |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
105 |
if cleaned_data['src'].startswith("rtmp://") or cleaned_data['src'].startswith("http://"): |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
106 |
cleaned_data['videopath'] = '' |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
107 |
media, created = Media.objects.get_or_create(src=cleaned_data['src'], defaults=cleaned_data) #@UndefinedVariable |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
108 |
elif media_input_type == "url" or media_input_type == "upload" : |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
109 |
# copy file |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
110 |
#complet src |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
111 |
destination_file = None |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
112 |
source_file = None |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
113 |
try: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
114 |
if media_input_type == "url": |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
115 |
url = cleaned_data["external_src_url"] |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
116 |
source_file = urllib2.urlopen(url) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
117 |
source_filename = source_file.info().get('Content-Disposition', None) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
118 |
if not source_filename: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
119 |
source_filename = urlparse.urlparse(url).path.rstrip("/").split('/')[-1] |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
120 |
elif media_input_type == "upload": |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
121 |
#source_file = request.FILES['media-media_file'] |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
122 |
# At this point the file has already be uploaded thanks to the upload view, and original file name is sent through a post var |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
123 |
source_filename = request.POST["media-local_file_name"] |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
124 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
125 |
source_filename = ldt_utils_path.sanitize_filename(source_filename) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
126 |
destination_filepath = os.path.join(settings.STREAM_PATH, source_filename) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
127 |
base_source_filename = source_filename |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
128 |
extension = base_source_filename.split(".")[-1] |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
129 |
if extension == base_source_filename: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
130 |
extension = "" |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
131 |
base_basename_filename = base_source_filename |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
132 |
else: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
133 |
base_basename_filename = base_source_filename[:-1 * (len(extension) + 1)] |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
134 |
i = 0 |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
135 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
136 |
while os.path.exists(destination_filepath): |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
137 |
base_source_filename = "%s.%d.%s" % (base_basename_filename, i, extension) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
138 |
destination_filepath = os.path.join(settings.STREAM_PATH, base_source_filename) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
139 |
i += 1 |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
140 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
141 |
if media_input_type == "url": |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
142 |
# we upload the file if we are in url case |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
143 |
destination_file = open(destination_filepath, "wb") |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
144 |
chunck = source_file.read(2048) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
145 |
while chunck: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
146 |
destination_file.write(chunck) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
147 |
chunck = source_file.read(2048) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
148 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
149 |
elif media_input_type == "upload": |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
150 |
# The media file has been uploaded in the session temp folder |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
151 |
# so we just have to move to the regular folder and rename it. |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
152 |
if os.path.exists(os.path.join(settings.STREAM_PATH, "tmp/" + request.COOKIES[settings.SESSION_COOKIE_NAME] + "/", source_filename)): |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
153 |
os.rename(os.path.join(settings.STREAM_PATH, "tmp/" + request.COOKIES[settings.SESSION_COOKIE_NAME] + "/", source_filename), os.path.join(settings.STREAM_PATH, base_source_filename)) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
154 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
155 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
156 |
src_prefix = settings.STREAM_SRC_PREFIX.rstrip("/") |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
157 |
if len(src_prefix) > 0: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
158 |
cleaned_data["src"] = src_prefix + "/" + base_source_filename |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
159 |
else: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
160 |
cleaned_data["src"] = base_source_filename |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
161 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
162 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
163 |
except Exception as inst: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
164 |
logging.debug("write_content_base : POST error when processing file:" + str(inst)) #@UndefinedVariable |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
165 |
form_status = "error" |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
166 |
#set error for form |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
167 |
if media_input_type == "url": |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
168 |
errors = media_form._errors.setdefault("external_src_url", ErrorList()) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
169 |
errors.append(_("Problem when downloading file from url : ") + url) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
170 |
elif media_input_type == "upload": |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
171 |
errors = media_form._errors.setdefault("media_file", ErrorList()) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
172 |
errors.append(_("Problem when uploading file : ") + str(inst)) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
173 |
finally: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
174 |
if media_input_type == "url": |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
175 |
if destination_file: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
176 |
destination_file.close() |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
177 |
if source_file: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
178 |
source_file.close() |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
179 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
180 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
181 |
if form_status != "error": |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
182 |
#try: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
183 |
del cleaned_data["media_file"] |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
184 |
if not cleaned_data['videopath']: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
185 |
cleaned_data['videopath'] = settings.STREAM_URL |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
186 |
mimetype = cleaned_data.get('mimetype_field', None) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
187 |
if not mimetype: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
188 |
mimetype = mimetypes.guess_type(cleaned_data['src']) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
189 |
cleaned_data['mimetype_field'] = mimetype |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
190 |
media, created = Media.safe_objects.get_or_create(src=cleaned_data['src'], defaults=cleaned_data) #@UndefinedVariable |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
191 |
cached_assign('view_media', request.user, media) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
192 |
else: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
193 |
media = None |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
194 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
195 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
196 |
if media and not created: |
| 383 | 197 |
for attribute in ('external_id', 'external_permalink', 'external_publication_url', 'external_src_url', 'media_creation_date', 'videopath', 'duration', 'description', 'title', 'front_project'): |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
198 |
setattr(media, attribute, cleaned_data.get(attribute)) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
199 |
mimetype = cleaned_data.get('mimetype_field', None) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
200 |
if not mimetype: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
201 |
mimetype = mimetypes.guess_type(media.src) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
202 |
media.mimetype_field = mimetype |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
203 |
cached_assign('view_media', request.user, media) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
204 |
cached_assign('change_media', request.user, media) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
205 |
media.save() |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
206 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
207 |
if form_status != "error": |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
208 |
content_defaults = {} |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
209 |
content_defaults.update(content_form.cleaned_data) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
210 |
content_defaults['media_obj'] = media |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
211 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
212 |
for key in ["media_input_type", "groups", "is_public", "read_list", "write_list", "share" ]: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
213 |
del content_defaults[key] |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
214 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
215 |
content, created = Content.safe_objects.get_or_create(iri_id=content_form.cleaned_data['iri_id'], defaults=content_defaults) #@UndefinedVariable |
| 325 | 216 |
|
| 544 | 217 |
if not created and not request.user.has_perm('ldt_utils.change_content', content): |
218 |
raise AttributeError("%s is not allowed to change content %s" % (request.user, content)) |
|
219 |
||
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
220 |
cached_assign('change_content', request.user, content) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
221 |
cached_assign('view_content', request.user, content) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
222 |
everyone = Group.objects.get(name=settings.PUBLIC_GROUP_NAME) |
| 505 | 223 |
|
|
795
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
224 |
# On separe la gestion des permissions du media et du content |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
225 |
# Si le media est public, alors le content l'est automatiquement |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
226 |
# Si le media n'est pas public, on veut pouvoir choisir si le content est liste ou non sur le front |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
227 |
|
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
228 |
if media_form.cleaned_data['media_public']: |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
229 |
cached_assign('view_content', everyone, content) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
230 |
if media: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
231 |
cached_assign('view_media', everyone, media) |
| 505 | 232 |
else: |
| 515 | 233 |
remove_perm('ldt_utils.view_media', everyone, media) |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
234 |
if media: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
235 |
assign_perm_to_obj(media, content_form.cleaned_data['read_list'], content_form.cleaned_data['write_list'], request.user) |
|
795
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
236 |
if content_form.cleaned_data['is_public']: |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
237 |
cached_assign('view_content', everyone, content) |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
238 |
else: |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
239 |
remove_perm('ldt_utils.view_content', everyone, content) |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
240 |
assign_perm_to_obj(content, content_form.cleaned_data['read_list'], content_form.cleaned_data['write_list'], request.user) |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
241 |
|
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
242 |
if not created: |
|
781
f094e31cd30b
merge content.py des modifications de Louise et Julien
rougeronj
parents:
779
diff
changeset
|
243 |
for attribute in ('iriurl', 'title', 'description', 'duration', 'content_creation_date', 'tags', 'media_obj'): |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
244 |
setattr(content, attribute, content_defaults[attribute]) |
|
781
f094e31cd30b
merge content.py des modifications de Louise et Julien
rougeronj
parents:
779
diff
changeset
|
245 |
|
| 383 | 246 |
if request.user.is_staff and content_defaults.has_key('front_project'): |
247 |
content.front_project = content_defaults['front_project'] |
|
| 544 | 248 |
|
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
249 |
content.save() |
|
333
4ddf8c0eeab4
Image size is checked before save + project image can be set manually
verrierj
parents:
327
diff
changeset
|
250 |
picture_form.model = content |
|
4ddf8c0eeab4
Image size is checked before save + project image can be set manually
verrierj
parents:
327
diff
changeset
|
251 |
picture_form.save() |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
252 |
form_status = 'saved' |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
253 |
media_form = MediaForm(instance=media, prefix="media") |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
254 |
content_form = ContentForm(instance=content, prefix="content") |
|
333
4ddf8c0eeab4
Image size is checked before save + project image can be set manually
verrierj
parents:
327
diff
changeset
|
255 |
picture_form = PictureForm() |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
256 |
else: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
257 |
form_status = 'error' |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
258 |
else: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
259 |
form_status = 'empty' |
|
795
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
260 |
initial_c = { 'media_input_type':"link"} |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
261 |
initial_m = {} |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
262 |
if instance_media: |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
263 |
initial_m['media_public'] = instance_media.is_public |
| 544 | 264 |
else: |
|
795
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
265 |
initial_m['media_public'] = True |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
266 |
if instance_content: |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
267 |
initial_c['is_public'] = instance_content.is_public |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
268 |
else: |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
269 |
initial_c['is_public'] = True |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
270 |
content_form = ContentForm(prefix="content", instance=instance_content, initial=initial_c) |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
271 |
media_form = MediaForm(prefix="media", instance=instance_media, initial=initial_m) |
|
333
4ddf8c0eeab4
Image size is checked before save + project image can be set manually
verrierj
parents:
327
diff
changeset
|
272 |
picture_form = PictureForm() |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
273 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
274 |
if instance_content is not None: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
275 |
content_form.media_input_type = "link" |
| 404 | 276 |
|
277 |
if request.user.is_staff: |
|
278 |
content_form.fields['front_project'].queryset = Project.objects.filter(contents__in=[instance_content]) |
|
| 734 | 279 |
|
280 |
return content_form, media_form, picture_form, form_status, current_front_project |
|
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
281 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
282 |
@login_required |
|
791
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
283 |
def write_content(request, iri_id=None): |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
284 |
case=0 |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
285 |
submit_action = request.REQUEST.get("submit_button", False) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
286 |
member_list = admin_list = [] |
| 734 | 287 |
current_front_project = None |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
288 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
289 |
if submit_action == "prepare_delete": |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
290 |
errors, titles = prepare_delete_content(request, iri_id) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
291 |
if errors and len(errors) > 0: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
292 |
message = ungettext("There is %(count)d error when deleting content", "There are %(count)d errors when deleting content", len(errors)) % { 'count': len(errors)} |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
293 |
title_msg = _('title error deleting content') |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
294 |
else: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
295 |
message = _("Confirm delete content %(titles)s") % { 'titles' : ",".join(titles) } |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
296 |
title_msg = _("confirm delete content") |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
297 |
return render_to_response('ldt/ldt_utils/error_confirm.html', {'errors':errors, 'message':message, 'title': title_msg}, context_instance=RequestContext(request)) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
298 |
elif submit_action == "delete": |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
299 |
delete_content(request, iri_id) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
300 |
form_status = "deleted" |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
301 |
content_form = ContentForm() |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
302 |
media_form = MediaForm() |
|
791
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
303 |
picture_form = PictureForm() |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
304 |
elif submit_action=="close": |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
305 |
return redirect("root-view") |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
306 |
else: |
| 734 | 307 |
content_form, media_form, picture_form, form_status, current_front_project = write_content_base(request, iri_id) |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
308 |
if iri_id: |
|
795
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
309 |
content_temp = Content.objects.get(iri_id=iri_id) |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
310 |
media_temp = content_temp.media_obj |
|
923429f142ea
Possibility to list a content on the front or not, with a private media. A media can be private, and the content public (listed or not)
rougeronj
parents:
791
diff
changeset
|
311 |
member_list, admin_list = get_userlist_model(media_temp, request.user) |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
312 |
if iri_id: |
|
321
c68744402249
Change urls used in reverse to be compatible with the new organization
verrierj
parents:
319
diff
changeset
|
313 |
create_content_action = reverse('ldt.ldt_utils.views.content.write_content', kwargs={'iri_id':iri_id}) |
| 327 | 314 |
img_container = content_form.instance |
|
791
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
315 |
|
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
316 |
else: |
|
321
c68744402249
Change urls used in reverse to be compatible with the new organization
verrierj
parents:
319
diff
changeset
|
317 |
create_content_action = reverse('ldt.ldt_utils.views.content.write_content') |
| 327 | 318 |
img_container = '' |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
319 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
320 |
session_key = request.COOKIES[settings.SESSION_COOKIE_NAME] |
| 410 | 321 |
cookie_name = settings.SESSION_COOKIE_NAME |
|
702
d50cb79f96ee
Add category cloud in front and media page. Correct js pagination in workspace. Languages updated.
cavaliet
parents:
646
diff
changeset
|
322 |
# Media.safe_objects.all() does not return the good list of media, so we get them from the Content.safe_objects |
|
d50cb79f96ee
Add category cloud in front and media page. Correct js pagination in workspace. Languages updated.
cavaliet
parents:
646
diff
changeset
|
323 |
content_form.fields["media_obj"].queryset = Media.objects.filter(id__in=Content.safe_objects.values_list('media_obj', flat=True)) |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
324 |
|
|
791
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
325 |
if form_status=='saved' or form_status=='deleted': |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
326 |
return redirect("root-view") |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
327 |
else: |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
328 |
return render_to_response('ldt/ldt_utils/create_content.html', {'content_form': content_form, 'media_form': media_form, 'form_status': form_status, 'create_content_': create_content_action, |
| 325 | 329 |
'elem_list': get_userlist(request.user), 'member_list': member_list, 'admin_list': admin_list, 'iri_id': iri_id, 'session_key':session_key, |
| 734 | 330 |
'cookie_name':cookie_name, 'img_container': img_container, 'profile_picture_form': picture_form, |
331 |
'current_front_project':current_front_project}, context_instance=RequestContext(request)) |
|
|
791
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
332 |
#else : |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
333 |
# |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
334 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
335 |
@login_required |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
336 |
def prepare_delete_content(request, iri_id=None): |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
337 |
errors = [] |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
338 |
titles = [] |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
339 |
if not iri_id: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
340 |
iri_id = request.REQUEST.get("iri_id", None) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
341 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
342 |
if iri_id: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
343 |
for content in Content.safe_objects.filter(iri_id=iri_id): |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
344 |
titles.append(unicode(content.title)) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
345 |
projects = content.project_set.all() |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
346 |
projects_nb = len(projects) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
347 |
if projects_nb > 0: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
348 |
project_titles = map(lambda p: unicode(p.title), projects) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
349 |
errors.append(ungettext("Content '%(title)s' is referenced by this project : %(project_titles)s. Please delete it beforehand.", "Content '%(title)s' is referenced by %(count)d projects: %(project_titles)s. Please delete them beforehand.", projects_nb) % {'title':unicode(content.title), 'count':projects_nb, 'project_titles': ",".join(project_titles)}) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
350 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
351 |
return errors, titles |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
352 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
353 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
354 |
@login_required |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
355 |
def delete_content(request, iri_id=None): |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
356 |
if not iri_id: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
357 |
iri_id = request.REQUEST.get("iri_id", None) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
358 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
359 |
if iri_id: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
360 |
Content.safe_objects.get(iri_id=iri_id).delete() |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
361 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
362 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
363 |
def upload(request): |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
364 |
if request.method == 'POST': |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
365 |
for field_name in request.FILES: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
366 |
# We get the file name |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
367 |
source_file = request.FILES[field_name] |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
368 |
source_filename = source_file.name |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
369 |
# We sanitize the file name : no space, only lower case. |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
370 |
source_filename = ldt_utils_path.sanitize_filename(source_filename) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
371 |
# We create the session temp folder if necessary |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
372 |
if not os.path.exists(os.path.join(settings.STREAM_PATH, "tmp/" + request.COOKIES[settings.SESSION_COOKIE_NAME])): |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
373 |
os.makedirs(os.path.join(settings.STREAM_PATH, "tmp/" + request.COOKIES[settings.SESSION_COOKIE_NAME])) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
374 |
destination_filepath = os.path.join(settings.STREAM_PATH, "tmp/" + request.COOKIES[settings.SESSION_COOKIE_NAME] + "/", source_filename) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
375 |
# We delete the existing file if necessary |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
376 |
if os.path.exists(destination_filepath): |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
377 |
os.remove(destination_filepath) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
378 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
379 |
destination_file = open(destination_filepath, "wb") |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
380 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
381 |
for chunk in source_file.chunks(): |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
382 |
destination_file.write(chunk) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
383 |
destination_file.close() |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
384 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
385 |
# indicate that everything is OK for SWFUpload |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
386 |
return HttpResponse("ok", mimetype="text/plain") |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
387 |
else: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
388 |
return HttpResponse("notok", mimetype="text/plain") |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
389 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
390 |
def remove_temp_file(request): |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
391 |
# The filename arrives with a GET var. |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
392 |
file_path = os.path.join(settings.STREAM_PATH, "tmp/" + request.COOKIES[settings.SESSION_COOKIE_NAME] + "/", ldt_utils_path.sanitize_filename(request.GET["filename"])) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
393 |
if os.path.exists(file_path): |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
394 |
os.remove(file_path) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
395 |
return HttpResponse("remove ok", mimetype="text/plain") |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
396 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
397 |
def get_duration(request): |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
398 |
try: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
399 |
# The filename arrives with a GET var. |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
400 |
file_path = os.path.join(settings.STREAM_PATH, "tmp/" + request.COOKIES[settings.SESSION_COOKIE_NAME] + "/", ldt_utils_path.sanitize_filename(request.GET["filename"])) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
401 |
if hasattr(settings, 'FFMPEG_PATH') and os.path.exists(file_path): |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
402 |
output = str(subprocess.Popen([settings.FFMPEG_PATH, "-i", file_path], stderr=subprocess.PIPE).communicate()[1]) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
403 |
m = re.search("Duration:\s*?([\d.:]+)", output, re.M) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
404 |
dur_arr = m.group(1).split(":") |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
405 |
td = datetime.timedelta(hours=int(dur_arr[0]), minutes=int(dur_arr[1]), seconds=float(dur_arr[2])) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
406 |
str_duration = str((td.microseconds + (td.seconds + td.days * 24 * 3600) * 10 ** 6) / 10 ** 3) |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
407 |
return HttpResponse(str_duration, mimetype="text/plain") |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
408 |
else: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
409 |
return HttpResponse("", mimetype="text/plain") |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
410 |
except Exception as inst: |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
411 |
return HttpResponse(str(inst), mimetype="text/plain") |
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
412 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
413 |
|
|
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
414 |
@login_required |
|
786
623bc24bee49
change filter to filter_c to avoid name collision with the built-in filter fuction
ymh <ymh.work@gmail.com>
parents:
785
diff
changeset
|
415 |
def contents_filter(request, filter_c): |
|
623bc24bee49
change filter to filter_c to avoid name collision with the built-in filter fuction
ymh <ymh.work@gmail.com>
parents:
785
diff
changeset
|
416 |
if filter_c and len(filter_c) > 0 and filter_c[0] == '_': |
|
623bc24bee49
change filter to filter_c to avoid name collision with the built-in filter fuction
ymh <ymh.work@gmail.com>
parents:
785
diff
changeset
|
417 |
filter_c = filter_c[1:] |
|
646
97f5db87d71c
Enhance pagination with public project and quick search.
cavaliet
parents:
644
diff
changeset
|
418 |
|
|
97f5db87d71c
Enhance pagination with public project and quick search.
cavaliet
parents:
644
diff
changeset
|
419 |
num_page = 0 |
|
97f5db87d71c
Enhance pagination with public project and quick search.
cavaliet
parents:
644
diff
changeset
|
420 |
if request.GET.has_key('num_page'): |
|
97f5db87d71c
Enhance pagination with public project and quick search.
cavaliet
parents:
644
diff
changeset
|
421 |
num_page = int(request.GET["num_page"]) |
| 710 | 422 |
tag_filter = "" |
423 |
if request.GET.has_key('tag_filter'): |
|
424 |
tag_filter = request.GET["tag_filter"] |
|
|
646
97f5db87d71c
Enhance pagination with public project and quick search.
cavaliet
parents:
644
diff
changeset
|
425 |
|
|
786
623bc24bee49
change filter to filter_c to avoid name collision with the built-in filter fuction
ymh <ymh.work@gmail.com>
parents:
785
diff
changeset
|
426 |
# We paginate the content list, in case of filter_c or not |
|
623bc24bee49
change filter to filter_c to avoid name collision with the built-in filter fuction
ymh <ymh.work@gmail.com>
parents:
785
diff
changeset
|
427 |
if filter_c and not tag_filter : |
|
623bc24bee49
change filter to filter_c to avoid name collision with the built-in filter fuction
ymh <ymh.work@gmail.com>
parents:
785
diff
changeset
|
428 |
content_nb = Content.safe_objects.filter(title__icontains=filter_c).count() |
| 710 | 429 |
nb_ct_pages = int(math.ceil(content_nb / settings.LDT_MAX_CONTENTS_PER_PAGE)) + 1 |
|
786
623bc24bee49
change filter to filter_c to avoid name collision with the built-in filter fuction
ymh <ymh.work@gmail.com>
parents:
785
diff
changeset
|
430 |
content_list = Content.safe_objects.filter(title__icontains=filter_c)[(num_page*settings.LDT_MAX_CONTENTS_PER_PAGE):((num_page+1)*settings.LDT_MAX_CONTENTS_PER_PAGE)] #@UndefinedVariable |
|
623bc24bee49
change filter to filter_c to avoid name collision with the built-in filter fuction
ymh <ymh.work@gmail.com>
parents:
785
diff
changeset
|
431 |
elif filter_c and tag_filter : |
| 710 | 432 |
#TaggedItem.objects.get_by_model(Content.objects.all(), '"'+tag_filter+'"') |
|
786
623bc24bee49
change filter to filter_c to avoid name collision with the built-in filter fuction
ymh <ymh.work@gmail.com>
parents:
785
diff
changeset
|
433 |
content_nb = TaggedItem.objects.get_by_model(Content.safe_objects.filter(title__icontains=filter_c), '"'+tag_filter+'"').count() |
| 710 | 434 |
nb_ct_pages = int(math.ceil(content_nb / settings.LDT_MAX_CONTENTS_PER_PAGE)) + 1 |
|
786
623bc24bee49
change filter to filter_c to avoid name collision with the built-in filter fuction
ymh <ymh.work@gmail.com>
parents:
785
diff
changeset
|
435 |
content_list = TaggedItem.objects.get_by_model(Content.safe_objects.filter(title__icontains=filter_c), '"'+tag_filter+'"')[(num_page*settings.LDT_MAX_CONTENTS_PER_PAGE):((num_page+1)*settings.LDT_MAX_CONTENTS_PER_PAGE)] #@UndefinedVariable |
|
623bc24bee49
change filter to filter_c to avoid name collision with the built-in filter fuction
ymh <ymh.work@gmail.com>
parents:
785
diff
changeset
|
436 |
elif tag_filter and not filter_c: |
| 710 | 437 |
content_nb = TaggedItem.objects.get_by_model(Content.safe_objects.all(), '"'+tag_filter+'"').count() |
438 |
nb_ct_pages = int(math.ceil(content_nb / settings.LDT_MAX_CONTENTS_PER_PAGE)) +1 |
|
439 |
content_list = TaggedItem.objects.get_by_model(Content.safe_objects.all(), '"'+tag_filter+'"')[(num_page*settings.LDT_MAX_CONTENTS_PER_PAGE):((num_page+1)*settings.LDT_MAX_CONTENTS_PER_PAGE)] #@UndefinedVariable |
|
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
440 |
else: |
|
646
97f5db87d71c
Enhance pagination with public project and quick search.
cavaliet
parents:
644
diff
changeset
|
441 |
content_nb, nb_ct_pages, content_list = get_contents_page(num_page, request.user) |
|
97f5db87d71c
Enhance pagination with public project and quick search.
cavaliet
parents:
644
diff
changeset
|
442 |
#Change attributes with object permissions |
|
97f5db87d71c
Enhance pagination with public project and quick search.
cavaliet
parents:
644
diff
changeset
|
443 |
content_list = add_change_attr(request.user, content_list) |
| 710 | 444 |
# Get the all tags list |
445 |
tag_cloud = get_content_tags() |
|
|
644
94429061bbfa
First step of pagination for contents and projet in workspace home.
cavaliet
parents:
544
diff
changeset
|
446 |
|
|
94429061bbfa
First step of pagination for contents and projet in workspace home.
cavaliet
parents:
544
diff
changeset
|
447 |
is_gecko = ((request.META['HTTP_USER_AGENT'].lower().find("firefox")) > -1); |
|
315
877f89ec1efa
Split big views.py files into several views grouped by "make sense".
cavaliet
parents:
diff
changeset
|
448 |
return render_to_response("ldt/ldt_utils/partial/contentslist.html", |
|
644
94429061bbfa
First step of pagination for contents and projet in workspace home.
cavaliet
parents:
544
diff
changeset
|
449 |
{'contents': content_list, 'nb_ct_pages': nb_ct_pages, 'content_nb': content_nb, 'current_content_page':float(num_page), |
| 710 | 450 |
'tag_cloud': tag_cloud, 'current_content_tag':tag_filter, 'is_gecko': is_gecko |
|
644
94429061bbfa
First step of pagination for contents and projet in workspace home.
cavaliet
parents:
544
diff
changeset
|
451 |
}, |
|
94429061bbfa
First step of pagination for contents and projet in workspace home.
cavaliet
parents:
544
diff
changeset
|
452 |
context_instance=RequestContext(request)) |
|
94429061bbfa
First step of pagination for contents and projet in workspace home.
cavaliet
parents:
544
diff
changeset
|
453 |
|
|
94429061bbfa
First step of pagination for contents and projet in workspace home.
cavaliet
parents:
544
diff
changeset
|
454 |
|
|
94429061bbfa
First step of pagination for contents and projet in workspace home.
cavaliet
parents:
544
diff
changeset
|
455 |
def get_contents_page(num_page, user): |
|
94429061bbfa
First step of pagination for contents and projet in workspace home.
cavaliet
parents:
544
diff
changeset
|
456 |
content_nb = float(Content.safe_objects.count()) #@UndefinedVariable |
|
94429061bbfa
First step of pagination for contents and projet in workspace home.
cavaliet
parents:
544
diff
changeset
|
457 |
nb_ct_pages = int(math.ceil(content_nb / settings.LDT_MAX_CONTENTS_PER_PAGE)) |
|
94429061bbfa
First step of pagination for contents and projet in workspace home.
cavaliet
parents:
544
diff
changeset
|
458 |
content_list = add_change_attr(user, Content.safe_objects.all()[(num_page*settings.LDT_MAX_CONTENTS_PER_PAGE):((num_page+1)*settings.LDT_MAX_CONTENTS_PER_PAGE)]) #@UndefinedVariable |
|
94429061bbfa
First step of pagination for contents and projet in workspace home.
cavaliet
parents:
544
diff
changeset
|
459 |
return content_nb, nb_ct_pages, content_list |
| 710 | 460 |
|
461 |
||
462 |
def get_content_tags(limit=None, steps=10): |
|
463 |
if limit is None: |
|
464 |
return Tag.objects.cloud_for_model(Content, steps=steps) |
|
465 |
else : |
|
466 |
return Tag.objects.cloud_for_model(Content, steps=steps)[:limit] |
|
|
779
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
467 |
|
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
468 |
def get_json(src_video): |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
469 |
if 'youtube' in src_video: |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
470 |
url_data=urlparse.urlparse(src_video) |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
471 |
query=urlparse.parse_qs(url_data.query) |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
472 |
video_id=query['v'][0] |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
473 |
lien='http://gdata.youtube.com/feeds/api/videos/'+video_id+'?v=2&alt=jsonc' |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
474 |
elif 'vimeo' in src_video: |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
475 |
url_data=urlparse.urlparse(src_video) |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
476 |
url_path=url_data.path |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
477 |
video_id=(url_path.split('/'))[1] |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
478 |
lien='http://vimeo.com/api/v2/video/'+video_id+'.json' |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
479 |
elif 'dailymotion' in src_video: |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
480 |
url_data=urlparse.urlparse(src_video) |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
481 |
video_path=url_data.path |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
482 |
split_path=(video_path.split('/'))[2] |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
483 |
video_id=(split_path.split('_'))[0] |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
484 |
lien='https://api.dailymotion.com/video/'+video_id+'?fields=id,duration,title' |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
485 |
resp=requests.get(lien) |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
486 |
data=simplejson.loads(resp.content) |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
487 |
return data |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
488 |
|
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
489 |
def get_duration_json(src_video, data): |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
490 |
if 'youtube' in src_video: |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
491 |
duration=data['data']['duration']*1000 |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
492 |
elif 'vimeo' in src_video: |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
493 |
duration=data[0]['duration']*1000 |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
494 |
else: |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
495 |
duration=data['duration']*1000 |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
496 |
return duration |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
497 |
|
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
498 |
def get_title_json(src_video, data): |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
499 |
if 'youtube' in src_video: |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
500 |
title=data['data']['title'] |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
501 |
elif 'vimeo' in src_video: |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
502 |
title=data[0]['title'] |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
503 |
else: |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
504 |
title=data['title'] |
|
129b1c8b0088
Commit Louise :
Louise Grandjonc <louise.grandjonc@iri.centrepompidou.fr>
parents:
734
diff
changeset
|
505 |
return title |
|
791
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
506 |
|
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
507 |
def get_image_json(src_video, data): |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
508 |
if 'youtube' in src_video: |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
509 |
lien=data['data']['thumbnail']['sqDefault'] |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
510 |
filename=""+data['data']['id']+".jpg" |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
511 |
download_path=settings.MEDIA_ROOT+"thumbnails/contents/" |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
512 |
file_path = "%s\%s" % (download_path, filename) |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
513 |
video_thumbnail = file(file_path, "wb") |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
514 |
image_web=urllib2.urlopen(lien) |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
515 |
while True: |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
516 |
buf = image_web.read(65536) |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
517 |
if len(buf) == 0: |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
518 |
break |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
519 |
video_thumbnail.write(buf) |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
520 |
video_thumbnail.close() |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
521 |
image_web.close() |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
522 |
return file_path |
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
523 |
|
|
12ba862f33fa
Creation of a page instead of pop up for the content creation, update and suppression
grandjoncl
parents:
786
diff
changeset
|
524 |