index.py 4.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. from datetime import timedelta
  2. from django.core.cache import cache
  3. from django.template import RequestContext
  4. from django.utils import timezone
  5. from misago.models import Forum, Post, Rank, Session, Thread
  6. from misago.readstrackers import ForumsTracker
  7. def index(request):
  8. # Threads ranking
  9. popular_threads = []
  10. if request.settings['thread_ranking_size'] > 0:
  11. popular_threads = cache.get('thread_ranking_%s' % request.user.make_acl_key(), 'nada')
  12. if popular_threads == 'nada':
  13. popular_threads = []
  14. for thread in Thread.objects.filter(moderated=False).filter(deleted=False).filter(forum__in=Forum.objects.readable_forums(request.acl)).prefetch_related('forum').order_by('-score')[:request.settings['thread_ranking_size']]:
  15. thread.forum_name = thread.forum.name
  16. thread.forum_slug = thread.forum.slug
  17. popular_threads.append(thread)
  18. cache.set('thread_ranking_%s' % request.user.make_acl_key(), popular_threads, 60 * request.settings['thread_ranking_refresh'])
  19. # Users online
  20. users_online = request.onlines.stats(request)
  21. # Ranks online
  22. ranks_list = cache.get('ranks_online', 'nada')
  23. if ranks_list == 'nada':
  24. ranks_dict = {}
  25. ranks_list = []
  26. users_list = []
  27. for rank in Rank.objects.filter(on_index=True).order_by('order'):
  28. rank_entry = {
  29. 'id':rank.id,
  30. 'name': rank.name,
  31. 'slug': rank.slug if rank.as_tab else '',
  32. 'style': rank.style,
  33. 'title': rank.title,
  34. 'online': [],
  35. 'pks': [],
  36. }
  37. ranks_list.append(rank_entry)
  38. ranks_dict[rank.pk] = rank_entry
  39. if ranks_dict:
  40. for session in Session.objects.select_related('user').filter(rank__in=ranks_dict.keys()).filter(last__gte=timezone.now() - timedelta(seconds=request.settings['online_counting_frequency'])).filter(user__isnull=False):
  41. if not session.user_id in users_list:
  42. ranks_dict[session.user.rank_id]['online'].append(session.user)
  43. ranks_dict[session.user.rank_id]['pks'].append(session.user.pk)
  44. users_list.append(session.user_id)
  45. # Assert we are on list
  46. if (request.user.is_authenticated() and request.user.rank_id in ranks_dict.keys()
  47. and not request.user.pk in users_list):
  48. ranks_dict[request.user.rank_id]['online'].append(request.user)
  49. ranks_dict[request.user.rank_id]['pks'].append(request.user.pk)
  50. users_list.append(request.user.pk)
  51. cache.set('team_users_online', users_list, request.settings['online_counting_frequency'])
  52. del ranks_dict
  53. del users_list
  54. cache.set('ranks_online', ranks_list, request.settings['online_counting_frequency'])
  55. elif request.user.is_authenticated():
  56. for rank in ranks_list:
  57. if rank['id'] == request.user.rank_id and not request.user.pk in rank['pks']:
  58. rank['online'].append(request.user)
  59. rank['pks'].append(request.user.pk)
  60. break
  61. # Load reads tracker and build forums list
  62. reads_tracker = ForumsTracker(request.user)
  63. forums_list = Forum.objects.treelist(request.acl.forums, tracker=reads_tracker)
  64. # Whitelist ignored members
  65. Forum.objects.ignored_users(request.user, forums_list)
  66. # Render page
  67. return request.theme.render_to_response('index.html',
  68. {
  69. 'forums_list': forums_list,
  70. 'ranks_online': ranks_list,
  71. 'users_online': users_online,
  72. 'popular_threads': popular_threads,
  73. },
  74. context_instance=RequestContext(request));