-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.py
120 lines (86 loc) · 2.51 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
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
116
117
118
119
120
import sqlite3
from flask import Flask, flash, jsonify, render_template, request
app = Flask(__name__)
app.secret_key = '#$%1RTY2^&3FGh4%^&*{"5)(iukVT^ioIo_\{\:DFDFHJHkjn})'
DATABASE_NAME = "flask_ajax_db"
@app.route('/', methods=['GET', 'POST'])
def index():
return render_template('app.html')
@app.route('/insert', methods=['POST'])
def insert():
message = "Task not inserted"
result = "Provide first or last name"
status = 0
first_name = request.form.get('firstName', '')
last_name = request.form.get('lastName', '')
try:
conn = sqlite3.connect(DATABASE_NAME)
cur = conn.cursor()
result = cur.execute(
"INSERT INTO `info`(`firstname`, `lastname`) VALUES(?, ?)", (first_name, last_name)).rowcount
conn.commit()
cur.close()
conn.close()
except Exception as e:
print(e)
if first_name or last_name:
message = first_name if first_name else last_name
message += " added"
result = f"{first_name} {last_name}"
status = 1
response_object = {
'result': result,
'status': status
}
flash(message, 'info')
return jsonify(response_object=response_object)
@app.route('/read', methods=['GET', 'POST'])
def read():
message = 'No data'
result = []
status = 0
try:
conn = sqlite3.connect(DATABASE_NAME)
cur = conn.cursor()
result = cur.execute(
"SELECT * FROM `info` ORDER BY `id` DESC").fetchall()
conn.commit()
cur.close()
conn.close()
except Exception as e:
print(e)
if result:
message = ""
status = 1
response_object = {
'result': result,
'status': status
}
flash(message, 'info')
return jsonify(response_object=response_object)
@app.route('/delete/<id>', methods=['DELETE'])
def delete(id):
message = "Task not deleted"
status = 0
result = ''
try:
conn = sqlite3.connect(DATABASE_NAME)
cur = conn.cursor()
result = cur.execute(
"DELETE FROM `info` WHERE `id` = ?", (id, )).rowcount
conn.commit()
cur.close()
conn.close()
except Exception as e:
print(e)
if result > 0:
message = f"Task with id {id} deleted"
status = 1
response_object = {
'result': result,
'status': status
}
flash(message, 'info')
return jsonify(response_object=response_object)
if __name__ == "__main__":
app.run(debug=True)