71 lines
1.6 KiB
Python
71 lines
1.6 KiB
Python
from flask import Flask, abort, request
|
|
app = Flask(__name__)
|
|
|
|
import ldap_functions
|
|
import secrets
|
|
|
|
HTTP_UNAUTHORIZED = 401
|
|
|
|
def check_auth():
|
|
auth_header = request.headers.get('Authorization', '')
|
|
if auth_header != 'Token ' + secrets.AUTH_TOKEN:
|
|
abort(HTTP_UNAUTHORIZED)
|
|
|
|
@app.route('/')
|
|
def index():
|
|
return '<i>SEE YOU SPACE SAMURAI...</i>'
|
|
|
|
@app.route('/find-user', methods=['POST'])
|
|
def find_user():
|
|
check_auth()
|
|
|
|
username = request.form['username']
|
|
|
|
return ldap_functions.find_user(username)
|
|
|
|
@app.route('/create-user', methods=['POST'])
|
|
def create_user():
|
|
check_auth()
|
|
|
|
first = request.form['first']
|
|
last = request.form['last']
|
|
username = request.form['username']
|
|
email = request.form['email']
|
|
password = request.form['password']
|
|
|
|
ldap_functions.create_user(first, last, username, email, password)
|
|
return ''
|
|
|
|
@app.route('/set-password', methods=['POST'])
|
|
def set_password():
|
|
check_auth()
|
|
|
|
username = request.form['username']
|
|
password = request.form['password']
|
|
|
|
ldap_functions.set_password(username, password)
|
|
return ''
|
|
|
|
@app.route('/add-to-group', methods=['POST'])
|
|
def add_to_group():
|
|
check_auth()
|
|
|
|
groupname = request.form['groupname']
|
|
username = request.form['username']
|
|
|
|
ldap_functions.add_to_group(groupname, username)
|
|
return ''
|
|
|
|
@app.route('/remove-from-group', methods=['POST'])
|
|
def remove_from_group():
|
|
check_auth()
|
|
|
|
groupname = request.form['groupname']
|
|
username = request.form['username']
|
|
|
|
ldap_functions.remove_from_group(groupname, username)
|
|
return ''
|
|
|
|
if __name__ == '__main__':
|
|
app.run(debug=True, host='0.0.0.0')
|