1
from flask import Flask
2
from flask import request
3
from flask import render_template, url_for
4
from flask import make_response
5
from flask import jsonify
6
import logging
7
from logging import FileHandler
8
import pymongo
9
import os
10
import lxml.html
11
import urllib2
12
import StringIO
13
import json
14
import urllib
15
16
import conf
17
import sweetmaker
18
19
app = Flask(__name__)
20
21
SWEET_STORE_URL = conf.SWEET_STORE_URL
22
23
24
@app.route('/', methods=['GET'])
25
def index():
26
    if request.args.has_key('url'):
27
        return render_template('index.html', url=request.args['url'])
28
    else:
29
        return render_template('index.html')
30
31
32
@app.route('/fetch', methods=['GET'])
33
def fetch():
34
    connection = pymongo.Connection()
35
    db = connection['mural']
36
    collection = db['data']
37
    ret = {}
38
    x = 0
39
    resource = "default"
40
    if request.args.has_key('uri'):
41
        resource = request.args['uri']
42
    for i in collection.find({'uri':resource}):
43
        del(i['_id'])
44
        ret[x] = i
45
        x = x + 1
46
    else:
47
        for i in collection.find():
48
            del(i['_id'])
49
            ret[x] = i
50
            x = x + 1
51
    if len(ret) == 0:
52
        ret['error'] = "Sorry! No re-treats for you."
53
    return jsonify(ret)
54
55
@app.route('/sweets', methods=['GET'])
56
def displaySweet():
57
    return render_template('sweets.html')
58
59
@app.route('/search', methods=['GET'])
60
def search():
61
    connection = pymongo.Connection()
62
    db = connection['mural']
63
    collection = db['data']
64
    y = 0
65
    ret = {}
66
    keywords_dict = json.loads(request.args['data'])
67
    #keywords = json.loads(keywords_dict)['data']
68
    if 'nodes' in keywords_dict:
69
        for i in collection.find():
70
            try:
71
                if 'how' in i:
72
                    i['nodes'] = i['how']
73
            except:
74
                pass
75
            for node in keywords_dict['nodes']:
76
                try:
77
                    if node in i['nodes']:
78
                        del(i['_id'])
79
                        ret[y] = i
80
                        y = y + 1
81
                except:
82
                    pass
83
    elif 'where' in keywords_dict:
84
        for i in collection.find({'uri': keywords_dict['where']}):
85
            del(i['_id'])
86
            ret[y] = i
87
            y = y + 1
88
        for i in collection.find({'where': {'$regex':\
89
                                            keywords_dict['where']}}):
90
            del(i['_id'])
91
            ret[y] = i
92
            y = y + 1
93
94
    return render_template('blank.html', content = ret, flag =\
95
                           request.args['flag'])
96
97
98
@app.route('/submit', methods=['POST'])
99
def submit():
100
    c = pymongo.Connection()
101
    db = c['mural']
102
    coll = db['data']
103
    requestData = json.loads(request.form['data'])
104
    try:
105
        for i in requestData:
106
            coll.insert(i)
107
        print 'inserted'
108
        print requestData
109
        response = make_response()
110
        response.headers['Access-Control-Allow-Origin'] = '*'
111
        response.status_code = 200
112
        for i in requestData:
113
            del(i['_id'])
114
            i['how'] = '{concepts: ' + ', '.join(i['how']) + '}'
115
            #i['how'] = attribs
116
        print 'payload for sweet'
117
        print requestData
118
        sweetmaker.sweet(SWEET_STORE_URL, requestData)
119
    except:
120
        response = make_response()
121
        response.status_code = 500
122
        response.data = "Your post could not be saved. Try posting again."
123
124
    return response
125
126
127
@app.route('/web/', methods=['GET'])
128
def web():
129
  return render_template('web.html')
130
131
@app.route('/SWeeText', methods=['GET'])
132
def SWeeText():
133
    if request.args.has_key('url'):
134
        # Log -- comment them
135
        print "Got URL " + request.args['url'] + " .. Fetching and Parsing.."
136
        myhandler1 = urllib2.Request(request.args['url'], headers={'User-Agent': "Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:20.0) Gecko/20100101 Firefox/20.0"})
137
        a = urllib2.urlopen(myhandler1)
138
        page = a.read()
139
        a.close()
140
        try:
141
            page = unicode(page, 'utf-8')
142
        except UnicodeDecodeError:
143
            pass
144
        root = lxml.html.parse(StringIO.StringIO(page)).getroot()
145
        root.make_links_absolute(request.args['url'], resolve_base_href = True)
146
        # Log -- comment them
147
        #print "Page parsed.. Preparing to send.."
148
149
        # inject the JS toolbar to annotate text
150
        jq = root.makeelement('script')
151
        jq.set('src', url_for('static', filename='jquery-1.9.1.min.js'))
152
153
        script = root.makeelement('script')
154
        script.set('src', url_for('static', filename='text-annotation.js'))
155
156
157
        config_script = root.makeelement('script')
158
        config_script.set('src', url_for('static', filename='config.js'))
159
160
        tree = root.makeelement('script')
161
        tree.set('src', url_for('static', filename='tree.js'))
162
163
        bs_js = root.makeelement('script')
164
        bs_js.set('src', url_for('static', filename='bootstrap.js'))
165
166
        jit = root.makeelement('script')
167
        jit.set('src', url_for('static', filename='jit.js'))
168
169
        us = root.makeelement('script')
170
        us.set('src', url_for('static', filename='underscore-min-1.4.4.js'))
171
172
        link = root.makeelement('link')
173
        link.set('href', url_for('static', filename='text-annotation.css'))
174
        link.set('type', 'text/css')
175
        link.set('rel', 'stylesheet')
176
177
        bs = root.makeelement('link')
178
        bs.set('href', url_for('static', filename='bootstrap.css'))
179
        bs.set('type', 'text/css')
180
        bs.set('rel', 'stylesheet')
181
182
        tree_css = root.makeelement('link')
183
        tree_css.set('href', url_for('static', filename='tree.css'))
184
        tree_css.set('type', 'text/css')
185
        tree_css.set('rel', 'stylesheet')
186
187
        root.head.append(bs)
188
        root.head.append(link)
189
        root.head.append(tree_css)
190
191
        root.head.append(jq)
192
        root.head.append(bs_js)
193
        root.head.append(jit)
194
        root.head.append(us)
195
        root.head.append(tree)
196
        root.head.append(script)
197
        root.head.append(config_script)
198
199
        return lxml.html.tostring(root)
200
201
202
#Log the errors, don't depend on apache to log it for you.
203
    fil = FileHandler(os.path.join(os.path.dirname(__file__), 'logme'),mode='a')
204
    fil.setLevel(logging.ERROR)
205
    app.logger.addHandler(fil)
206
207
208
if __name__ == "__main__":
209
    app.run(debug=True, host='0.0.0.0')