views.py 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. from django.conf import settings
  2. from django.core.urlresolvers import reverse
  3. from django.core.mail import send_mail
  4. from django.http import JsonResponse, HttpResponseForbidden
  5. from django.shortcuts import render, redirect
  6. from django.template.loader import get_template
  7. from django.views.generic import View
  8. from .forms import PublicContribForm
  9. from .models import Contrib
  10. from .decorators import prevent_robots
  11. @prevent_robots()
  12. def add_contrib(request):
  13. if request.method == 'GET':
  14. form = PublicContribForm()
  15. elif request.method == 'POST':
  16. form = PublicContribForm(request.POST)
  17. if form.is_valid():
  18. contrib = form.save()
  19. # Send notification email
  20. if len(settings.NOTIFICATION_EMAILS) > 0:
  21. context = {
  22. 'site_url': settings.SITE_URL,
  23. 'contrib': contrib,
  24. }
  25. subject = get_template(
  26. 'contribmap/mails/new_contrib_notice.subject')
  27. body = get_template(
  28. 'contribmap/mails/new_contrib_notice.txt')
  29. send_mail(
  30. subject.render(context),
  31. body.render(context),
  32. settings.DEFAULT_FROM_EMAIL,
  33. settings.NOTIFICATION_EMAILS,
  34. )
  35. return redirect(reverse('thanks'))
  36. return render(request, 'contribmap/wifi-form.html', {
  37. 'form': form,
  38. })
  39. def display_map(request):
  40. return render(request, 'contribmap/map.html')
  41. def thanks(request):
  42. return render(request, 'contribmap/thanks.html')
  43. class JSONContribView(View):
  44. def get(self, request):
  45. return JsonResponse({
  46. "id": self.ID,
  47. "license": self.LICENSE,
  48. "features": self.get_features(),
  49. })
  50. PLACE_PROPERTIES = [
  51. 'floor', 'angles', 'orientations', 'roof', 'floor', 'floor_total']
  52. class PublicJSON(JSONContribView):
  53. ID = 'public'
  54. LICENSE = {
  55. "type": "ODC-BY-1.0",
  56. "url": "http:\/\/opendatacommons.org\/licenses\/by\/1.0\/"
  57. }
  58. def get_features(self):
  59. contribs = Contrib.objects.all()
  60. data = []
  61. for i in contribs:
  62. if not i.is_public():
  63. continue
  64. data.append({
  65. "id": i.pk,
  66. "type": "Feature",
  67. "geometry": {
  68. "coordinates": [
  69. i.longitude,
  70. i.latitude
  71. ],
  72. "type": "Point",
  73. },
  74. "properties": {
  75. "contrib_type": i.contrib_type,
  76. "name": i.get_public_field('name'),
  77. "place": {
  78. k: i.get_public_field(k) for k in self.PLACE_PROPERTIES
  79. },
  80. "comment": i.get_public_field('comment'),
  81. }
  82. })
  83. return data
  84. class PrivateJSON(JSONContribView):
  85. ID = 'private'
  86. LICENSE = {
  87. "type": "Copyright",
  88. }
  89. def dispatch(self, request, *args, **kwargs):
  90. if hasattr(request, 'user') and request.user.is_staff:
  91. return super().dispatch(request, *args, **kwargs)
  92. else:
  93. return HttpResponseForbidden('Need staff access')
  94. def get_features(self):
  95. contribs = Contrib.objects.all()
  96. data = []
  97. for i in contribs:
  98. if not i.is_public():
  99. continue
  100. data.append({
  101. "id": i.pk,
  102. "type": "Feature",
  103. "geometry": {
  104. "coordinates": [
  105. i.latitude,
  106. i.longitude,
  107. ],
  108. "type": "Point",
  109. },
  110. "properties": {
  111. "contrib_type": i.contrib_type,
  112. "name": i.name,
  113. "place": {
  114. k: getattr(i, k) for k in self.PLACE_PROPERTIES
  115. },
  116. "comment": i.comment,
  117. "phone": i.phone,
  118. "email": i.email
  119. }
  120. })
  121. return data