Как я могу разрешить пользователю получать доступ к представлению только один раз каждые 30 минут в Django? - PullRequest
0 голосов
/ 10 января 2020

Я создаю приложение, которое позволяет пользователям обновлять веб-страницу, но я хочу запретить любому пользователю делать обновления каждые 20-30 минут. Смогу ли я просто добавить эту логику c к определению вида?

@login_required
def update_options(request):
    ...
    # logic to determine how much time passed since the user visited
    ...
    return render(request, 'main/update-options.html')

Ответы [ 2 ]

1 голос
/ 10 января 2020

Я бы сделал что-то подобное. Я не тестировал его, но он должен быть закрыт. В основном используйте request.session для отслеживания последнего обновления.

from datetime import datetime

def update_options(request):
    if request.session['last_access'] is None or (datetime.now() - request.session['last_access']).days * 24 * 60 > 30:
        'YOUR CODE HERE'
        request.session['last_access'] = datetime.now()
    else:
        'TOO MANY TRIES'
    return render(request, 'main/update-options.html')
0 голосов
/ 10 января 2020

Я придумал довольно простой способ сделать это, хотя предложенный ответ кажется еще одним вероятным подходом. Я добавил в свою модель поле, которое будет содержать значение 10 минут с момента, когда пользователь публикует обновление. Затем я могу просто сослаться на это поле и проверить, больше ли (позже) текущее время, чем через 10 минут после последнего обновления пользователя.

models.py

class Update(models.Model):
    update = models.IntegerField(null=True, blank=True)
    user = models.ForeignKey(User, on_delete=models.DO_NOTHING)
    date = models.DateTimeField(auto_now=True) # datetime of object creation
    next_allowed_update = models.DateTimeField(
            default=datetime.now()+timedelta(minutes=10)-timedelta(hours=5) # adjust for UTC
        )
    location = models.CharField(max_length=30, default='none')

views.py

@login_required
def update_options(request):
    # user can only update once every 10 minutes : 10 set in model
    user_latest_update = Update.objects.filter(user=request.user).latest('id')
    current_time = datetime.now().replace(tzinfo=None)   
    next_allowed_update = user_latest_update.next_allowed_update.replace(tzinfo=None)

    remaining = str(next_allowed_update - current_time).split(':')
    minutes_remaining = int(remaining[1].lstrip("0")) + 1
    if current_time > next_allowed_update:
        return render(request, 'main/update-options.html')
    else:
        return render(request, 'main/update-denied.html', {'time_remaining': minutes_remaining})

template

{% extends "main/base.html" %}

{% block content %}
<div class="container">
    <h1>You can update again in {{ time_remaining }} minute</h1>
</div>
{% endblock content %}

Это решение также позволяет отображать представление и передавать значение, показывающее, сколько минут пользователь может сделать еще одно обновление

...