-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathapp.py
More file actions
executable file
·64 lines (51 loc) · 1.71 KB
/
app.py
File metadata and controls
executable file
·64 lines (51 loc) · 1.71 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
import json
from flask import Flask, request, jsonify
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker
from database import Base, User, Item
# declare constants
HOST = '0.0.0.0'
PORT = 5000
# connect to database
engine = create_engine('sqlite:///sample.db')
Base.metadata.bind = engine
# create database session
DBSession = sessionmaker(bind=engine)
session = DBSession()
# initialize flask application
app = Flask(__name__)
# sample hello world page
@app.route('/')
def hello():
return "<h1>Hello World</h1>"
# sample api endpoint to get all users
@app.route('/api/users')
def get_users():
users = session.query(User).all()
return jsonify(status=200, users=[i.serialize for i in users])
# sample api endpoint for items
@app.route('/api/users/<int:user_id>/items', methods=['GET', 'POST'])
def get_items(user_id):
if request.method == 'POST':
# get data from post request
data = request.get_json()
if data.keys() >= {'name', 'description'}:
# create new item
new_item = Item(user_id=user_id,
name=data['name'],
description=data['description'])
session.add(new_item)
session.commit()
# return success status and new item
return jsonify(status=201, item=new_item.serialize)
else:
# return error status
return jsonify(status=400)
else:
# get all items for user
items = session.query(Item).filter_by(user_id=user_id).all()
return jsonify(status=200, items=[i.serialize for i in items])
if __name__ == '__main__':
app.run(host=HOST,
debug=True,
port=PORT)