def bulk_validation_status(self, request, *args, **kwargs): xform = self.__validate_permission_on_bulk_action( request, 'validate_xform') payload = self.__get_payload(request) try: new_validation_status_uid = payload['validation_status.uid'] except KeyError: raise ValidationError( {'payload': _('No `validation_status.uid` provided')}) # Create new validation_status object new_validation_status = get_validation_status( new_validation_status_uid, xform, request.user.username) postgres_query, mongo_query = self.__build_db_queries(xform, payload) # Update Postgres & Mongo updated_records_count = Instance.objects.\ filter(**postgres_query).update(validation_status=new_validation_status) ParsedInstance.bulk_update_validation_statuses(mongo_query, new_validation_status) return Response( { 'detail': _('{} submissions have been updated').format( updated_records_count) }, status.HTTP_200_OK)
def modify(self, request, *args, **kwargs): xform = self.get_object() http_status = status.HTTP_200_OK response = {} if request.user.has_perm("validate_xform", xform): owner = xform.user userform_id = "{}_{}".format(owner.username, xform.id_string) query = {ParsedInstance.USERFORM_ID: userform_id} # Query used for MongoDB filter_ = {"xform_id": xform.id} # Filter for Django ORM payload = {} try: payload = json.loads(request.data.get("payload", "{}")) except ValueError: http_status = status.HTTP_400_BAD_REQUEST response = {"detail": _("Invalid payload")} if http_status == status.HTTP_200_OK: new_validation_status_uid = payload.get("validation_status.uid") if new_validation_status_uid is None: http_status = status.HTTP_400_BAD_REQUEST response = {"detail": _("No validation_status.uid provided")} else: # Create new validation_status object new_validation_status = get_validation_status( new_validation_status_uid, xform, request.user.username) # 3 scenarios to update submissions # First scenario / Modify submissions based on user's query if payload.get("query"): # Validate if query is valid. try: query.update(payload.get("query")) except ValueError: raise ParseError(_("Invalid query: %(query)s" % {'query': json.dumps(payload.get("query"))})) query_kwargs = { "query": json.dumps(query), "fields": '["_id"]' } cursor = ParsedInstance.query_mongo_no_paging(**query_kwargs) submissions_ids = [record.get("_id") for record in list(cursor)] filter_.update({"id__in": submissions_ids}) # Second scenario / Modify submissions based on list of ids elif payload.get("submissions_ids"): try: # Use int() to test if list of integers is valid. submissions_ids = payload.get("submissions_ids", []) or_ = {u"$or": [{u"_id": int(submission_id)} for submission_id in submissions_ids]} query.update(or_) except ValueError: raise ParseError(_("Invalid submissions ids: %(submissions_ids)s" % {'submissions_ids': json.dumps(payload.get("submissions_ids"))})) filter_.update({"id__in": submissions_ids}) # Third scenario / Modify all submissions in form, but confirmation param must be among payload elif payload.get("confirm", False) is not True: http_status = status.HTTP_400_BAD_REQUEST response = {"detail": _("No confirmations provided")} # If everything is OK, submit data to DBs if http_status == status.HTTP_200_OK: # Update Postgres & Mongo updated_records_count = Instance.objects.\ filter(**filter_).update(validation_status=new_validation_status) ParsedInstance.bulk_update_validation_statuses(query, new_validation_status) response = {"detail": _("{} submissions have been updated").format(updated_records_count)} return Response(response, http_status) else: raise PermissionDenied(_(u"You do not have validate permissions."))
def modify(self, request, *args, **kwargs): xform = self.get_object() http_status = status.HTTP_200_OK response = {} if request.user.has_perm("validate_xform", xform): owner = xform.user userform_id = "{}_{}".format(owner.username, xform.id_string) query = {ParsedInstance.USERFORM_ID: userform_id} # Query used for MongoDB filter_ = {"xform_id": xform.id} # Filter for Django ORM payload = {} try: payload = json.loads(request.data.get("payload", "{}")) except ValueError: http_status = status.HTTP_400_BAD_REQUEST response = {"detail": _("Invalid payload")} if http_status == status.HTTP_200_OK: if request.data.get("reset"): new_validation_status_uid = {} else: new_validation_status_uid = payload.get("validation_status.uid") if new_validation_status_uid is None: http_status = status.HTTP_400_BAD_REQUEST response = {"detail": _("No validation_status.uid provided")} else: # Create new validation_status object new_validation_status = get_validation_status( new_validation_status_uid, xform, request.user.username) # 3 scenarios to update submissions # First scenario / Modify submissions based on user's query if payload.get("query"): # Validate if query is valid. try: query.update(payload.get("query")) except ValueError: raise ParseError(_("Invalid query: %(query)s" % {'query': json.dumps(payload.get("query"))})) query_kwargs = { "query": json.dumps(query), "fields": '["_id"]' } cursor = ParsedInstance.query_mongo_no_paging(**query_kwargs) submissions_ids = [record.get("_id") for record in list(cursor)] filter_.update({"id__in": submissions_ids}) # Second scenario / Modify submissions based on list of ids elif payload.get("submissions_ids"): try: # Use int() to test if list of integers is valid. submissions_ids = payload.get("submissions_ids", []) or_ = {u"$or": [{u"_id": int(submission_id)} for submission_id in submissions_ids]} query.update(or_) except ValueError: raise ParseError(_("Invalid submissions ids: %(submissions_ids)s" % {'submissions_ids': json.dumps(payload.get("submissions_ids"))})) filter_.update({"id__in": submissions_ids}) # Third scenario / Modify all submissions in form, but confirmation param must be among payload elif payload.get("confirm", False) is not True: http_status = status.HTTP_400_BAD_REQUEST response = {"detail": _("No confirmations provided")} # If everything is OK, submit data to DBs if http_status == status.HTTP_200_OK: # Update Postgres & Mongo updated_records_count = Instance.objects.\ filter(**filter_).update(validation_status=new_validation_status) ParsedInstance.bulk_update_validation_statuses(query, new_validation_status) response = {"detail": _("{} submissions have been updated").format(updated_records_count)} return Response(response, http_status) else: raise PermissionDenied(_(u"You do not have validate permissions."))