-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.py
47 lines (35 loc) · 1.56 KB
/
app.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
from flask import Blueprint
main = Blueprint('main', __name__)
import json
from engine import RecommendationEngine
import logging
logging.basicConfig(level=logging.INFO)
logger = logging.getLogger(__name__)
from flask import Flask, request
@main.after_request
def after_request(response):
response.headers.add('Access-Control-Allow-Origin', '*')
response.headers.add('Access-Control-Allow-Headers', 'Content-Type,Authorization')
response.headers.add('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE,OPTIONS')
return response
@main.route("/<int:user_id>/ratings/top/<int:count>", methods=["GET"])
def top_ratings(user_id, count):
logger.debug("User %s TOP ratings requested", user_id)
top_ratings = recommendation_engine.get_top_ratings(user_id,count)
return json.dumps(top_ratings)
@main.route("/ratings", methods = ["POST"])
def add_ratings():
# get the ratings from the Flask POST request object
ratings_list = request.get_json().get('ratings')
# create a list with the format required by the engine (user_id, game_id, rating)
ratings = map(lambda x: (1, int(x['id']), float(x['rating'])), ratings_list)
# add them to the model using then engine API
recommendation_engine.add_ratings(ratings)
top_ratings = recommendation_engine.get_top_ratings(1,10)
return json.dumps(top_ratings)
def create_app(spark_context, dataset_path):
global recommendation_engine
recommendation_engine = RecommendationEngine(spark_context, dataset_path)
app = Flask(__name__)
app.register_blueprint(main)
return app