forked from albertkun/flaskmap
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.2.py
115 lines (94 loc) · 4.07 KB
/
app.2.py
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
#from config import *
from flask import Flask, jsonify, render_template, request
import simplejson
from playhouse.shortcuts import model_to_dict, dict_to_model
from flask_marshmallow import Marshmallow
from flask_sqlalchemy import SQLAlchemy
# define the app here
app = Flask(__name__)
# here is the marshmallow app definition for the api
ma = Marshmallow(app)
# bring in the table models
from models import *
### api schema begins here ###
class bookingSchema(ma.Schema):
class Meta:
# Fields to expose through api
# fields = ('fid', 'desc_', 'slug','sex','home_addre','x','y')
fields = ('booking_nu','sex','race','charge','charge_des','charge_lev','bail','year','longitude','latitude','slug','age_categories')
json_module = simplejson
bookings_schema = bookingSchema(many=True)
class raceSchema(ma.Schema):
class Meta:
# Fields to expose through api
# fields = ('fid', 'desc_', 'slug','sex','home_addre','x','y')
fields = ('race','count')
json_module = simplejson
race_schema = raceSchema()
races_schema = raceSchema(many=True)
### api schema ends here ###
# def basicQuery():
# global bookings
# global neighborhoods
# bookings = lapd.select()
# # neighborhoods = lapd.select(lapd.slug).distinct().order_by(lapd.slug.asc())
# neighborhoods = lapd.select(lapd.slug).distinct().order_by(lapd.slug.asc())
# # bookings = lapd.select().where(lapd.slug == "downtown")
@app.route('/')
def index():
# basicQuery()
neighborhoods = lasd.select(lasd.slug).distinct().order_by(lasd.slug.asc())
return render_template('index.html',neighborhoods = neighborhoods)
# bookings = lapd.select().where(lapd.slug == "downtown")
# count = lapd.select().where(lapd.slug == "downtown").count()
# @app.route('/<slug>')
# def slug(slug=None):
# basicQuery()
# bookings = lapd.select().where(lapd.slug == slug)
# count = lapd.select().where(lapd.slug == slug).count()
# return render_template('index.html',bookings=bookings,count=count,neighborhoods = neighborhoods)
# @app.route("/<slug>/<year>/bookings/", methods=['GET'])
# def get_bookings(slug,year):
# all_bookings = lasd.select().where(lasd.slug == slug,lasd.year==year)
# # all_bookings = lasd.select().where(lasd.slug == slug)
# result = bookings_schema.dump(all_bookings)
# return jsonify(result.data)
@app.route("/bookings/<lat>/<lng>/<distance>", methods=['GET'])
def get_bookings_by_distance(lat,lng,distance):
all_bookings = lasd.select().where(ST_DWithin(geom,ST_GeogFromText('POINT(lng lat)'),distance,false))
# all_bookings = lasd.select().where(lasd.slug == slug)
result = bookings_schema.dump(all_bookings)
return jsonify(result.data)
@app.route("/<slug>/bookings/", methods=['GET'])
def get_bookings(slug):
all_bookings = lasd.select().where(lasd.slug == slug)
# all_bookings = lasd.select().where(lasd.slug == slug)
result = bookings_schema.dump(all_bookings)
return jsonify(result.data)
@app.route("/<slug>/<year>/race/", methods=['GET'])
def get_race(slug,year):
all_bookings = lasd.select(lasd.race,fn.COUNT(lasd.race)).where(lasd.slug == slug,lasd.year==year).group_by(lasd.race)
# all_bookings = lasd.select().where(lasd.slug == slug)
result = races_schema.dump(all_bookings)
return jsonify(result.data)
### not needed anymore ###
# @app.route('/_neighborhood')
# def neighborhood():
# slug = request.args.get('slug')
# # return slug
# bookings = lapd.select().where(lapd.slug == slug)
# # json_data = json.dumps(model_to_dict(bookings))
# # return json_data
# # return jsonify(model_to_dict(bookings))
# return BinaryJSONField({'rows':[model_to_dict(booking) for booking in bookings]})
@app.route('/_add_numbers')
def add_numbers():
a = request.args.get('a', 0, type=int)
b = request.args.get('b', 0, type=int)
return jsonify(result=a + b)
# @app.route('/info')
# def info():
# basicQuery()
# return render_template('info.html', events=events)
if __name__ == '__main__':
app.run(debug=True)