L
LivisАқп. 6, 2021, 1:50 Т.Қ.

Не работает код на статус онлайн

Django

При попытке добавить код для статуса как встатье, я сталкнулся с проблемой, что он не записывает данные в бд(поля last_online NULL), такое ощущение, что бек просто не работает. Можете подсказать как это исправить?
Версия Django 3.1.6
Версия питона 3.8.2
Модель юзера

from django.db import models
from django.contrib.auth.models import User
from PIL import Image
from django.urls import reverse
from django.contrib.humanize.templatetags.humanize import naturaltime
from django.utils import timezone


class Profile(models.Model):
    user = models.OneToOneField(User, on_delete=models.CASCADE)
    image = models.ImageField(default='default.jpg', upload_to='profile_pics')
    last_online = models.DateTimeField(blank=True, null=True)

    def __str__(self):
        return f'{self.user.username} Profile'

    # В данном методе проверяем, что дата последнего посещения не старше 15 минут
    def is_online(self):
        if self.last_online:
            return (timezone.now() - self.last_online) < timezone.timedelta(minutes=15)
        return False

    def get_online_info(self):
        if self.is_online():
            return 'Онлайн'
        if self.last_online:
            return f'Последнее посещение: {naturaltime(self.last_online)}'
        else:
            return 'Не известно'

код MyBackend

from django.contrib.auth import get_user_model
from django.utils import timezone
from django.contrib.auth.backends import BaseBackend


class MyBackend(BaseBackend):

    def get_user(self, user_id):
        try:
            user = get_user_model().objects.get(pk=user_id)
            user.last_online = timezone.now()  # При запросе пользователя выполним обновлении
            # даты и времени последнего посещения
            user.save(update_fields=['last_online'])
            return user
        except get_user_model().DoesNotExist:
            return None

файл settings

AUTHENTICATION_BACKENDS = (
    'users.backends.MyBackend',
    'django.contrib.auth.backends.ModelBackend',
)

код темплейта

<span class="caption-1">Статус</span>
<span class="body-2">{{ user.get_online_info }}</span>
Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

6
Илья Чичак
  • Ақп. 6, 2021, 3:09 Т.Қ.

