forked from 0x2620/pandora
admin
This commit is contained in:
parent
c1cd54023a
commit
f833109c02
7 changed files with 107 additions and 49 deletions
|
@ -1,29 +0,0 @@
|
||||||
# -*- coding: utf-8 -*-
|
|
||||||
# vi:si:et:sw=4:sts=4:ts=4
|
|
||||||
|
|
||||||
from django.contrib import admin
|
|
||||||
|
|
||||||
#from forms import FileAdminForm, ItemAdminForm, ArchiveFileAdminForm
|
|
||||||
import models
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
'''
|
|
||||||
#class ItemImdbAdmin(admin.ModelAdmin):
|
|
||||||
# search_fields = ['imdbId', 'title']
|
|
||||||
#admin.site.register(models.ItemImdb, ItemImdbAdmin)
|
|
||||||
class ItemImdbInline(admin.StackedInline):
|
|
||||||
model = models.ItemImdb
|
|
||||||
|
|
||||||
class ItemOxdbInline(admin.StackedInline):
|
|
||||||
model = models.ItemOxdb
|
|
||||||
'''
|
|
||||||
|
|
||||||
class ItemAdmin(admin.ModelAdmin):
|
|
||||||
search_fields = ['itemId', 'imdb__title', 'oxdb__title']
|
|
||||||
#form = ItemAdminForm
|
|
||||||
#inlines = [ItemImdbInline, ItemOxdbInline]
|
|
||||||
|
|
||||||
admin.site.register(models.Item, ItemAdmin)
|
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,6 @@ from django.contrib import admin
|
||||||
|
|
||||||
import models
|
import models
|
||||||
|
|
||||||
|
|
||||||
class PageAdmin(admin.ModelAdmin):
|
class PageAdmin(admin.ModelAdmin):
|
||||||
search_fields = ['name', 'body']
|
search_fields = ['name', 'body']
|
||||||
|
|
||||||
|
@ -16,3 +15,4 @@ class SiteSettingsAdmin(admin.ModelAdmin):
|
||||||
search_fields = ['key', 'value']
|
search_fields = ['key', 'value']
|
||||||
|
|
||||||
admin.site.register(models.SiteSettings, SiteSettingsAdmin)
|
admin.site.register(models.SiteSettings, SiteSettingsAdmin)
|
||||||
|
|
||||||
|
|
26
pandora/item/admin.py
Normal file
26
pandora/item/admin.py
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# vi:si:et:sw=4:sts=4:ts=4
|
||||||
|
|
||||||
|
from django.contrib import admin
|
||||||
|
|
||||||
|
import models
|
||||||
|
|
||||||
|
|
||||||
|
class BinAdmin(admin.ModelAdmin):
|
||||||
|
search_fields = ['name', 'title']
|
||||||
|
admin.site.register(models.Bin, BinAdmin)
|
||||||
|
|
||||||
|
class PropertyAdmin(admin.ModelAdmin):
|
||||||
|
search_fields = ['name', 'title']
|
||||||
|
admin.site.register(models.Property, PropertyAdmin)
|
||||||
|
|
||||||
|
|
||||||
|
class PlaceAdmin(admin.ModelAdmin):
|
||||||
|
search_fields = ['name']
|
||||||
|
admin.site.register(models.Place, PlaceAdmin)
|
||||||
|
|
||||||
|
|
||||||
|
class EventAdmin(admin.ModelAdmin):
|
||||||
|
search_fields = ['name']
|
||||||
|
admin.site.register(models.Event, EventAdmin)
|
||||||
|
|
|
@ -31,6 +31,9 @@ from archive import extract
|
||||||
|
|
||||||
|
|
||||||
class Bin(models.Model):
|
class Bin(models.Model):
|
||||||
|
class Meta:
|
||||||
|
ordering = ('position', )
|
||||||
|
|
||||||
name = models.CharField(null=True, max_length=255, unique=True)
|
name = models.CharField(null=True, max_length=255, unique=True)
|
||||||
title = models.CharField(null=True, max_length=255)
|
title = models.CharField(null=True, max_length=255)
|
||||||
#text, string, string from list(fixme), event, place, person
|
#text, string, string from list(fixme), event, place, person
|
||||||
|
@ -246,7 +249,10 @@ def getItem(info):
|
||||||
item.save()
|
item.save()
|
||||||
return item
|
return item
|
||||||
|
|
||||||
class ItemProperty(models.Model):
|
class Property(models.Model):
|
||||||
|
class Meta:
|
||||||
|
ordering = ('position', )
|
||||||
|
|
||||||
name = models.CharField(null=True, max_length=255, unique=True)
|
name = models.CharField(null=True, max_length=255, unique=True)
|
||||||
title = models.CharField(null=True, max_length=255)
|
title = models.CharField(null=True, max_length=255)
|
||||||
#text, string, string from list(fixme), event, place, person
|
#text, string, string from list(fixme), event, place, person
|
||||||
|
@ -260,6 +266,11 @@ class ItemProperty(models.Model):
|
||||||
totals = models.BooleanField(default=False)
|
totals = models.BooleanField(default=False)
|
||||||
admin = models.BooleanField(default=False)
|
admin = models.BooleanField(default=False)
|
||||||
|
|
||||||
|
def __unicode__(self):
|
||||||
|
if self.title:
|
||||||
|
return self.title
|
||||||
|
return self.name
|
||||||
|
|
||||||
def json(self):
|
def json(self):
|
||||||
j = {}
|
j = {}
|
||||||
for key in ('type', 'sort', 'title', 'array', 'totals', 'admin'):
|
for key in ('type', 'sort', 'title', 'array', 'totals', 'admin'):
|
||||||
|
@ -1016,10 +1027,13 @@ class ReviewWhitelist(models.Model):
|
||||||
url = models.CharField(max_length=255, unique=True)
|
url = models.CharField(max_length=255, unique=True)
|
||||||
|
|
||||||
class List(models.Model):
|
class List(models.Model):
|
||||||
|
class Meta:
|
||||||
|
unique_together = ("user", "name")
|
||||||
|
|
||||||
created = models.DateTimeField(auto_now_add=True)
|
created = models.DateTimeField(auto_now_add=True)
|
||||||
modified = models.DateTimeField(auto_now=True)
|
modified = models.DateTimeField(auto_now=True)
|
||||||
user = models.ForeignKey(User)
|
user = models.ForeignKey(User)
|
||||||
name = models.CharField(max_length=255, unique=True)
|
name = models.CharField(max_length=255)
|
||||||
public = models.BooleanField(default=False)
|
public = models.BooleanField(default=False)
|
||||||
items = models.ManyToManyField(Item, related_name='lists', through='ListItem')
|
items = models.ManyToManyField(Item, related_name='lists', through='ListItem')
|
||||||
|
|
||||||
|
|
|
@ -36,6 +36,7 @@ from user.models import getUserJSON
|
||||||
from archive.models import File
|
from archive.models import File
|
||||||
from archive import extract
|
from archive import extract
|
||||||
|
|
||||||
|
|
||||||
def _order_query(qs, sort, prefix='sort__'):
|
def _order_query(qs, sort, prefix='sort__'):
|
||||||
order_by = []
|
order_by = []
|
||||||
if len(sort) == 1:
|
if len(sort) == 1:
|
||||||
|
@ -259,7 +260,7 @@ def api_removeItem(request):
|
||||||
if item.editable(request.user):
|
if item.editable(request.user):
|
||||||
response = json_response(status=501, text='not implemented')
|
response = json_response(status=501, text='not implemented')
|
||||||
else:
|
else:
|
||||||
response = json_response(status=403, text='permissino denied')
|
response = json_response(status=403, text='permission denied')
|
||||||
return render_to_json_response(response)
|
return render_to_json_response(response)
|
||||||
|
|
||||||
@login_required_json
|
@login_required_json
|
||||||
|
@ -311,10 +312,26 @@ def api_editLayer(request):
|
||||||
def api_addListItem(request):
|
def api_addListItem(request):
|
||||||
'''
|
'''
|
||||||
param data
|
param data
|
||||||
{key: value}
|
{list: listId,
|
||||||
|
item: itemId,
|
||||||
|
quert: ...
|
||||||
|
}
|
||||||
return {'status': {'code': int, 'text': string},
|
return {'status': {'code': int, 'text': string},
|
||||||
'data': {}}
|
'data': {}}
|
||||||
'''
|
'''
|
||||||
|
data = json.loads(request.POST['data'])
|
||||||
|
list = get_object_or_404_json(models.List, pk=data['list'])
|
||||||
|
if 'item' in data:
|
||||||
|
item = get_object_or_404_json(models.Item, pk=data['item'])
|
||||||
|
if list.editable(request.user):
|
||||||
|
list.add(item)
|
||||||
|
response = json_response(status=200, text='item removed')
|
||||||
|
else:
|
||||||
|
response = json_response(status=403, text='not allowed')
|
||||||
|
elif 'query' in data:
|
||||||
|
response = json_response(status=501, text='not implemented')
|
||||||
|
|
||||||
|
else:
|
||||||
response = json_response(status=501, text='not implemented')
|
response = json_response(status=501, text='not implemented')
|
||||||
return render_to_json_response(response)
|
return render_to_json_response(response)
|
||||||
|
|
||||||
|
@ -322,10 +339,26 @@ def api_addListItem(request):
|
||||||
def api_removeListItem(request):
|
def api_removeListItem(request):
|
||||||
'''
|
'''
|
||||||
param data
|
param data
|
||||||
{key: value}
|
{list: listId,
|
||||||
|
item: itemId,
|
||||||
|
quert: ...
|
||||||
|
}
|
||||||
return {'status': {'code': int, 'text': string},
|
return {'status': {'code': int, 'text': string},
|
||||||
'data': {}}
|
'data': {}}
|
||||||
'''
|
'''
|
||||||
|
data = json.loads(request.POST['data'])
|
||||||
|
list = get_object_or_404_json(models.List, pk=data['list'])
|
||||||
|
if 'item' in data:
|
||||||
|
item = get_object_or_404_json(models.Item, pk=data['item'])
|
||||||
|
if list.editable(request.user):
|
||||||
|
list.remove(item)
|
||||||
|
response = json_response(status=200, text='item removed')
|
||||||
|
else:
|
||||||
|
response = json_response(status=403, text='not allowed')
|
||||||
|
elif 'query' in data:
|
||||||
|
response = json_response(status=501, text='not implemented')
|
||||||
|
|
||||||
|
else:
|
||||||
response = json_response(status=501, text='not implemented')
|
response = json_response(status=501, text='not implemented')
|
||||||
return render_to_json_response(response)
|
return render_to_json_response(response)
|
||||||
|
|
||||||
|
@ -333,11 +366,17 @@ def api_removeListItem(request):
|
||||||
def api_addList(request):
|
def api_addList(request):
|
||||||
'''
|
'''
|
||||||
param data
|
param data
|
||||||
{key: value}
|
{name: value}
|
||||||
return {'status': {'code': int, 'text': string},
|
return {'status': {'code': int, 'text': string},
|
||||||
'data': {}}
|
'data': {}}
|
||||||
'''
|
'''
|
||||||
response = json_response(status=501, text='not implemented')
|
data = json.loads(request.POST['data'])
|
||||||
|
if models.List.filter(name=data['name'], user=request.user).count() == 0:
|
||||||
|
list = models.List(name = data['name'], user=request.user)
|
||||||
|
list.save()
|
||||||
|
response = json_response(status=200, text='created')
|
||||||
|
else:
|
||||||
|
response = json_response(status=403, text='list name exists')
|
||||||
return render_to_json_response(response)
|
return render_to_json_response(response)
|
||||||
|
|
||||||
@login_required_json
|
@login_required_json
|
||||||
|
@ -345,10 +384,18 @@ def api_editList(request):
|
||||||
'''
|
'''
|
||||||
param data
|
param data
|
||||||
{key: value}
|
{key: value}
|
||||||
|
keys: name, public
|
||||||
return {'status': {'code': int, 'text': string},
|
return {'status': {'code': int, 'text': string},
|
||||||
'data': {}}
|
'data': {}}
|
||||||
'''
|
'''
|
||||||
response = json_response(status=501, text='not implemented')
|
data = json.loads(request.POST['data'])
|
||||||
|
list = get_object_or_404_json(models.List, pk=data['list'])
|
||||||
|
if list.editable(request.user):
|
||||||
|
for key in data:
|
||||||
|
if key in ('name', 'public'):
|
||||||
|
setattr(list, key, data['key'])
|
||||||
|
else:
|
||||||
|
response = json_response(status=403, text='not allowed')
|
||||||
return render_to_json_response(response)
|
return render_to_json_response(response)
|
||||||
|
|
||||||
def api_removeList(request):
|
def api_removeList(request):
|
||||||
|
@ -358,7 +405,12 @@ def api_removeList(request):
|
||||||
return {'status': {'code': int, 'text': string},
|
return {'status': {'code': int, 'text': string},
|
||||||
'data': {}}
|
'data': {}}
|
||||||
'''
|
'''
|
||||||
response = json_response(status=501, text='not implemented')
|
data = json.loads(request.POST['data'])
|
||||||
|
list = get_object_or_404_json(models.List, pk=data['list'])
|
||||||
|
if list.editable(request.user):
|
||||||
|
list.delete()
|
||||||
|
else:
|
||||||
|
response = json_response(status=403, text='not allowed')
|
||||||
return render_to_json_response(response)
|
return render_to_json_response(response)
|
||||||
|
|
||||||
'''
|
'''
|
||||||
|
|
|
@ -111,6 +111,7 @@ INSTALLED_APPS = (
|
||||||
'django.contrib.sites',
|
'django.contrib.sites',
|
||||||
'django.contrib.admin',
|
'django.contrib.admin',
|
||||||
'django.contrib.humanize',
|
'django.contrib.humanize',
|
||||||
|
|
||||||
'django_extensions',
|
'django_extensions',
|
||||||
'devserver',
|
'devserver',
|
||||||
'south',
|
'south',
|
||||||
|
|
|
@ -11,10 +11,12 @@ from django.conf import settings
|
||||||
from django.contrib import admin
|
from django.contrib import admin
|
||||||
admin.autodiscover()
|
admin.autodiscover()
|
||||||
|
|
||||||
|
|
||||||
def serve_static_file(path, location, content_type):
|
def serve_static_file(path, location, content_type):
|
||||||
return HttpFileResponse(location, content_type=content_type)
|
return HttpFileResponse(location, content_type=content_type)
|
||||||
|
|
||||||
urlpatterns = patterns('',
|
urlpatterns = patterns('',
|
||||||
|
(r'^admin/', include(admin.site.urls)),
|
||||||
(r'^ajax_filtered_fields/', include('ajax_filtered_fields.urls')),
|
(r'^ajax_filtered_fields/', include('ajax_filtered_fields.urls')),
|
||||||
(r'^api/upload/$', 'archive.views.firefogg_upload'),
|
(r'^api/upload/$', 'archive.views.firefogg_upload'),
|
||||||
(r'^site.json$', 'app.views.site_json'),
|
(r'^site.json$', 'app.views.site_json'),
|
||||||
|
@ -26,13 +28,6 @@ urlpatterns = patterns('',
|
||||||
(r'^r/(?P<key>.*)$', 'user.views.recover'),
|
(r'^r/(?P<key>.*)$', 'user.views.recover'),
|
||||||
(r'^api/$', include('api.urls')),
|
(r'^api/$', include('api.urls')),
|
||||||
(r'', include('item.urls')),
|
(r'', include('item.urls')),
|
||||||
|
|
||||||
# Uncomment the admin/doc line below and add 'django.contrib.admindocs'
|
|
||||||
# to INSTALLED_APPS to enable admin documentation:
|
|
||||||
# (r'^admin/doc/', include('django.contrib.admindocs.urls')),
|
|
||||||
|
|
||||||
# Uncomment the next line to enable the admin:
|
|
||||||
(r'^admin/(.*)', include(admin.site.urls)),
|
|
||||||
(r'^robots.txt$', serve_static_file, {'location': os.path.join(settings.STATIC_ROOT, 'robots.txt'), 'content_type': 'text/plain'}),
|
(r'^robots.txt$', serve_static_file, {'location': os.path.join(settings.STATIC_ROOT, 'robots.txt'), 'content_type': 'text/plain'}),
|
||||||
(r'^favicon.ico$', serve_static_file, {'location': os.path.join(settings.STATIC_ROOT, 'png/icon.16.png'), 'content_type': 'image/x-icon'}),
|
(r'^favicon.ico$', serve_static_file, {'location': os.path.join(settings.STATIC_ROOT, 'png/icon.16.png'), 'content_type': 'image/x-icon'}),
|
||||||
)
|
)
|
||||||
|
@ -47,4 +42,3 @@ if settings.DEBUG:
|
||||||
{'document_root': settings.TESTS_ROOT}),
|
{'document_root': settings.TESTS_ROOT}),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue