Skip to content

Instantly share code, notes, and snippets.

@boolbag
Created August 22, 2015 05:35
Show Gist options
  • Save boolbag/61ecf048b7f08964b956 to your computer and use it in GitHub Desktop.
Save boolbag/61ecf048b7f08964b956 to your computer and use it in GitHub Desktop.
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from sqlalchemy import String, text
import flask_admin as admin
from flask_admin.contrib import sqla
# Create application
app = Flask(__name__)
# Create dummy secrey key so we can use sessions
app.config['SECRET_KEY'] = '123456790'
# Create in-memory database
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///a_sample_database.sqlite'
app.config['SQLALCHEMY_ECHO'] = True
db = SQLAlchemy(app)
# Flask views
@app.route('/')
def index():
return '<a href="/admin/">Click me to get to Admin!</a>'
class Pet(db.Model):
__tablename__ = 'pet'
id = db.Column(db.Integer, primary_key=True, autoincrement=True)
petname = db.Column(String(20), nullable=False, unique=True)
nickname = db.Column(String(20), nullable=False,)
notes = db.Column(String(20), nullable=False, server_default=text("''"))
class PetAdmin(sqla.ModelView):
column_editable_list = ('petname', 'nickname')
# Create admin
admin = admin.Admin(app, name='Not Nullable Empty Issue', template_mode='bootstrap3')
admin.add_view(PetAdmin(Pet, db.session))
if __name__ == '__main__':
# Create DB
db.drop_all()
db.create_all()
db.session.add(Pet(petname='Flipper', nickname='Flee'))
db.session.add(Pet(petname='Lassie', nickname=''))
db.session.add(Pet(petname='Jumbo', nickname=''))
db.session.commit()
# Start app
app.run(debug=True)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment