| author | veltr |
| Mon, 30 Sep 2013 16:56:58 +0200 | |
| changeset 1234 | a4e00ed296f8 |
| parent 1193 | cd67b17d257d |
| child 1342 | 514145eb8c01 |
| permissions | -rw-r--r-- |
|
1190
129d45eec68c
Clean warning and errors for Django 1.5
ymh <ymh.work@gmail.com>
parents:
1027
diff
changeset
|
1 |
from StringIO import StringIO |
| 1193 | 2 |
from django.conf.urls import patterns, url |
| 0 | 3 |
from django.contrib import admin |
|
1190
129d45eec68c
Clean warning and errors for Django 1.5
ymh <ymh.work@gmail.com>
parents:
1027
diff
changeset
|
4 |
from django.core.management import call_command |
|
129d45eec68c
Clean warning and errors for Django 1.5
ymh <ymh.work@gmail.com>
parents:
1027
diff
changeset
|
5 |
from django.http import HttpResponse |
| 0 | 6 |
from django.shortcuts import render_to_response |
7 |
from django.template import RequestContext |
|
|
1190
129d45eec68c
Clean warning and errors for Django 1.5
ymh <ymh.work@gmail.com>
parents:
1027
diff
changeset
|
8 |
from guardian.admin import GuardedModelAdmin |
| 77 | 9 |
from ldt.ldt_utils.contentindexer import ContentIndexer, ProjectIndexer |
| 63 | 10 |
from ldt.ldt_utils.fileimport import FileImport, FileImportError |
|
340
5f919a978f50
Stats for annotations volume can be computed using ./manage.py statannotation [-c content_id] or in the admin pages of module ldt_utils.
verrierj
parents:
249
diff
changeset
|
11 |
from ldt.ldt_utils.forms import LdtImportForm, ReindexForm, StatAnnotationForm |
|
467
a1e9f5e91791
Removed object AnnotationStat + stats are computed when projects are published/unpublished
verrierj
parents:
393
diff
changeset
|
12 |
from ldt.ldt_utils.models import Content, Project, Media, Author |
| 534 | 13 |
from ldt.ldt_utils.stat import update_stat_content |
| 0 | 14 |
|
|
393
fa07a599883c
GroupProfile and AnnotationStat are editable in admin pages
verrierj
parents:
343
diff
changeset
|
15 |
|
|
230
39d97d561c60
Add admin panel to manage permissions for Content and Project
verrierj
parents:
167
diff
changeset
|
16 |
class ProjectAdmin(GuardedModelAdmin): |
|
467
a1e9f5e91791
Removed object AnnotationStat + stats are computed when projects are published/unpublished
verrierj
parents:
393
diff
changeset
|
17 |
pass |
| 0 | 18 |
|
|
249
5c5fab6d8ae8
Add admin permission panel to Group, Media, Author
verrierj
parents:
230
diff
changeset
|
19 |
class AuthorAdmin(GuardedModelAdmin): |
|
5c5fab6d8ae8
Add admin permission panel to Group, Media, Author
verrierj
parents:
230
diff
changeset
|
20 |
pass |
|
5c5fab6d8ae8
Add admin permission panel to Group, Media, Author
verrierj
parents:
230
diff
changeset
|
21 |
|
|
5c5fab6d8ae8
Add admin permission panel to Group, Media, Author
verrierj
parents:
230
diff
changeset
|
22 |
class MediaAdmin(GuardedModelAdmin): |
| 731 | 23 |
readonly_fields = ['src_hash'] |
|
230
39d97d561c60
Add admin panel to manage permissions for Content and Project
verrierj
parents:
167
diff
changeset
|
24 |
|
|
39d97d561c60
Add admin panel to manage permissions for Content and Project
verrierj
parents:
167
diff
changeset
|
25 |
class ContentAdmin(GuardedModelAdmin): |
| 0 | 26 |
|
27 |
def import_file(self, request): |
|
|
13
97ab7b3191cf
add api to update project, uses psiton
ymh <ymh.work@gmail.com>
parents:
0
diff
changeset
|
28 |
if request.method == 'POST': |
| 0 | 29 |
form = LdtImportForm(request.POST, request.FILES) |
30 |
if form.is_valid(): |
|
|
13
97ab7b3191cf
add api to update project, uses psiton
ymh <ymh.work@gmail.com>
parents:
0
diff
changeset
|
31 |
filetoprocess = form.cleaned_data['importFile'] |
| 0 | 32 |
flatten = form.cleaned_data['flatten'] |
33 |
videoPath = form.cleaned_data['videoPath'] |
|
34 |
# fi = None |
|
35 |
fi = FileImport(filetoprocess, videoPath, flatten) |
|
36 |
try: |
|
|
167
fe00e7302efe
Change class and functions names to follow PEP8 formatting standards
verrierj
parents:
142
diff
changeset
|
37 |
fi.process_file() |
| 0 | 38 |
args = {'message': "File imported"} |
39 |
except FileImportError: |
|
40 |
non_field_errors = form.non_field_errors() |
|
41 |
non_field_errors.append("Error when importing : unknown file type") |
|
42 |
form._errors["__all__"] = non_field_errors |
|
43 |
args = {'message': "Can not import file, unknown file type", 'form': form} |
|
44 |
||
45 |
else: |
|
46 |
non_field_errors = form.non_field_errors() |
|
47 |
non_field_errors.append("Error when importing : invalid form") |
|
48 |
form._errors["__all__"] = non_field_errors |
|
49 |
args = {'message': "Error when importing : invalid form", 'form': form} |
|
50 |
else: |
|
51 |
form = LdtImportForm() |
|
52 |
args = {'form': form, 'current_app': self.admin_site.name, 'current_action' : 'import_file'} |
|
53 |
return render_to_response('admin/ldt_utils/content/upload_form.html', args, context_instance=RequestContext(request)) |
|
54 |
||
55 |
def reindex(self, request): |
|
56 |
message = None |
|
57 |
if request.method == "POST": |
|
58 |
form = ReindexForm(request.POST) |
|
59 |
if form.is_valid(): |
|
|
718
5e27a39d3742
replace lucene by haystack, remove references to lucene
ymh <ymh.work@gmail.com>
parents:
534
diff
changeset
|
60 |
contentList = form.cleaned_data["contents"] |
|
5e27a39d3742
replace lucene by haystack, remove references to lucene
ymh <ymh.work@gmail.com>
parents:
534
diff
changeset
|
61 |
indexer = ContentIndexer(contentList) |
|
5e27a39d3742
replace lucene by haystack, remove references to lucene
ymh <ymh.work@gmail.com>
parents:
534
diff
changeset
|
62 |
indexer.index_all() |
|
5e27a39d3742
replace lucene by haystack, remove references to lucene
ymh <ymh.work@gmail.com>
parents:
534
diff
changeset
|
63 |
|
|
5e27a39d3742
replace lucene by haystack, remove references to lucene
ymh <ymh.work@gmail.com>
parents:
534
diff
changeset
|
64 |
index_projects = form.cleaned_data["index_projects"] |
|
5e27a39d3742
replace lucene by haystack, remove references to lucene
ymh <ymh.work@gmail.com>
parents:
534
diff
changeset
|
65 |
if index_projects: |
|
5e27a39d3742
replace lucene by haystack, remove references to lucene
ymh <ymh.work@gmail.com>
parents:
534
diff
changeset
|
66 |
projectList = Project.objects.filter(contents__in=contentList, state=2).distinct() #filter(contents__in=contentList) @UndefinedVariable |
|
5e27a39d3742
replace lucene by haystack, remove references to lucene
ymh <ymh.work@gmail.com>
parents:
534
diff
changeset
|
67 |
indexer = ProjectIndexer(projectList) |
| 77 | 68 |
indexer.index_all() |
| 0 | 69 |
message = "Indexation ok : " + repr(form.cleaned_data["contents"]) |
70 |
form = ReindexForm() |
|
71 |
# except Exception, inst: |
|
72 |
# non_field_errors = form.non_field_errors() |
|
73 |
# non_field_errors.append("Error when reindexing : " + cgi.escape(repr(inst))) |
|
74 |
# form._errors["__all__"] = non_field_errors |
|
75 |
#message = "ERROR : " + repr(non_field_errors) |
|
76 |
else: |
|
77 |
form = ReindexForm() |
|
78 |
||
79 |
return render_to_response('admin/ldt_utils/content/reindex_form.html', {'form': form, 'message':message, 'current_app': self.admin_site.name, 'current_action' : 'reindex' }, context_instance=RequestContext(request)) |
|
80 |
||
|
340
5f919a978f50
Stats for annotations volume can be computed using ./manage.py statannotation [-c content_id] or in the admin pages of module ldt_utils.
verrierj
parents:
249
diff
changeset
|
81 |
def stats_annotations(self, request): |
|
5f919a978f50
Stats for annotations volume can be computed using ./manage.py statannotation [-c content_id] or in the admin pages of module ldt_utils.
verrierj
parents:
249
diff
changeset
|
82 |
|
|
5f919a978f50
Stats for annotations volume can be computed using ./manage.py statannotation [-c content_id] or in the admin pages of module ldt_utils.
verrierj
parents:
249
diff
changeset
|
83 |
message = None |
|
5f919a978f50
Stats for annotations volume can be computed using ./manage.py statannotation [-c content_id] or in the admin pages of module ldt_utils.
verrierj
parents:
249
diff
changeset
|
84 |
if request.method == "POST": |
|
343
1b9b509013a7
Stats are recomputed without parsing extra xml file when projects are saved from ligne de temps.
verrierj
parents:
340
diff
changeset
|
85 |
form = StatAnnotationForm(request.POST) |
|
340
5f919a978f50
Stats for annotations volume can be computed using ./manage.py statannotation [-c content_id] or in the admin pages of module ldt_utils.
verrierj
parents:
249
diff
changeset
|
86 |
|
|
343
1b9b509013a7
Stats are recomputed without parsing extra xml file when projects are saved from ligne de temps.
verrierj
parents:
340
diff
changeset
|
87 |
if form.is_valid(): |
|
340
5f919a978f50
Stats for annotations volume can be computed using ./manage.py statannotation [-c content_id] or in the admin pages of module ldt_utils.
verrierj
parents:
249
diff
changeset
|
88 |
|
|
343
1b9b509013a7
Stats are recomputed without parsing extra xml file when projects are saved from ligne de temps.
verrierj
parents:
340
diff
changeset
|
89 |
if form.cleaned_data['choose_all']: |
| 534 | 90 |
contents = Content.objects.all() |
|
340
5f919a978f50
Stats for annotations volume can be computed using ./manage.py statannotation [-c content_id] or in the admin pages of module ldt_utils.
verrierj
parents:
249
diff
changeset
|
91 |
else: |
| 534 | 92 |
contents = form.cleaned_data['contents'] |
|
340
5f919a978f50
Stats for annotations volume can be computed using ./manage.py statannotation [-c content_id] or in the admin pages of module ldt_utils.
verrierj
parents:
249
diff
changeset
|
93 |
|
| 534 | 94 |
for content in contents: |
95 |
update_stat_content(content) |
|
96 |
message = "Stats computed for :" + repr(contents) |
|
|
340
5f919a978f50
Stats for annotations volume can be computed using ./manage.py statannotation [-c content_id] or in the admin pages of module ldt_utils.
verrierj
parents:
249
diff
changeset
|
97 |
else: |
|
343
1b9b509013a7
Stats are recomputed without parsing extra xml file when projects are saved from ligne de temps.
verrierj
parents:
340
diff
changeset
|
98 |
form = StatAnnotationForm() |
|
340
5f919a978f50
Stats for annotations volume can be computed using ./manage.py statannotation [-c content_id] or in the admin pages of module ldt_utils.
verrierj
parents:
249
diff
changeset
|
99 |
|
|
343
1b9b509013a7
Stats are recomputed without parsing extra xml file when projects are saved from ligne de temps.
verrierj
parents:
340
diff
changeset
|
100 |
return render_to_response('admin/ldt_utils/content/stats_form.html', {'form': form, 'message':message, 'current_app': self.admin_site.name, 'current_action' : 'stats' }, context_instance=RequestContext(request)) |
| 1027 | 101 |
|
102 |
||
103 |
def dumpdata(self, request): |
|
104 |
# do we dump the datas ? |
|
105 |
dump_str = request.REQUEST.get("dump") |
|
106 |
app_str = request.REQUEST.get("app", "") |
|
107 |
dump_bool = False |
|
108 |
if dump_str: |
|
109 |
dump_bool = {'true': True, 'false': False, "0": False, "1": True}.get(dump_str.lower()) |
|
110 |
if dump_bool: |
|
111 |
content = StringIO() |
|
112 |
if app_str=="": |
|
113 |
call_command("dumpdata", indent=1, stdout=content) |
|
114 |
else: |
|
115 |
call_command("dumpdata", app_str, indent=1, stdout=content) |
|
116 |
content.seek(0) |
|
117 |
out = content.getvalue() |
|
118 |
content.close() |
|
119 |
res = HttpResponse(out, mimetype='application/json') |
|
120 |
res["Content-Disposition"] = "attachment; filename=dumpdata_ldt.json" |
|
121 |
return res |
|
122 |
return render_to_response('admin/ldt_utils/content/dumpdata.html', {}, context_instance=RequestContext(request)) |
|
123 |
||
|
340
5f919a978f50
Stats for annotations volume can be computed using ./manage.py statannotation [-c content_id] or in the admin pages of module ldt_utils.
verrierj
parents:
249
diff
changeset
|
124 |
|
| 0 | 125 |
def get_urls(self): |
126 |
urls = super(ContentAdmin, self).get_urls() |
|
127 |
content_urls = patterns('', |
|
128 |
url(r'^reindex/$', self.admin_site.admin_view(self.reindex), name="ldt_content_reindex"), |
|
|
340
5f919a978f50
Stats for annotations volume can be computed using ./manage.py statannotation [-c content_id] or in the admin pages of module ldt_utils.
verrierj
parents:
249
diff
changeset
|
129 |
url(r'^import/$', self.admin_site.admin_view(self.import_file), name="ldt_content_import_file"), |
| 1027 | 130 |
url(r'^stats/$', self.admin_site.admin_view(self.stats_annotations), name="ldt_project_compute_stats"), |
131 |
url(r'^dumpdata/$', self.admin_site.admin_view(self.dumpdata), name="ldt_admin_dump_data"), |
|
| 0 | 132 |
) |
133 |
return content_urls + urls |
|
134 |
||
135 |
||
|
249
5c5fab6d8ae8
Add admin permission panel to Group, Media, Author
verrierj
parents:
230
diff
changeset
|
136 |
admin.site.register(Project, ProjectAdmin) |
| 0 | 137 |
admin.site.register(Content, ContentAdmin) |
|
249
5c5fab6d8ae8
Add admin permission panel to Group, Media, Author
verrierj
parents:
230
diff
changeset
|
138 |
admin.site.register(Media, MediaAdmin) |
|
5c5fab6d8ae8
Add admin permission panel to Group, Media, Author
verrierj
parents:
230
diff
changeset
|
139 |
admin.site.register(Author, AuthorAdmin) |