Редактирование книг

This commit is contained in:
2025-01-16 18:34:40 +03:00
parent 0da6c9efa7
commit 782d9cfbb1
5 changed files with 31 additions and 1 deletions

View File

@@ -25,7 +25,7 @@ SECRET_KEY = "django-insecure-c1_r=$!h*n-@r1u-r#9x*xsgs7$a*2cnr7!c8=+irf!*4@g$$2
# SECURITY WARNING: don't run with debug turned on in production! # SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True DEBUG = True
ALLOWED_HOSTS = ["bookify.tishenko.dev"] ALLOWED_HOSTS = ["127.0.0.1", "bookify.tishenko.dev"]
# Application definition # Application definition

View File

@@ -17,6 +17,7 @@
{% if user.is_authenticated and user == book.created_by %} {% if user.is_authenticated and user == book.created_by %}
<p> <p>
<a href="{% url 'books:edit_book' book.pk %}">Редактировать книгу</a> |
<a class="btn-delete" href="{% url 'books:delete_book' book.pk %}">Удалить книгу</a> <a class="btn-delete" href="{% url 'books:delete_book' book.pk %}">Удалить книгу</a>
</p> </p>
{% endif %} {% endif %}

View File

@@ -0,0 +1,9 @@
{% extends 'books/base.html' %}
{% block content %}
<h2>Редактировать книгу "{{ book.title }}"</h2>
<form method="POST">
{% csrf_token %}
{{ form.as_p }}
<button type="submit">Сохранить</button>
</form>
{% endblock %}

View File

@@ -23,4 +23,5 @@ urlpatterns = [
), ),
path("register/", views.register, name="register"), path("register/", views.register, name="register"),
path("succesful-logout/", views.logout, name="logout"), path("succesful-logout/", views.logout, name="logout"),
path("book/<int:pk>/edit/", views.edit_book, name="edit_book"),
] ]

View File

@@ -43,6 +43,25 @@ def book_detail(request, pk):
) )
@login_required
def edit_book(request, pk):
"""Редактирование книги, только для её создателя."""
book = get_object_or_404(Book, pk=pk)
# Проверяем, что текущий пользователь владелец:
if book.created_by != request.user:
raise PermissionDenied("Вы не можете редактировать чужую книгу.")
if request.method == "POST":
form = BookForm(request.POST, instance=book)
if form.is_valid():
form.save()
return redirect("books:book_detail", pk=book.pk)
else:
form = BookForm(instance=book)
return render(request, "books/edit_book.html", {"form": form, "book": book})
@login_required @login_required
def add_book(request): def add_book(request):
"""Добавление новой книги (только авторизованный пользователь).""" """Добавление новой книги (только авторизованный пользователь)."""