user_resource.py 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. # -*- coding: utf-8 -*-
  2. from __future__ import unicode_literals
  3. from tastypie import fields
  4. from tastypie.resources import ModelResource
  5. from tastypie.authorization import Authorization
  6. from tastypie.exceptions import ImmediateHttpResponse
  7. from tastypie.utils import trailing_slash
  8. from django.conf.urls import url
  9. from core.models.user import User
  10. from api.validations.user_validation import UserValidation
  11. from api.resources.group_resource import GroupResource
  12. import simplejson as json
  13. '''
  14. '''
  15. class UserResource(ModelResource):
  16. groups = fields.ToManyField(GroupResource, 'groups')
  17. class Meta:
  18. queryset = User.objects.all()
  19. authorization = Authorization()
  20. always_return_data = True
  21. validation = UserValidation()
  22. '''
  23. '''
  24. def prepend_urls(self):
  25. return [
  26. url(r'^(?P<resource_name>%s)/(?P<%s>.*?)/change_password%s$' % (self._meta.resource_name, self._meta.detail_uri_name, trailing_slash), self.wrap_view('change_password'), name='api_change_password')
  27. ]
  28. '''
  29. '''
  30. def change_password(self, request, **kwargs):
  31. self.method_check(request, ['post'])
  32. self.is_authenticated(request)
  33. # Check content type
  34. if request.content_type != 'application/json':
  35. return self.create_response(request, {
  36. 'error_message': 'request is not json'
  37. })
  38. # Check body
  39. if not request.body:
  40. return self.create_response(request, {
  41. 'error_message': 'request body is empty'
  42. })
  43. # Check if password is present in body
  44. if not 'password' in request.body:
  45. return self.create_response(request, {
  46. 'error_message': 'password is not provided'
  47. })
  48. bundle = self.build_bundle(obj=json.loads(request.body), request=request)
  49. import pdb; pdb.set_trace()
  50. return self.create_response(request, {
  51. self._meta.resource_name: 'ok'
  52. })
  53. '''
  54. '''
  55. def save(self, bundle, skip_errors=False):
  56. if bundle.via_uri:
  57. return bundle
  58. self.is_valid(bundle)
  59. # If bundle has errors send this reponse
  60. if bundle.errors and not skip_errors:
  61. raise ImmediateHttpResponse(response=self.error_response(bundle.request, bundle.errors))
  62. # If object data is not persist create django auth user
  63. if bundle.obj._state.adding:
  64. user = User.objects.create_user(bundle.data['username'], bundle.data['email'], bundle.data['password'])
  65. user.first_name = bundle.data.get('first_name', '')
  66. user.last_name = bundle.data.get('last_name', '')
  67. bundle.obj = user
  68. bundle.data['groups'] = bundle.data.get('groups', [])
  69. if bundle.obj.pk:
  70. self.authorized_update_detail(self.get_object_list(bundle.request), bundle)
  71. else:
  72. self.authorized_create_detail(self.get_object_list(bundle.request), bundle)
  73. self.save_related(bundle)
  74. obj_id = self.create_identifier(bundle.obj)
  75. if obj_id not in bundle.objects_saved or bundle.obj._state.adding:
  76. bundle.obj.save()
  77. bundle.objects_saved.add(obj_id)
  78. m2m_bundle = self.hydrate_m2m(bundle)
  79. self.save_m2m(m2m_bundle)
  80. return bundle