Django Как добавить информацию о пользователе в отчет Sentry, когда произошла ошибка? - PullRequest
0 голосов
/ 18 апреля 2019

Я использую django-restful framework и хочу добавить информацию о пользователе в отчет Sentry, когда в ModelViewSet произошла ошибка.

Я нахожу этот документ Стража: https://docs.sentry.io/enriching-error-data/context/?_ga=1.219964441.1220115692.1472094716%3F_ga&platform=python#capturing-the-user

Это дает некоторый код следующим образом:

from sentry_sdk import configure_scope

with configure_scope() as scope:
    scope.user = {"email": "john.doe@example.com"}

Но я не могу понять, как правильно его использовать. Я думаю, что существует лучший способ, чем следующий:

@list_route()
def fun_xxx(self, request, *args, **kwargs):
  user = request.user
  with configure_scope() as scope:
     scope.user = {"id": user.id,......}

  ...some code may cause an error...

  return Response({...})

Кто-нибудь может дать мне несколько советов? :)

1 Ответ

0 голосов
/ 22 апреля 2019

Как упоминалось в комментариях, интеграция Django автоматически прикрепит эти данные.

Что касается вопроса о том, как обычно добавлять данные в приложение Django, вы в основном ищете что-то для запуска перед каждым представлением. Промежуточное программное обеспечение Django подходит для этого:

def sentry_middleware(get_response):

    def middleware(request):
        with configure_scope() as scope:
            ...

        response = get_response(request)
        return response

    return middleware

https://docs.djangoproject.com/en/2.2/topics/http/middleware/

...