Почему мой текущий пользователь не может видеть свою собственную папку «Входящие», но может видеть папку «Входящие» другого пользователя? - PullRequest
0 голосов
/ 12 апреля 2020

Итак, я пытаюсь запрашивать и отображать сообщения между двумя пользователями в папке «Входящие». Я сталкиваюсь с проблемой, когда никакие сообщения не появляются для request.user. Он показывает, как пустой, когда есть сообщения. Однако, когда я go вошел в почтовый ящик другого пользователя, которому мой request.user отправил сообщение, в то время как все еще вошел в систему request.user, я могу видеть сообщения от обеих сторон там и отображаться правильно.

Так что в основном мой текущий пользователь не может получить доступ к своим собственным сообщениям. Я знаю, что мне нужно как-то передать request.user в шаблон для правильного запроса сообщений, но я не уверен, как это сделать.

настройки / шаблоны

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',

            ],
        },
    },
]

сообщений. html

{% for msg in messages %}


    {% if msg.receiver_id == user.id %}
        <li class="text-right list-group-item">{{ msg.message }}<br/>{{ msg.date }}<br/>{{ request.user.username }}</li>

    {% elif msg.sender_id == user.id %}
        <li class="text-left list-group-item">{{ msg.message }}<br/>{{ msg.date }}</li>
    {% endif %} 



    {% empty %}
{%endfor %}

views.py / messages

def messages(request, profile_id):
    messages = InstantMessage.objects.filter(Q(sender_id=request.user, receiver_id=profile_id,) 
            | Q(sender_id=profile_id, receiver_id=request.user,) ).\
        values('sender_id','receiver_id', 'message', 'date', ).\
        order_by('date',)


    return render(request, 'dating_app/messages.html', {'messages': messages,})

urls.py / messages

path('messages/<int:profile_id>/', views.messages, name='messages')

base.html / messages url href

<a class="nav-link" href="{% url 'dating_app:messages' user.id %}">Check Messages</a

models.py

from django.db import models
from django.contrib.auth.models import AbstractBaseUser,BaseUserManager, User
from dating_project import settings
from django.contrib.auth import get_user_model


class ProfileManager(BaseUserManager):



    def create_user(self, username, email,description,photo, password=None):
        if not email:
            raise ValueError("You must creat an email")
        if not username:
            raise ValueError("You must create a username!")
        if not description:
            raise ValueError("You must write a description")
        if not photo:
            raise ValueError("You must upload a photo")

        user = self.model(
                email=self.normalize_email(email),
                username = username, 
                description= description,
                photo= photo,

            )

        user.set_password(password)
        user.save(using=self._db)
        return user 


    def create_superuser(self, username, email,description,photo, password):
        user = self.create_user(
                email=self.normalize_email(email),
                password=password,
                username=username,
                description=description,
                photo=photo,

            )

        user.is_admin=True
        user.is_staff=True
        user.is_superuser=True
        user.save(using=self._db)
        return user




class Profile(AbstractBaseUser):

    class Meta:
        swappable = 'AUTH_USER_MODEL'


    email                       = models.EmailField(verbose_name="email")
    username                    = models.CharField(max_length=30, unique=True)
    date_joined                 = models.DateTimeField(verbose_name='date joined', auto_now_add=True)
    last_login                  = models.DateTimeField(verbose_name='last login', auto_now=True)
    is_admin                    = models.BooleanField(default=False)
    is_active                   = models.BooleanField(default=True)
    is_staff                    = models.BooleanField(default=False)
    is_superuser                = models.BooleanField(default=False)
    #what I added
    description                 = models.TextField()
    photo                       = models.ImageField(upload_to='profile_photo',blank=False, height_field=None, width_field=None, max_length=100)
    matches                     = models.ManyToManyField(settings.AUTH_USER_MODEL, related_name='+', blank=True)



    USERNAME_FIELD = 'username'
    REQUIRED_FIELDS = ['description','photo','email']


    objects = ProfileManager()


    def __str__(self):
        return self.username


    def has_perm(self, perm, obj=None):
        return self.is_admin


    def has_module_perms(self,app_label):
        return True



class UserVote(models.Model):

    user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)
    voter = models.ForeignKey(settings.AUTH_USER_MODEL, related_name='given_vote', on_delete=models.CASCADE)
    vote = models.BooleanField(default=False)

    class Meta:
        unique_together = (('user', 'voter'))

class InstantMessage(models.Model):

    sender = models.ForeignKey(settings.AUTH_USER_MODEL, related_name= 'senderr',on_delete=models.CASCADE )
    receiver = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)
    message = models.TextField()
    date = models.DateTimeField(auto_now_add=True)


    def __unicode__(self):
        return self.message

Ответы [ 2 ]

0 голосов
/ 12 апреля 2020

Я думаю, что ваша проблема в views.py/messages. Вы фильтруете сообщения от пользователя-> профиль или профиль-> пользователь. Но вы ссылаетесь на URL, где профиль и пользователь совпадают. Таким образом, на этой странице вы будете получать сообщения только с теми же отправителями и получателями.

def messages(request, profile_id):
    messages = InstantMessage.objects.filter(Q(sender_id=request.user, receiver_id=profile_id,) 
            | Q(sender_id=profile_id, receiver_id=request.user,) ).\
        values('sender_id','receiver_id', 'message', 'date', ).\
        order_by('date',)


    return render(request, 'dating_app/messages.html', {'messages': messages,})

Возможно, вам следует создать другое представление для отображения сообщений текущему пользователю или от него с этим запросом.

messages = InstantMessage.objects.filter(Q(sender_id=request.user) | Q( receiver_id=request.user)).\
    values('sender_id','receiver_id', 'message', 'date', ).\
    order_by('date',)

РЕДАКТИРОВАТЬ: предложение с использованием модели разговора.

class Conversation(models.Model):
    members = models.ManyToManyField(settings.AUTH_USER_MODEL)

    @property
    def last_message_time(self):
        try:
            return self.instantmessage_set.order_by('-date').first().date
        except self.instantmessage_set.DoesNotExist:
            pass

    def __unicode__(self):
        return ', '.join(self.members.all())


class InstantMessage(models.Model):
    sender = models.ForeignKey(settings.AUTH_USER_MODEL, related_name= 'senderr',on_delete=models.CASCADE )
    conversation = models.ForeignKey(Conversation, models.CASCADE)
    # Don't need this if it belongs to a conversation
    # receiver = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)
    message = models.TextField()
    date = models.DateTimeField(auto_now_add=True)

    def __unicode__(self):
        return self.message

В представлении вы можете получить доступ к беседам, используя {{ user.conversation_set.all }}.

сообщения. html

{% for conversation in user.conversation_set.all %}
    <li class="text-right list-group-item">
        {% for member in conversation.members.all %}{% if member != user %}
            {{ member.username }}<br/>
        {% endif %}{% endfor %}
        {{ conversation.last_message_time }}
    </li>
{%endfor %}
0 голосов
/ 12 апреля 2020

Вы messages метод возвращает сообщения в контексте, но не user, который используется в вашем шаблоне.

Однако, django может добавить запрос в контекст для вас, если вы настроите его для , Делая это, вам никогда не придется передавать зарегистрированного пользователя в контексте ваших представлений, потому что он уже существует.

Чтобы сделать это, убедитесь, что django.template.context_processors.request в вашем процессоры контекста шаблона.

С этим настроенным ваш шаблон может делать {% if msg.receiver_id == request.user.id %}

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...