-
Notifications
You must be signed in to change notification settings - Fork 0
/
lookup_variant.py
43 lines (28 loc) · 1.06 KB
/
lookup_variant.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
import sqlite3 as sql
import os
from flask import Flask, render_template, json, request, redirect, url_for
app = Flask(__name__)
@app.route('/')
def main():
return render_template('home.html')
@app.route('/search', methods=["POST"])
def search():
chrom = request.form['chrom']
coord = request.form['coord']
db = request.form['db']
if db.lower() != 'revel':
return "Sorry, only the revel database is supported", 404
if not chrom:
return "Must provide a valid Chromosome", 404
if not coord:
return "Must provide a valid Coordinate", 404
return redirect(url_for("result", chrom=chrom, start=coord))
@app.route('/result/<chrom>/<start>', methods=["GET"])
def result(chrom, start):
conn = sql.connect("REVEL.db")
conn.row_factory = sql.Row
cur = conn.cursor()
rows = cur.execute('SELECT * FROM variants WHERE chrom=? and hg19_pos=?', (chrom, start))
return render_template("result.html", rows=rows, chrom=chrom, start=start)
if __name__ == "__main__":
app.run(host="0.0.0.0", port=5000, debug=True)