Редактирование книг
This commit is contained in:
@@ -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
|
||||||
|
|||||||
@@ -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 %}
|
||||||
|
|||||||
9
bookify/books/templates/books/edit_book.html
Normal file
9
bookify/books/templates/books/edit_book.html
Normal 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 %}
|
||||||
@@ -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"),
|
||||||
]
|
]
|
||||||
|
|||||||
@@ -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):
|
||||||
"""Добавление новой книги (только авторизованный пользователь)."""
|
"""Добавление новой книги (только авторизованный пользователь)."""
|
||||||
|
|||||||
Reference in New Issue
Block a user