#!/usr/bin/python
#
# Flask server, woo!
#
import json

from flask import Flask, jsonify, request
from flask.json import JSONEncoder

from DLIObject import DLIObject, DLIRelation
from DLIQueryResolver import QueryResolver
from logger import dlilogger


class MyJSONEncoder(JSONEncoder):
    def default(self, obj):
        if isinstance(obj, DLIObject):
            return obj.__dict__
        if isinstance(obj, DLIRelation):
            return obj.__dict__
        return super(MyJSONEncoder, self).default(obj)


app = Flask(__name__)
app.debug = False
app.json_encoder = MyJSONEncoder

host = "http://node0-p-dli.d4science.org:8983/solr/DLIF-index-cleaned_shard1_replica1"


# q = QueryResolver("http://localhost:8983/solr/DLIF-index-cleaned_shard1_replica1")

class InvalidUsage(Exception):
    status_code = 400

    def __init__(self, message, status_code=None, payload=None):
        Exception.__init__(self)
        self.message = message
        if status_code is not None:
            self.status_code = status_code
        self.payload = payload

    def to_dict(self):
        rv = dict(self.payload or ())
        rv['message'] = self.message
        return rv


# Routes
@app.route('/')
def root():
    return app.send_static_file('index.html')


@app.route('/<path:path>')
def static_proxy(path):
    # send_static_file will guess the correct MIME type
    return app.send_static_file(path)


@app.route('/api/item/<path:identifier>', methods=['post', 'get'])
def getItem(identifier):
    if identifier:
        q = QueryResolver(host)
        return jsonify(result=q.get_item(identifier))
    else:
        raise InvalidUsage('This view is gone', status_code=410)


@app.route('/api/stats/', methods=['post', 'get'])
def stats():
    q = QueryResolver(host)
    return jsonify(stats=q.get_stats())


@app.route('/api/stats_detail/', methods=['post', 'get'])
def stats_detail():
    q = QueryResolver(host)
    return jsonify(stats=q.get_stats_detail())


@app.route('/api/post/', methods=['post', 'get'])
def query_post():
    action = None
    query = None
    only_result = False
    filter_query = None
    start = 0
    if 'action' in request.form:
        action = request.form['action']
    if 'query' in request.form:
        query = request.form['query']
    if 'only_result' in request.form:
        only_result = True

    if 'browse_field' in request.form:
        try:
            filter_query = json.loads(request.form['browse_field'])
        except:
            app.logger.error("Unable to parse browse_field, current value %s" % request.form['browse_field'])

    if 'start' in request.form:
        start = int(request.form['start'])

    if action == 'query' and query is not None:
        q = QueryResolver(host)
        result = q.query(q=query, browse_fields=["entitytype", "provenance"], start=start, only_result=only_result,
                         filter_query=filter_query)
        return jsonify(result=result)
    else:
        return jsonify(error={'error_code': 'an error occur during query on server'})


if __name__ == '__main__':
    app.logger.addHandler(dlilogger)
    app.run(debug=False, host='0.0.0.0', processes=5)
