forked from 0x2620/pandora
subscription
This commit is contained in:
parent
d2b0c18001
commit
c577e6930b
7 changed files with 129 additions and 83 deletions
|
@ -7,7 +7,7 @@ from django.db.models import Q, Manager
|
||||||
import models
|
import models
|
||||||
|
|
||||||
|
|
||||||
def parseCondition(condition):
|
def parseCondition(condition, user):
|
||||||
'''
|
'''
|
||||||
condition: {
|
condition: {
|
||||||
value: "war"
|
value: "war"
|
||||||
|
@ -35,10 +35,9 @@ def parseCondition(condition):
|
||||||
exclude = False
|
exclude = False
|
||||||
if k == 'subscribed':
|
if k == 'subscribed':
|
||||||
print "FXIME, subscribed needs work"
|
print "FXIME, subscribed needs work"
|
||||||
k = 'public'
|
key = 'subscribed_users__username'
|
||||||
v = True
|
v = user.username
|
||||||
|
elif isinstance(v, bool): #featured and public flag
|
||||||
if isinstance(v, bool): #featured and public flag
|
|
||||||
key = k
|
key = k
|
||||||
else:
|
else:
|
||||||
if op == '=':
|
if op == '=':
|
||||||
|
@ -58,7 +57,7 @@ def parseCondition(condition):
|
||||||
q = Q(**{key: v})
|
q = Q(**{key: v})
|
||||||
return q
|
return q
|
||||||
|
|
||||||
def parseConditions(conditions, operator):
|
def parseConditions(conditions, operator, user):
|
||||||
'''
|
'''
|
||||||
conditions: [
|
conditions: [
|
||||||
{
|
{
|
||||||
|
@ -81,14 +80,14 @@ def parseConditions(conditions, operator):
|
||||||
for condition in conditions:
|
for condition in conditions:
|
||||||
if 'conditions' in condition:
|
if 'conditions' in condition:
|
||||||
q = parseConditions(condition['conditions'],
|
q = parseConditions(condition['conditions'],
|
||||||
condition.get('operator', '&'))
|
condition.get('operator', '&'), user)
|
||||||
if q:
|
if q:
|
||||||
conn.append(q)
|
conn.append(q)
|
||||||
pass
|
pass
|
||||||
else:
|
else:
|
||||||
if condition.get('value', '') != '' or \
|
if condition.get('value', '') != '' or \
|
||||||
condition.get('operator', '') == '=':
|
condition.get('operator', '') == '=':
|
||||||
conn.append(parseCondition(condition))
|
conn.append(parseCondition(condition, user))
|
||||||
if conn:
|
if conn:
|
||||||
q = conn[0]
|
q = conn[0]
|
||||||
for c in conn[1:]:
|
for c in conn[1:]:
|
||||||
|
@ -129,8 +128,9 @@ class ListManager(Manager):
|
||||||
|
|
||||||
#join query with operator
|
#join query with operator
|
||||||
qs = self.get_query_set()
|
qs = self.get_query_set()
|
||||||
conditions = parseConditions(data['query']['conditions'],
|
conditions = parseConditions(data['query'].get('conditions', []),
|
||||||
data['query'].get('operator', '&'))
|
data['query'].get('operator', '&'),
|
||||||
|
user)
|
||||||
if conditions:
|
if conditions:
|
||||||
qs = qs.filter(conditions)
|
qs = qs.filter(conditions)
|
||||||
|
|
||||||
|
|
|
@ -19,7 +19,7 @@ class List(models.Model):
|
||||||
|
|
||||||
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, related_name='lists')
|
||||||
name = models.CharField(max_length=255)
|
name = models.CharField(max_length=255)
|
||||||
status = models.CharField(max_length=20, default='private')
|
status = models.CharField(max_length=20, default='private')
|
||||||
_status = ['private', 'public', 'featured']
|
_status = ['private', 'public', 'featured']
|
||||||
|
@ -28,6 +28,8 @@ class List(models.Model):
|
||||||
items = models.ManyToManyField('item.Item', related_name='lists',
|
items = models.ManyToManyField('item.Item', related_name='lists',
|
||||||
through='ListItem')
|
through='ListItem')
|
||||||
|
|
||||||
|
subscribed_users = models.ManyToManyField(User, related_name='subscribed_lists')
|
||||||
|
|
||||||
objects = managers.ListManager()
|
objects = managers.ListManager()
|
||||||
|
|
||||||
def save(self, *args, **kwargs):
|
def save(self, *args, **kwargs):
|
||||||
|
@ -53,22 +55,29 @@ class List(models.Model):
|
||||||
def __unicode__(self):
|
def __unicode__(self):
|
||||||
return u'%s (%s)' % (self.name, self.user)
|
return u'%s (%s)' % (self.name, self.user)
|
||||||
|
|
||||||
|
def get_id(self):
|
||||||
|
return '%s:%s' % (self.user.username, self.name)
|
||||||
|
|
||||||
def editable(self, user):
|
def editable(self, user):
|
||||||
#FIXME: make permissions work
|
#FIXME: make permissions work
|
||||||
if self.user == user or user.has_perm('Ox.admin'):
|
if self.user == user or user.is_staff:
|
||||||
return True
|
return True
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def json(self, keys, user=None):
|
def json(self, keys=['id', 'name', 'user', 'query', 'status'], user=None):
|
||||||
response = {}
|
response = {}
|
||||||
for key in keys:
|
for key in keys:
|
||||||
if key == 'items':
|
if key == 'items':
|
||||||
response[key] = self.get_number_of_items(user)
|
response[key] = self.get_number_of_items(user)
|
||||||
|
elif key == 'id':
|
||||||
|
response[key] = self.get_id()
|
||||||
elif key == 'user':
|
elif key == 'user':
|
||||||
response[key] = self.user.username
|
response[key] = self.user.username
|
||||||
elif key == 'query':
|
elif key == 'query':
|
||||||
if not self.query.get('static', False):
|
if not self.query.get('static', False):
|
||||||
response[key] = self.query
|
response[key] = self.query
|
||||||
|
elif key == 'ui':
|
||||||
|
response[key] = site_conf['uiDefaults']['list']
|
||||||
else:
|
else:
|
||||||
response[key] = getattr(self, key)
|
response[key] = getattr(self, key)
|
||||||
return response
|
return response
|
||||||
|
@ -81,3 +90,4 @@ class ListItem(models.Model):
|
||||||
|
|
||||||
def __unicode__(self):
|
def __unicode__(self):
|
||||||
return u'%s in %s' % (self.item, self.list)
|
return u'%s in %s' % (self.item, self.list)
|
||||||
|
|
||||||
|
|
|
@ -160,7 +160,7 @@ def addList(request):
|
||||||
}
|
}
|
||||||
'''
|
'''
|
||||||
data = json.loads(request.POST['data'])
|
data = json.loads(request.POST['data'])
|
||||||
if models.List.filter(name=data['name'], user=request.user).count() == 0:
|
if models.List.objects.filter(name=data['name'], user=request.user).count() == 0:
|
||||||
list = models.List(name = data['name'], user=request.user)
|
list = models.List(name = data['name'], user=request.user)
|
||||||
list.save()
|
list.save()
|
||||||
response = json_response(status=200, text='created')
|
response = json_response(status=200, text='created')
|
||||||
|
@ -186,8 +186,10 @@ def editList(request):
|
||||||
}
|
}
|
||||||
'''
|
'''
|
||||||
data = json.loads(request.POST['data'])
|
data = json.loads(request.POST['data'])
|
||||||
list = get_object_or_404_json(models.List, pk=data['list'])
|
username, listname = data['id'].split(':')
|
||||||
|
list = get_object_or_404_json(models.List, user__username=username, name=listname)
|
||||||
if list.editable(request.user):
|
if list.editable(request.user):
|
||||||
|
response = json_response()
|
||||||
for key in data:
|
for key in data:
|
||||||
if key in ('name', 'status', 'query'):
|
if key in ('name', 'status', 'query'):
|
||||||
if key in data:
|
if key in data:
|
||||||
|
@ -200,7 +202,7 @@ def editList(request):
|
||||||
setattr(list, key, value)
|
setattr(list, key, value)
|
||||||
else:
|
else:
|
||||||
setattr(list, key, data[key])
|
setattr(list, key, data[key])
|
||||||
if user.has_perm('Ox.admin') and 'featured' in data:
|
if request.user.is_staff and 'featured' in data:
|
||||||
list.featured = data['featured']
|
list.featured = data['featured']
|
||||||
else:
|
else:
|
||||||
response = json_response(status=403, text='not allowed')
|
response = json_response(status=403, text='not allowed')
|
||||||
|
@ -223,7 +225,7 @@ def removeList(request):
|
||||||
'''
|
'''
|
||||||
data = json.loads(request.POST['data'])
|
data = json.loads(request.POST['data'])
|
||||||
user = request.user.username
|
user = request.user.username
|
||||||
if user.has_perm('Ox.admin') and 'user' in data:
|
if user.is_staff and 'user' in data:
|
||||||
user = data.get('user')
|
user = data.get('user')
|
||||||
list = get_object_or_404_json(models.List, name=data['name'], user__username=user)
|
list = get_object_or_404_json(models.List, name=data['name'], user__username=user)
|
||||||
if list.editable(request.user):
|
if list.editable(request.user):
|
||||||
|
@ -232,3 +234,49 @@ def removeList(request):
|
||||||
response = json_response(status=403, text='not allowed')
|
response = json_response(status=403, text='not allowed')
|
||||||
return render_to_json_response(response)
|
return render_to_json_response(response)
|
||||||
actions.register(removeList)
|
actions.register(removeList)
|
||||||
|
|
||||||
|
|
||||||
|
@login_required_json
|
||||||
|
def subscribeToList(request):
|
||||||
|
'''
|
||||||
|
param data {
|
||||||
|
id: listId,
|
||||||
|
user: username(only admins)
|
||||||
|
}
|
||||||
|
return {
|
||||||
|
status: {'code': int, 'text': string},
|
||||||
|
data: {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
data = json.loads(request.POST['data'])
|
||||||
|
username, listname = data['id'].split(':')
|
||||||
|
list = get_object_or_404_json(models.List, user__username=username, name=listname)
|
||||||
|
user = request.user
|
||||||
|
if list.subscribed_users.filter(username=user.username).count() == 0:
|
||||||
|
list.subscribed_users.add(user)
|
||||||
|
response = json_response()
|
||||||
|
return render_to_json_response(response)
|
||||||
|
actions.register(subscribeToList)
|
||||||
|
|
||||||
|
@login_required_json
|
||||||
|
def unsubscribeFromList(request):
|
||||||
|
'''
|
||||||
|
param data {
|
||||||
|
id: listId,
|
||||||
|
user: username(only admins)
|
||||||
|
}
|
||||||
|
return {
|
||||||
|
status: {'code': int, 'text': string},
|
||||||
|
data: {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
data = json.loads(request.POST['data'])
|
||||||
|
username, listname = data['id'].split(':')
|
||||||
|
list = get_object_or_404_json(models.List, user__username=username, name=listname)
|
||||||
|
user = request.user
|
||||||
|
list.subscribed_users.remove(user)
|
||||||
|
response = json_response()
|
||||||
|
return render_to_json_response(response)
|
||||||
|
actions.register(unsubscribeFromList)
|
||||||
|
|
|
@ -124,6 +124,16 @@
|
||||||
{"id": "size", "admin": true},
|
{"id": "size", "admin": true},
|
||||||
{"id": "pixels"}
|
{"id": "pixels"}
|
||||||
],
|
],
|
||||||
|
"uiDefaults": {
|
||||||
|
"list": {
|
||||||
|
"columns": ["id", "title", "director", "country", "year", "language", "runtime", "genre"],
|
||||||
|
"listView": "icons",
|
||||||
|
"selected": [],
|
||||||
|
"sort": [
|
||||||
|
{"key": "director", "operator": ""}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
"user": {
|
"user": {
|
||||||
"group": "guest",
|
"group": "guest",
|
||||||
"lists": {
|
"lists": {
|
||||||
|
@ -131,13 +141,14 @@
|
||||||
{"id": "all_movies", "title": "All Movies", "query": {}}
|
{"id": "all_movies", "title": "All Movies", "query": {}}
|
||||||
],
|
],
|
||||||
"my": [
|
"my": [
|
||||||
|
{"user": "foo", "name": "Favorites", "featured": false, "public": true},
|
||||||
{"id": "favorites", "title": "Favorites", "public": true, "items": []},
|
{"id": "favorites", "title": "Favorites", "public": true, "items": []},
|
||||||
{"id": "most_popular", "title": "Most Popular", "query": {}},
|
{"id": "most_popular", "title": "Most Popular", "query": {}},
|
||||||
{"id": "recently_viewed", "title": "Recently Viewed", "query": {}},
|
{"id": "recently_viewed", "title": "Recently Viewed", "query": {}},
|
||||||
{"id": "1960s", "title": "1960s", "query": {"conditions": [{"key": "year", "value": "196", "operator": "^"}], "operator": ""}}
|
{"id": "1960s", "title": "1960s", "query": {"conditions": [{"key": "year", "value": "196", "operator": "^"}], "operator": ""}}
|
||||||
],
|
],
|
||||||
"public": [
|
"public": [
|
||||||
{"id": "rlx_watchme", "title": "rlx: watchme", "public": true, "items": [0, 1, 2, 3, 4]}
|
{"id": "rlx:watchme", "title": "rlx: watchme", "public": true, "items": [0, 1, 2, 3, 4]}
|
||||||
],
|
],
|
||||||
"featured": [
|
"featured": [
|
||||||
{"id": "situationist_film", "title": "Situationist Film", "query": {}},
|
{"id": "situationist_film", "title": "Situationist Film", "query": {}},
|
||||||
|
@ -147,17 +158,26 @@
|
||||||
"preferences": {},
|
"preferences": {},
|
||||||
"ui": {
|
"ui": {
|
||||||
"annotationsSize": 256,
|
"annotationsSize": 256,
|
||||||
"columns": ["id", "title", "director", "country", "year", "language", "runtime", "genre"],
|
|
||||||
"findQuery": {"conditions": [], "operator": ""},
|
"findQuery": {"conditions": [], "operator": ""},
|
||||||
"groups": ["director", "country", "year", "language", "genre"],
|
"groups": ["director", "country", "year", "language", "genre"],
|
||||||
"groupsQuery": {"conditions": [], "operator": "|"},
|
"groupsQuery": {"conditions": [], "operator": "|"},
|
||||||
"groupsSize": 176,
|
"groupsSize": 176,
|
||||||
"item": "",
|
"item": "",
|
||||||
"itemView": "timeline",
|
"itemView": "timeline",
|
||||||
|
"list": "",
|
||||||
"listQuery": {"conditions": [], "operator": ""},
|
"listQuery": {"conditions": [], "operator": ""},
|
||||||
|
"lists": {
|
||||||
|
"": {
|
||||||
|
"columns": ["id", "title", "director", "country", "year", "language", "runtime", "genre"],
|
||||||
"listView": "icons",
|
"listView": "icons",
|
||||||
|
"selected": [],
|
||||||
|
"sort": [
|
||||||
|
{"key": "director", "operator": ""}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
"section": "items",
|
"section": "items",
|
||||||
"sections": ["history", "my", "public", "featured"],
|
"sections": ["my", "public", "featured"],
|
||||||
"showAnnotations": true,
|
"showAnnotations": true,
|
||||||
"showGroups": true,
|
"showGroups": true,
|
||||||
"showInfo": true,
|
"showInfo": true,
|
||||||
|
@ -165,9 +185,6 @@
|
||||||
"showSidebar": true,
|
"showSidebar": true,
|
||||||
"sidebarSize": 256,
|
"sidebarSize": 256,
|
||||||
"sitePage": "home",
|
"sitePage": "home",
|
||||||
"sort": [
|
|
||||||
{"key": "director", "operator": ""}
|
|
||||||
],
|
|
||||||
"theme": "classic"
|
"theme": "classic"
|
||||||
},
|
},
|
||||||
"username": ""
|
"username": ""
|
||||||
|
|
|
@ -24,7 +24,7 @@ class Timeline(models.Model):
|
||||||
|
|
||||||
def editable(self, user):
|
def editable(self, user):
|
||||||
#FIXME: make permissions work
|
#FIXME: make permissions work
|
||||||
if self.user == user or user.has_perm('Ox.admin'):
|
if self.user == user or user.is_staff:
|
||||||
return True
|
return True
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
|
|
@ -23,6 +23,26 @@ class UserProfile(models.Model):
|
||||||
ui = DictField(default={})
|
ui = DictField(default={})
|
||||||
preferences = DictField(default={})
|
preferences = DictField(default={})
|
||||||
|
|
||||||
|
def get_preferences(self):
|
||||||
|
prefs = self.preferences
|
||||||
|
prefs['email'] = self.user.email
|
||||||
|
return prefs
|
||||||
|
|
||||||
|
def get_ui(self):
|
||||||
|
ui = {}
|
||||||
|
ui.update(site_config['user']['ui'])
|
||||||
|
ui.update(self.ui)
|
||||||
|
if not 'lists' in ui:
|
||||||
|
ui['lists'] = {}
|
||||||
|
ui['lists'][''] = site_config['uiDefaults']['list']
|
||||||
|
ids = [l.get_id() for l in self.user.lists.all()]
|
||||||
|
ids += [l.get_id() for l in self.user.subscribed_lists.all()]
|
||||||
|
ids += [l.get_id() for l in List.objects.filter(status='featured').exclude(user=self.user)]
|
||||||
|
for l in ids:
|
||||||
|
if l not in ui['lists']:
|
||||||
|
ui['lists'][l] = ui['lists']['']
|
||||||
|
return ui
|
||||||
|
|
||||||
def user_post_save(sender, instance, **kwargs):
|
def user_post_save(sender, instance, **kwargs):
|
||||||
profile, new = UserProfile.objects.get_or_create(user=instance)
|
profile, new = UserProfile.objects.get_or_create(user=instance)
|
||||||
|
|
||||||
|
@ -30,6 +50,7 @@ models.signals.post_save.connect(user_post_save, sender=User)
|
||||||
|
|
||||||
|
|
||||||
def get_user_json(user):
|
def get_user_json(user):
|
||||||
|
profile = user.get_profile()
|
||||||
result = {}
|
result = {}
|
||||||
for key in ('username', ):
|
for key in ('username', ):
|
||||||
result[key] = getattr(user, key)
|
result[key] = getattr(user, key)
|
||||||
|
@ -38,61 +59,6 @@ def get_user_json(user):
|
||||||
result['group'] = 'admin'
|
result['group'] = 'admin'
|
||||||
elif user.has_perm('0x.vip'): #FIXME: permissions
|
elif user.has_perm('0x.vip'): #FIXME: permissions
|
||||||
result['group'] = 'vip'
|
result['group'] = 'vip'
|
||||||
result['preferences'] = get_preferences(user)
|
result['preferences'] = profile.get_preferences()
|
||||||
result['ui'] = get_ui(user)
|
result['ui'] = profile.get_ui()
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
|
||||||
def get_ui(user):
|
|
||||||
return site_config['user']['ui']
|
|
||||||
'''
|
|
||||||
return {
|
|
||||||
"columns": ["id", "title", "director", "country", "year", "language", "genre"],
|
|
||||||
"findQuery": {"conditions": [], "operator": ""},
|
|
||||||
"groupsQuery": {"conditions": [], "operator": "|"},
|
|
||||||
"groupsSize": 128,
|
|
||||||
"itemView": "timeline",
|
|
||||||
"listQuery": {"conditions": [], "operator": ""},
|
|
||||||
"listsSize": 192,
|
|
||||||
"listView": "icons",
|
|
||||||
"sections": ["history", "lists", "public", "featured"],
|
|
||||||
"showGroups": True,
|
|
||||||
"showInfo": True,
|
|
||||||
"showLists": True,
|
|
||||||
"showMovies": True,
|
|
||||||
"sort": settings.DEFAULT_SORT,
|
|
||||||
"theme": settings.DEFAULT_THEME
|
|
||||||
}
|
|
||||||
'''
|
|
||||||
|
|
||||||
|
|
||||||
def get_preferences(user):
|
|
||||||
prefs = user.get_profile().preferences
|
|
||||||
prefs['email'] = user.email
|
|
||||||
return prefs
|
|
||||||
|
|
||||||
|
|
||||||
def get_preference(user, key, value=None):
|
|
||||||
if key in ('email', ):
|
|
||||||
value = getattr(user, key)
|
|
||||||
else:
|
|
||||||
q = Preference.objects.filter(user=user, key=key)
|
|
||||||
if q.count() > 0:
|
|
||||||
value = json.loads(q[0].value)
|
|
||||||
return value
|
|
||||||
|
|
||||||
|
|
||||||
def set_preference(user, key, value):
|
|
||||||
if key in ('email', ):
|
|
||||||
setattr(user, key, value)
|
|
||||||
user.save()
|
|
||||||
else:
|
|
||||||
value = json.dumps(value)
|
|
||||||
q = Preference.objects.filter(user=user, key=key)
|
|
||||||
if q.count() > 0:
|
|
||||||
p = q[0]
|
|
||||||
p.value = value
|
|
||||||
p.save()
|
|
||||||
else:
|
|
||||||
p = Preference(user=user, key=key, value=value)
|
|
||||||
p.save()
|
|
||||||
|
|
|
@ -408,7 +408,12 @@ def setUI(request):
|
||||||
param data {
|
param data {
|
||||||
key.subkey: value
|
key.subkey: value
|
||||||
}
|
}
|
||||||
return
|
you can set nested keys
|
||||||
|
api.setUI({"lists.my.listView": "icons"})
|
||||||
|
|
||||||
|
return {
|
||||||
|
'status': {'code': int, 'text': string}
|
||||||
|
}
|
||||||
'''
|
'''
|
||||||
data = json.loads(request.POST['data'])
|
data = json.loads(request.POST['data'])
|
||||||
keys = data.keys()[0].split('.')
|
keys = data.keys()[0].split('.')
|
||||||
|
|
Loading…
Reference in a new issue