finfree-be/routes/conditions.py

64 lines
2.3 KiB
Python

from flask import jsonify, request, redirect, render_template
import rethinkdb as r
table_name = 'conditions'
route = table_name
def create_conditions_routes(app, r, conn):
# Create a table (if not exists)
if table_name not in r.table_list().run(conn):
r.table_create(table_name).run(conn)
# Routes for CRUD operations
# Create operation
@app.route('/' + route + '/create', methods=['GET'])
def create_form():
return render_template('conditions/create.html')
@app.route('/' + route, methods=['POST'])
def create_condition():
if request.headers['Content-Type'] == 'application/json':
data = request.json
else: # Assuming form data is in 'application/x-www-form-urlencoded' format
data = request.form.to_dict()
result = r.table(table_name).insert(data).run(conn)
return redirect(request.referrer or url_for('index'))
# Read operation
@app.route('/' + route, methods=['GET'])
def get_conditions():
cursor = r.table(table_name).run(conn)
conditions = list(cursor)
return jsonify(conditions)
@app.route('/' + route + '/<id>', methods=['GET'])
def get_condition(id):
cursor = r.table(table_name).get(id).run(conn)
json = jsonify(cursor)
if request.headers.get('Content-Type') == 'application/json':
return json
else:
return render_template('conditions/update.html', data=cursor)
# Update operation
@app.route('/' + route + '/<id>', methods=['POST'])
def update_condition(id):
if request.headers['Content-Type'] == 'application/json':
data = request.json
else:
data = request.form.to_dict()
r.table(table_name).get(id).update(data).run(conn)
return "<script>window.close();</script>"
# Delete operation
@app.route('/' + route + '/delete/<id>', methods=['POST'])
def delete_post(id):
r.table(table_name).get(id).delete().run(conn)
return jsonify({'message': 'condition deleted successfully'})
@app.route('/' + route + '/<id>', methods=['DELETE'])
def delete_condition(id):
r.table(table_name).get(id).delete().run(conn)
return jsonify({'message': 'condition deleted successfully'})