Я пытаюсь создать простое веб-приложение, используя Python3.4, Flask и MongoEngine.
У меня возникла проблема при попытке создать форму с помощью WTForms.
У меня есть инициализированное приложение MongoEngine, называемое базой данных:
database = MongoEngine(app)
Я создал класс модели под названием Post:
class Post(database.Document):
author = database.StringField(
default='David Y. Stephenson', max_length=255, required=True
)
body = database.StringField(required=True)
comments = database.ListField(
database.EmbeddedDocumentField('Comment')
)
slug = database.StringField(max_length=255, required=True, unique=True)
tease = database.StringField(max_length=255, required=True)
time = database.DateTimeField(
default=datetime.datetime.now, required=True
)
title = database.StringField(max_length=255, required=True, unique=True)
У меня есть маршрут для создания формы с использованием этого класса:
@app.route('/blog/new')
def new():
form = model_form(Post)
return render_template('new_blog.html', form=form)
Когда я запускаю этот маршрут, я получаю TypeError:
TypeError: model must be a mongoengine Document schema
Глядя на код WTForm, кажется, что класс Post должен быть экземпляром MongoEngine BaseDocument
или DocumentMetaclass classes
. Строки 223-224 из /usr/local/lib/python3.4/dist-packages/flask_mongoengine/wtf/orm.py
гласят:
from mongoengine.base import BaseDocument, DocumentMetaclass
if not isinstance(model, (BaseDocument, DocumentMetaclass)):
raise TypeError('model must be a mongoengine Document schema'
Когда я пытаюсь вручную проверить свой класс Post, он кажется DocumentMetaclass
, но не BaseDocument
. Добавление
app.logger.debug(isinstance(Post, mongoengine.base.BaseDocument))
app.logger.debug(isinstance(Post, mongoengine.base.DocumentMetaclass))
в мой код возвращается:
--------------------------------------------------------------------------------
DEBUG in __init__ [__init__.py:57]:
False
--------------------------------------------------------------------------------
--------------------------------------------------------------------------------
DEBUG in __init__ [__init__.py:58]:
True
--------------------------------------------------------------------------------
Что я делаю неправильно?
Полный текст моего файла __init__.py
:
import datetime
from flask import Flask
from flask import render_template
from flask.ext.mongoengine import MongoEngine
from flask.ext.mongoengine.wtf import model_form
import mongoengine.base
app = Flask(__name__)
app.config['MONGODB_SETTINGS'] = {
'db': 'davidystephenson',
'host': 'ds059908.mongolab.com',
'username': 'david',
'password': 'opensecret',
'port': 59908,
}
database = MongoEngine(app)
class Post(database.Document):
author = database.StringField(
default='David Y. Stephenson', max_length=255, required=True
)
body = database.StringField(required=True)
comments = database.ListField(
database.EmbeddedDocumentField('Comment')
)
slug = database.StringField(max_length=255, required=True, unique=True)
tease = database.StringField(max_length=255, required=True)
time = database.DateTimeField(
default=datetime.datetime.now, required=True
)
title = database.StringField(max_length=255, required=True, unique=True)
@app.route('/')
def index():
return render_template('index.html')
@app.route('/blog/')
def blog():
posts = Post.objects.all()
return render_template('blog.html', posts=posts)
@app.route('/blog/<slug>')
def post(slug):
post = Post.objects.get(slug=slug)
return render_template('post.html', post=post)
@app.route('/blog/new')
def new():
app.logger.debug(isinstance(Post, mongoengine.base.BaseDocument))
app.logger.debug(isinstance(Post, mongoengine.base.DocumentMetaclass))
form = model_form(Post)
return render_template('new_blog.html', form=form)
if __name__ == '__main__':
app.run(debug=True)