open-law/app/forms/book.py

41 lines
1.2 KiB
Python
Raw Normal View History

2023-04-24 09:57:38 +03:00
from flask_wtf import FlaskForm
2023-05-02 09:48:10 +03:00
from wtforms import StringField, SubmitField, ValidationError
2023-04-24 09:57:38 +03:00
from wtforms.validators import DataRequired, Length
2023-05-02 09:48:10 +03:00
from app import models as m, db
from app.logger import log
2023-04-24 09:57:38 +03:00
2023-05-01 18:17:46 +03:00
class BaseBookForm(FlaskForm):
2023-04-27 16:17:25 +03:00
label = StringField("Label", [DataRequired(), Length(6, 256)])
2023-05-01 18:17:46 +03:00
class CreateBookForm(BaseBookForm):
2023-04-24 09:57:38 +03:00
submit = SubmitField("Add new book")
2023-05-01 18:17:46 +03:00
class EditBookForm(BaseBookForm):
2023-05-02 09:48:10 +03:00
book_id = StringField("User ID", [DataRequired()])
2023-05-01 18:17:46 +03:00
submit = SubmitField("Edit book")
2023-05-02 09:48:10 +03:00
def validate_book_id(self, field):
book_id = field.data
book: m.Book = db.session.get(m.Book, book_id)
if not book or book.is_deleted:
log(log.WARNING, "Book with id [%s] not found", book_id)
raise ValidationError("Book not found")
def validate_label(self, field):
label = field.data
book_id = self.book_id.data
existing_book: m.Book = m.Book.query.filter_by(
is_deleted=False,
label=label,
).first()
if existing_book:
log(
log.WARNING, "Book with label [%s] already exists: [%s]", label, book_id
)
raise ValidationError("Book label must be unique!")