schema.py 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. import graphene
  2. from graphene_django.types import DjangoObjectType
  3. from graphql_jwt.decorators import login_required
  4. from goods.schema import ImageType,ImageInput
  5. import json
  6. from functools import reduce
  7. from django.forms.models import model_to_dict
  8. from django.contrib.auth import get_user_model
  9. from goods.models import Image
  10. import operator
  11. from django.db.models import Q
  12. import graphene
  13. import graphql_jwt
  14. User = get_user_model()
  15. class UserType(graphene.ObjectType):
  16. _id = graphene.String(name='_id')
  17. avatar = graphene.Field(ImageType)
  18. name = graphene.String()
  19. nick = graphene.String()
  20. username = graphene.String()
  21. acl = graphene.List(graphene.String)
  22. is_active = graphene.Boolean(name = 'is_active')
  23. createdAt = graphene.String()
  24. def resolve__id(self,info):
  25. return self._id
  26. def resolve_avatar(self,info):
  27. return self.avatar
  28. def resolve_nick(self,info):
  29. return self.nick
  30. def resolve_name(self,info):
  31. return self.name
  32. def resolve_username(self,info):
  33. return self.username
  34. def resolve_is_active(self,info):
  35. return self.is_active
  36. def resolve_acl(self,info):
  37. user = User.objects.get(_id = self._id)
  38. acl = ["anon"]
  39. if user._id:
  40. if user.is_active:
  41. acl.append("active")
  42. if user.is_superuser:
  43. acl.append("admin")
  44. return acl
  45. def resolve_createdAt(self,info):
  46. return self.createdAt.strftime('%s')
  47. class UserInput(graphene.InputObjectType):
  48. _id = graphene.String(name='_id')
  49. avatar = graphene.Field(ImageInput)
  50. name = graphene.String()
  51. nick = graphene.String()
  52. acl = graphene.List(graphene.String)
  53. username = graphene.String()
  54. password = graphene.String()
  55. class Query(graphene.ObjectType):
  56. UserFind = graphene.List(UserType,query = graphene.String())
  57. UserFindOne = graphene.Field(UserType,query = graphene.String())
  58. def resolve_UserFind(self,info,query = "[{}]"):
  59. additional_params = {}
  60. query_list = json.loads(query)
  61. filter_params = query_list[0]
  62. if len(query_list) > 1:
  63. additional_params = query_list[1]
  64. skip = int(additional_params.get("skip",0))
  65. limit = int(additional_params.get("limit",20))
  66. order_by = additional_params.get("orderBy","_id")
  67. query_set = User.objects.all()
  68. if len(filter_params):
  69. or_filter_params = filter_params.pop("or",{})
  70. and_filter_params= filter_params.pop("and",{})
  71. and_filter_params |= filter_params
  72. if len(or_filter_params):
  73. query_set = query_set.filter(reduce(operator.or_,(Q(**d) for d in [dict([i]) for i in or_filter_params.items()])))
  74. if len(and_filter_params):
  75. query_set = query_set.filter(reduce(operator.and_,(Q(**d) for d in [dict([i]) for i in and_filter_params.items()])))
  76. query_set = query_set.order_by(order_by)[skip:skip+limit]
  77. return query_set
  78. def resolve_UserFindOne(self,info,query = "[{}]"):
  79. user = info.context.user
  80. additional_params = {}
  81. query_list = json.loads(query)
  82. filter_params = query_list[0]
  83. if len(query_list) > 1:
  84. additional_params = query_list[1]
  85. skip = additional_params.get("skip",0)
  86. limit = additional_params.get("limit",20)
  87. order_by = additional_params.get("orderBy","_id")
  88. if user.is_superuser:
  89. query_set = User.objects.all()
  90. else:
  91. query_set = User.objects.filter(pk=user._id)
  92. if len(filter_params):
  93. or_filter_params = filter_params.pop("or",{})
  94. and_filter_params= filter_params.pop("and",{})
  95. and_filter_params |= filter_params
  96. if len(or_filter_params):
  97. query_set = query_set.filter(reduce(operator.or_,(Q(**d) for d in [dict([i]) for i in or_filter_params.items()])))
  98. if len(and_filter_params):
  99. query_set = query_set.filter(reduce(operator.and_,(Q(**d) for d in [dict([i]) for i in and_filter_params.items()])))
  100. return query_set.first()
  101. class UserUpsert(graphene.Mutation):
  102. class Arguments:
  103. user = UserInput(required=True)
  104. Output =UserType
  105. @staticmethod
  106. def mutate(root,info,user):
  107. new_user={}
  108. password = None
  109. ava = None
  110. acl = []
  111. if "password" in user and len(user["password"]) < 3:
  112. raise Exception("Не вірні дані (пароль)")
  113. elif "password" in user:
  114. password = str(user.pop("password"))
  115. if "acl" in user:
  116. acl = user.get("acl", [])
  117. user.pop("acl")
  118. if "avatar" in user:
  119. if user.get("avatar") == "null":
  120. ava = user.pop("avatar")
  121. else:
  122. try:
  123. ava = Image.objects.get(_id = user.pop("avatar")["_id"])
  124. except:
  125. raise Exception("Не вірні дані (аватар)")
  126. if "_id" in user:
  127. if not info.context.user.is_authenticated:
  128. raise Exception("Authentication credentials were not provided")
  129. if str(info.context.user._id) != user._id and not info.context.user.is_superuser:
  130. raise Exception("Authentication credentials were not provided")
  131. try:
  132. _id = user._id
  133. new_user = User.objects.get(_id = _id)
  134. user.pop("_id",None)
  135. new_user.__dict__.update(**user)
  136. if password:
  137. new_user.set_password(password)
  138. except:
  139. raise Exception("Не вірні дані")
  140. else:
  141. if info.context.user.is_authenticated and not info.context.user.is_superuser:
  142. new_user = User.objects.get(username = info.context.user.username )
  143. else:
  144. new_user = User.objects.create_user(username = user.username,password=user.password)
  145. if ava:
  146. if ava == "null":
  147. new_user.avatar = None
  148. else:
  149. new_user.avatar = ava
  150. if len(acl):
  151. if not info.context.user.is_superuser:
  152. raise Exception("Authentication credentials were not provided")
  153. new_user.is_active = "active" in acl
  154. new_user.is_superuser = "admin" in acl
  155. new_user.save()
  156. user_data = {key: new_user.__dict__[key] for key in new_user.__dict__.keys() & {"username","_id","name","avatar","nick"}}
  157. user_data["_id"] = new_user._id
  158. return UserType(**user_data)
  159. class Mutations(graphene.ObjectType):
  160. token_auth = graphql_jwt.ObtainJSONWebToken.Field()
  161. verify_token = graphql_jwt.Verify.Field()
  162. refresh_token = graphql_jwt.Refresh.Field()
  163. UserUpsert = UserUpsert.Field()