auth_backend - это про другое. Попробуйте сделать это через middleware?

    L
    • Ақп. 6, 2021, 3:14 Т.Қ.

    пишет такое

    TypeError: MyBackend() takes no arguments
    
    MIDDLEWARE = [
        'django.middleware.security.SecurityMiddleware',
        'django.contrib.sessions.middleware.SessionMiddleware',
        'django.middleware.common.CommonMiddleware',
        'django.middleware.csrf.CsrfViewMiddleware',
        'django.contrib.auth.middleware.AuthenticationMiddleware',
        'django.contrib.messages.middleware.MessageMiddleware',
        'django.middleware.clickjacking.XFrameOptionsMiddleware',
        'users.backends.MyBackend',
        'django.contrib.auth.middleware.AuthenticationMiddleware',
        'blacklist.middleware.blacklist_middleware',
    ]
    
      Илья Чичак
      • Ақп. 6, 2021, 3:30 Т.Қ.

      так, я поторопился. Надо разбираться
      если вы делаете через auth_backend - last_online будет проставляться только в момент логина. Если сделать через middleware, оно будет обновляться каждый раз,когда пользователь будет делать что-либо.
      Тоесть, в первом случае, пользователь может авторизоваться и пользоваться сайтом час-два,но спустя 15 минут будет показано, что он оффлайн. А если нет протухания сессии, пользователь может и на следующий день вернуться, а показано будет, что он оффлайн.
      Во втором случае, пока он ходил по ссылкам и выполняет запросы - он будет отображаться, как онлайн. Но возрастет нагрузка на базу.

      если нагрузка по боку, я бы сделал такую middleware:

      class LastOnlineMiddleware:
          def __init__(self, get_response):
              self.get_response = get_response
      
          def __call__(self, request):
              if request.user.is_authenticated:
                  get_user_model().filter(id=request.user.id).update(last_online=timezone.now())
              response = self.get_response(request)
              return response
      

      так одним запросом будет обновляться его поле а дальше запросы будут выполняться, как выполнялись

        L
        • Ақп. 6, 2021, 3:49 Т.Қ.

        На нагрузку без разницы, и для меня ваш вариант подходит, но к сожалению выбивает в ошибку.

        Internal Server Error: /
        Traceback (most recent call last):
          File "C:\Python38\lib\site-packages\django\core\handlers\exception.py", line 47, in inner
            response = get_response(request)
          File "C:\Users\Livis\PycharmProjects\djangosite\users\backends.py", line 25, in __call__
            get_user_model().filter(id=request.user.id).update(last_online=timezone.now())
        AttributeError: type object 'User' has no attribute 'filter'
        

        Я заменил класс MyBackend, на ваш предложенный

        class LastOnlineMiddleware:
            def __init__(self, get_response):
                self.get_response = get_response
        
            def __call__(self, request):
                if request.user.is_authenticated:
                    get_user_model().filter(id=request.user.id).update(last_online=timezone.now())
                response = self.get_response(request)
                return response
        
        MIDDLEWARE = [
            'django.middleware.security.SecurityMiddleware',
            'django.contrib.sessions.middleware.SessionMiddleware',
            'django.middleware.common.CommonMiddleware',
            'django.middleware.csrf.CsrfViewMiddleware',
            'django.contrib.auth.middleware.AuthenticationMiddleware',
            'django.contrib.messages.middleware.MessageMiddleware',
            'django.middleware.clickjacking.XFrameOptionsMiddleware',
            'users.backends.LastOnlineMiddleware',
            'django.contrib.auth.middleware.AuthenticationMiddleware',
            'blacklist.middleware.blacklist_middleware',
        ]
        
          Илья Чичак
          • Ақп. 6, 2021, 4:51 Т.Қ.
          • Жауап шешім ретінде белгіленді.

          опечатался:
          get_user_model().filter(id=request.user.id).update(last_online=timezone.now())
          поменять на:
          get_user_model().objects.filter(id=request.user.id).update(last_online=timezone.now())

            L
            • Ақп. 6, 2021, 7:17 Т.Қ.

            Спасибо за уделенное время, всё работает

              Пікірлер

              Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
              Кіріңіз немесе Тіркеліңіз
              OI
              • Ora Iro
              • Жел. 24, 2024, 5:38 Т.Қ.

              C++ - Тест 001. Первая программа и типы данных

              • Нәтиже:40ұпай,
              • Бағалау ұпайлары-8
              AD

              C++ - Тест 004. Указатели, Массивы и Циклы

              • Нәтиже:50ұпай,
              • Бағалау ұпайлары-4
              m
              • molni99
              • Қаз. 26, 2024, 11:37 Т.Ж.

              C++ - Тест 004. Указатели, Массивы и Циклы

              • Нәтиже:80ұпай,
              • Бағалау ұпайлары4
              Соңғы пікірлер
              ИМ
              Игорь МаксимовҚар. 22, 2024, 10:51 Т.Қ.
              Django - Оқулық 017. Теңшелген Django кіру беті Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
              Evgenii Legotckoi
              Evgenii LegotckoiҚар. 1, 2024, 12:37 Т.Ж.
              Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
              A
              ALO1ZEҚаз. 19, 2024, 6:19 Т.Қ.
              Qt Creator көмегімен fb3 файл оқу құралы Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
              ИМ
              Игорь МаксимовҚаз. 5, 2024, 5:51 Т.Қ.
              Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
              d
              dblas5Шілде 5, 2024, 9:02 Т.Қ.
              QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
              Енді форумда талқылаңыз
              Evgenii Legotckoi
              Evgenii LegotckoiМаусым 25, 2024, 1:11 Т.Ж.
              добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
              t
              tonypeachey1Қар. 15, 2024, 5:04 Т.Қ.
              google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
              NSProject
              NSProjectМаусым 4, 2022, 1:49 Т.Қ.
              Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
              9
              9AnonimҚаз. 25, 2024, 7:10 Т.Қ.
              Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

              Бізді әлеуметтік желілерде бақылаңыз