diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml new file mode 100644 index 0000000000000000000000000000000000000000..d93cd99a0df80a4d1d81ec102262eaab431cb8b3 --- /dev/null +++ b/.gitlab-ci.yml @@ -0,0 +1,15 @@ +image: "python:3.7" + +before_script: + - python --version + - pip install pylint + +stages: + - lint + +linting: + tags: + - lint + stage: lint + script: + - pylint --ignore=tests.py --max-line-length=120 *.py app diff --git a/app/__init__.py b/app/__init__.py index c30a7f15fe768cea4c82808aeb8b10d79d782177..7995fe2ba022f8fd76b2d3761dc5fb697b688394 100644 --- a/app/__init__.py +++ b/app/__init__.py @@ -3,32 +3,57 @@ # local imports from __future__ import print_function import vars - +import messages # third-party imports import uuid -from flask import Flask, redirect, url_for, request, render_template, flash, session +from flask import Flask, redirect, url_for, request, render_template, flash, session, send_from_directory +from flask_cors import CORS from flask_bootstrap import Bootstrap import random - +import os +import json def create_app(config_name): - app = Flask(__name__) # initialization of the flask app + app = Flask(__name__, static_folder='static') # initialization of the flask app + cors = CORS(app, resources={r"/*": {"origins": vars.cors_allowed_origins}}) Bootstrap(app) # allowing app to use bootstrap + def get_authorized_user(): + username_key = list(filter(lambda key: (request.headers.get(key) is not None), vars.username_key)) + fullname_key = list(filter(lambda key: (request.headers.get(key) is not None), vars.fullname_key)) + email_key = list(filter(lambda key: (request.headers.get(key) is not None), vars.email_key)) + + user = { + "username": (request.headers.get(username_key[0]) if len(username_key) > 0 else None), + "fullname": (request.headers.get(fullname_key[0]) if len(fullname_key) > 0 else None), + "email": (request.headers.get(email_key[0]) if len(email_key) > 0 else None), + } + + return user + @app.route('/', methods=['GET', 'POST']) # initial route to display the reg page def index(): if 'uid' not in session: session['uid']=str(uuid.uuid4()) - if "redir" in request.args and 'return_url' not in session: # check for redir arg in url - session['return_url'] = request.args.get("redir") - elif "redir" not in request.args and 'return_url' not in session: - session['return_url'] = vars.default_referrer - else: - session['return_url'] = request.referrer + if 'user' not in session: + session["user"] = get_authorized_user() + + session['return_url'] = request.args.get('redir', vars.default_referrer) + + return render_template('auth/SignUp.html', room_id=session['uid'], + username=session['user'].get('username'), + fullname=session['user'].get('fullname'), email=session['user'].get('email'), + referrer=session['return_url'], cancel_url=vars.default_referrer, + welcome_msg=messages.welcome_message, + cancel_msg=messages.cancel_message, + error_msg=messages.error_message) + + @app.route('/error_account') + def error_account_create(): + return render_template('errors/error.html', title='account creation failed') - return render_template('auth/SignUp.html', room_id=session['uid'], referrer=session['return_url']) # misc page error catching @app.errorhandler(403) diff --git a/app/static/img/cheaha-logo-a605de0aecd3006b82a5ee30a6d0cb8cd9bf8b7e836296cc293eac746a4c2b11.png b/app/static/img/cheaha-logo-a605de0aecd3006b82a5ee30a6d0cb8cd9bf8b7e836296cc293eac746a4c2b11.png index 3472668aa4cf3857431874b1bc6f10f18ad1e107..884b448de16d2ad760f2d440ad86020d2a0df3eb 100644 Binary files a/app/static/img/cheaha-logo-a605de0aecd3006b82a5ee30a6d0cb8cd9bf8b7e836296cc293eac746a4c2b11.png and b/app/static/img/cheaha-logo-a605de0aecd3006b82a5ee30a6d0cb8cd9bf8b7e836296cc293eac746a4c2b11.png differ diff --git a/app/static/img/logo_svg.svg b/app/static/img/logo_svg.svg new file mode 100644 index 0000000000000000000000000000000000000000..88508a14b488c8f49df15e6a717b6714e60542f1 --- /dev/null +++ b/app/static/img/logo_svg.svg @@ -0,0 +1 @@ +<svg id="Layer_1" data-name="Layer 1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 300 157"><title>Supercomputer-logo</title><image width="300" height="157" xlink:href=""/></svg> \ No newline at end of file diff --git a/app/static/scripts/function.js b/app/static/scripts/function.js index 694ff191aaa2e9a4221412f1489f31ee84878ac1..77bd28ad114e8de33d54c031b80018c76b7f3580 100644 --- a/app/static/scripts/function.js +++ b/app/static/scripts/function.js @@ -1,15 +1,53 @@ -function displayloading() { - $('#myModal').modal('show'); +function check() { + var submitButton = document.getElementById("submit"); + let ckbox = document.getElementById('agree'); + submitButton.disabled = !ckbox.checked; +}; + +function displayloading1() { + $('#overlayModal').modal('show'); +} + +function displayloading2() { + $('#overlayModal').modal('hide'); + $('#myModal2').modal('show'); } function request_account() { socket.emit('request account', { fullname: document.getElementById("fullname").value, + email: document.getElementById("email").value, reason: document.getElementById("reason").value, - username: document.getElementById("bid").value + username: document.getElementById("username").value, + aup: document.getElementById("agree").checked }) } -function refresh() { - document.location.reload(true); +function renderDom(title, message, error_msg) { + document.getElementById("form-wrapper").innerHTML = "<h3>" + title + "</h3><br>"; + document.getElementById("form-wrapper").innerHTML += "<p>" + message + "</p><br>"; + if (error_msg !== null ) { + var error_button = document.createElement("BUTTON"); + error_button.innerHTML = 'Read Error Message'; + document.getElementById("form-wrapper").appendChild(error_button); + error_button.onclick = function(){document.getElementById("form-wrapper").innerHTML += "<br>" +error_msg} + } +} + +function autofill_form(username, fullname, email) { + let username_input = document.getElementById("username"); + let fullname_input = document.getElementById("fullname"); + let email_input = document.getElementById("email"); + if ((username.localeCompare("None")) !== 0) { + username_input.value = username; + username_input.disabled = "true"; + } + if ((fullname.localeCompare("None")) !== 0) { + fullname_input.value = fullname; + fullname_input.disabled = "true"; + } + if ((email.localeCompare("None")) !== 0) { + email_input.value = email; + email_input.disabled = "true"; + } } diff --git a/app/templates/auth/SignUp.html b/app/templates/auth/SignUp.html index 891a09a663e1b0ed49f4d0bd2a13840cd8371f2c..bc48390540c0ac03329d895d23aa56d22b42acc7 100644 --- a/app/templates/auth/SignUp.html +++ b/app/templates/auth/SignUp.html @@ -8,45 +8,42 @@ <script> console.info('Room ID: {{ room_id }}'); - var socket = io.connect('http://' + document.domain + ':' + location.port); + var socket = io.connect(); socket.on( 'connect', function() { + autofill_form("{{ username }}", "{{ fullname }}", "{{ email }}"); socket.emit( 'join_room', { referrer: '{{ referrer }}' }); socket.on( 'creating account', function( msg ) { - document.getElementById("error").innerText = ""; - displayloading(); + displayloading2(); }); socket.on( 'account ready', function( msg ) { - $('#myModal').modal('hide'); - alert("Account has been created!"); window.location.replace('{{ referrer }}'); }); - socket.on( 'Account creation failed', function( msg ) { - document.getElementById("error").innerText = "Registration Failed. Please try again."; + socket.on( 'account error', function( msg ) { + console.log(msg); + $('#myModal2').modal('hide'); + renderDom("Account Create Error", "{{ error_msg |safe}}", msg); }); }); </script> - <style type="text/css"> - .important { color: #336699; } - </style> - <link rel="shortcut icon" type="image/x-icon" href="/public/favicon.ico"> +<link rel="shortcut icon" type="image/x-icon" href="/public/favicon.ico"> <link rel="stylesheet" media="all" href="{{ url_for('static', filename='style/application.css') }}"> <link rel="stylesheet" media="all" href="{{ url_for('static', filename='style/app2.css') }}"> <meta name="viewport" content="width=device-width, initial-scale=1"> <style> -.navbar-inverse { - background-color: rgb(0,99,65); -} - + .navbar-inverse { background-color: rgb(0,99,65); } + button{ margin: 13px; + .important { color: #336699; }} </style> + </head> @@ -55,81 +52,100 @@ <nav class="navbar navbar-inverse navbar-static-top"> <div class="container-fluid"> <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-9" aria-expanded="false"> <span class="sr-only">Toggle navigation</span> <span class="icon-bar"></span> <span class="icon-bar"></span> <span class="icon-bar"></span> </button> - <a class="navbar-brand" href="/">Research Computing</a> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-9" aria-expanded="false"> <span class="sr-only">Toggle navigation</span> <span class="icon-bar"></span> <span class="icon-bar"></span> <span class="icon-bar"></span> </button> + <a class="navbar-brand" href="/"> UAB Research Computing</a> </div> <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-9"> - <ul class="nav navbar-nav"> - - </ul> - <div class="navbar-right"> - <ul class="nav navbar-nav"> - <li> - <a target="_blank" href="https://docs.uabgrid.uab.edu/wiki/Cheaha_GettingStarted"> - <i class="fas fa-info-circle fa-fw"></i> Online Documentation - </a></li> - <li> - </li></ul> - </div> + <div class="navbar-right"> + <ul class="nav navbar-nav"> + <li> + <a target="_blank" href="https://docs.uabgrid.uab.edu/wiki/Cheaha_GettingStarted"> + <i class="fas fa-info-circle fa-fw"></i> Online Documentation + </a> + </li> + </ul> + </div> </div> </div> </nav> </header> -<div class="container content" role="main" style="width: 625px"> - - <div style="position:relative;"> - <img alt="logo" height="auto" width="100%" style="margin-bottom: 20px" src="{{ url_for('static', filename='img/cheaha-logo-a605de0aecd3006b82a5ee30a6d0cb8cd9bf8b7e836296cc293eac746a4c2b11.png') }}"> - <a href="https://tinyurl.com/cheahaAL" target="_blank"> - <div style="float:left;position:absolute;display:block;left:310px;top:-6px;padding:10px 20px;"> </div> - </a> -</div> - -<!-- <h2>Hello, <span id="username">{{ user }}</span>!</h2> --> - - <h2>Hi, </h2> - <div id="test"> - <form action="." method="post" onsubmit=""> - <div class="signUpContainer"> - <label><b><label for="username">Blazer Id: </label><br></b></label> - <input class="form-control" id="bid" name="bid" placeholder="Enter BlazerId" required="" type="text"> - <label><b><label for="fullname">Full Name: </label><br></b></label> - <input class="form-control" id="fullname" name="fullname" placeholder="Enter Full Name" required="" type="text"> - <label><b><label for="reason">Reason for Requesting Account: </label><br></b></label> - <textarea class="form-control" id="reason" name="reason" placeholder="Enter Reason for Account Request" required=""></textarea> - <input class="btn btn-primary btn-block" id="submit" name="submit" type="button" value="Submit" onclick="request_account()"> - - <div> - <strong id="error" style="color: #be051b; text-align: center;"></strong> - </div> +<div class="container content" role="main" style="width: 100%"> + <div class="col-md-2 col-sm-2 my-col"> + <img alt="logo" height="auto" width="80%" src="{{ url_for('static', filename='img/logo_svg.svg') }}"> + <a href="https://tinyurl.com/cheahaAL" target="_blank"></a> + </div> + + <div class="col-md-10 col-sm-10 my-col"> + <div id="form-wrapper"> + <h2>Welcome to UAB Research Computing</h2> + <p style="font-size:110%;"> {{ welcome_msg |safe }}</p> + <div id="user-input"> + <form id="signup" data-toggle="validator" role="form" action="." method="post" onsubmit=""> + <div class="col-md-7 col-sm-7 my-col"> + <label for="username" class="control-label">Blazer Id:</label>	<input id="username" class="form-control" placeholder="Enter Username" required><br> + </div> + <div class="col-md-7 col-sm-7 my-col"> + <label for="fullname" class="control-label">Full Name:</label>	<input id="fullname" class="form-control" placeholder="Enter Full Name" required><br> + </div> + <div class="col-md-7 col-sm-7 my-col"> + <label for="email" class="control-label">Email:</label>	<input id="email" class="form-control" placeholder="Enter Email" required><br> + </div> + <div class="col-md-7 col-sm-7 my-col"> + <label for="reason" class="control-label">Reason for Requesting Account:</label><br> + <textarea class="form-control" id="reason" name="reason" placeholder="Enter Reason for Account Request" required></textarea> + </div> + <br> + <div class="col-md-7 col-sm-7 my-col"> + <br><input class="checks" id ="agree" type="checkbox" name="agree" value="agree" onchange= check() />Agree to proceed<br/> + <button class="btn btn-danger btn-md" id="cancel" name="cancel" type="button" onClick="renderDom('Account Creation Cancelled','{{ cancel_msg |safe }}', null)">Cancel</button> + <button class="btn btn-primary btn-md" disabled id="submit" name="submit" type="button" value="Submit" onclick="displayloading1();request_account()"> Create Account</button> + </div> + </form> </div> - </form> </div> + </div> +</div> + +<div class="modal fade" id="overlayModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false"> + <div class="modal-dialog modal-sm" role="document"> + <div class="modal-content"> + <div class="modal-header"> + <h4 class="modal-title" id="myModalLabel">Account Request Received!</h4> + </div> + <div class="modal-body"> + <span>Communicating this information to the server</span> + <img src="{{ url_for('static', filename='img/loading.gif') }}" width="40px"> + </div> </div> + </div> +</div> - <div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false"> - <div class="modal-dialog modal-sm" role="document"> - <div class="modal-content"> - <div class="modal-header"> - <h4 class="modal-title" id="myModalLabel">Account Request Received!</h4> - </div> - <div class="modal-body"> - <span>Please wait while we create your account. This may take up to 5-10 minutes.</span> - <img src="{{ url_for('static', filename='img/loading.gif') }}" width="40px"> - </div> - </div> - </div> +<div class="modal fade" id="myModal2" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false"> + <div class="modal-dialog modal-sm" role="document"> + <div class="modal-content"> + <div class="modal-header"> + <h4 class="modal-title" id="myModalLabel">Account Request Received!</h4> + </div> + <div class="modal-body"> + <span>Sit tight while we create your account.</span> + <img src="{{ url_for('static', filename='img/loading.gif') }}" width="40px"> + </div> </div> + </div> +</div> + <footer> <div class="container-fluid"> <div class="row"> <div class="col-md-6 col-sm-6"> - <a href="https://osc.github.io/Open-OnDemand/"> - <img class="footer-logo" alt="Powered by Open OnDemand" height="40" style="margin-bottom: 20px" src="{{ url_for('static', filename='img/OpenOnDemand_powered_by_RGB-cb3aad5ff5350c7994f250fb334ddcc72e343233ce99eb71fda93beddd76a847.svg') }}"> + <a href="https://osc.github.io/Open-OnDemand/"> + <img class="footer-logo" alt="Powered by Open OnDemand" height="40" style="margin-bottom: 20px" src="{{ url_for('static', filename='img/OpenOnDemand_powered_by_RGB-cb3aad5ff5350c7994f250fb334ddcc72e343233ce99eb71fda93beddd76a847.svg') }}"> </a> </div> </div> - </div><!-- /.container --> + </div> </footer> + </body> </html> diff --git a/app/templates/errors/error.html b/app/templates/errors/error.html new file mode 100644 index 0000000000000000000000000000000000000000..32933b0fb1292bf5cc94c3c35866e61447bb749d --- /dev/null +++ b/app/templates/errors/error.html @@ -0,0 +1,55 @@ +<html class="gr__rc_uab_edu"> +<title>User Registration Error</title> +<head> +<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/socket.io/1.7.3/socket.io.min.js"></script> +<script src="https://stackpath.bootstrapcdn.com/bootstrap/3.4.1/js/bootstrap.min.js" integrity="sha384-aJ21OjlMXNL5UyIl/XNwTMqvzeRMZH2w8c5cRVpzpU8Y5bApTppSuUkhZXN0VxHd" crossorigin="anonymous"></script> +<script src="{{ url_for('static', filename='scripts/function.js') }}"></script> + +<script> + + +</script> + + <style type="text/css"> + .important { color: #336699; } + </style> + <link rel="shortcut icon" type="image/x-icon" href="/public/favicon.ico"> +<link rel="stylesheet" media="all" href="{{ url_for('static', filename='style/application.css') }}"> +<link rel="stylesheet" media="all" href="{{ url_for('static', filename='style/app2.css') }}"> + +<meta name="viewport" content="width=device-width, initial-scale=1"> +<style> +.navbar-inverse { + background-color: rgb(0,99,65); +} + +</style> +</head> + + +<body data-gr-c-s-loaded="true"> + + +<div class="container content" role="main" style="width: 625px"> + + <div style="position:relative;"> + <img alt="logo" height="auto" width="100%" style="margin-bottom: 20px" src="{{ url_for('static', filename='img/cheaha-logo-a605de0aecd3006b82a5ee30a6d0cb8cd9bf8b7e836296cc293eac746a4c2b11.png') }}"> + <a href="https://tinyurl.com/cheahaAL" target="_blank"> + <div style="float:left;position:absolute;display:block;left:310px;top:-6px;padding:10px 20px;"> </div> + </a> +</div> + +<footer> + <div class="container-fluid"> + <div class="row"> + <div class="col-md-6 col-sm-6"> + <a href="https://osc.github.io/Open-OnDemand/"> + <img class="footer-logo" alt="Powered by Open OnDemand" height="40" style="margin-bottom: 20px" src="{{ url_for('static', filename='img/OpenOnDemand_powered_by_RGB-cb3aad5ff5350c7994f250fb334ddcc72e343233ce99eb71fda93beddd76a847.svg') }}"> + </a> + </div> + </div> + </div><!-- /.container --> +</footer> +</body> +</html> diff --git a/app/templates/errors/registration_failed.html b/app/templates/errors/registration_failed.html index 8386d4b87fc925632b9b5e616fd77e292ba5604c..8e506156a43804ee85162b9a9eb119a1910327dd 100644 --- a/app/templates/errors/registration_failed.html +++ b/app/templates/errors/registration_failed.html @@ -7,8 +7,5 @@ <body> <h2>Something went right...</h2> - <p> - Redirecting back to sign-in page in 5 seconds. - </p> </body> -</html> \ No newline at end of file +</html> diff --git a/logo_svg.svg b/logo_svg.svg new file mode 100644 index 0000000000000000000000000000000000000000..88508a14b488c8f49df15e6a717b6714e60542f1 --- /dev/null +++ b/logo_svg.svg @@ -0,0 +1 @@ +<svg id="Layer_1" data-name="Layer 1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 300 157"><title>Supercomputer-logo</title><image width="300" height="157" xlink:href=""/></svg> \ No newline at end of file diff --git a/messages.py b/messages.py new file mode 100644 index 0000000000000000000000000000000000000000..f4dfbf0b3c8f47f2a5e46fe4cec804f13e14f23b --- /dev/null +++ b/messages.py @@ -0,0 +1,3 @@ +welcome_message = "The information below will be used to create your account. Please fill in the reason for requesting your account as this helps us understand our user base.<br>Contact <a href='mailto:support@listserv.uab.edu'>Research Computing</a> if you have any questions." +cancel_message = "Close current tab to end session.<br>Contact <a href="'mailto:support@listserv.uab.edu'">Research Computing</a> if you have any questions." +error_message = "An error occurred while creating your account. Research Computing team has been notified and is working on fixing it.<br>Contact <a href='mailto:support@listserv.uab.edu'>Research Computing</a> if you have any questions." diff --git a/requirements.txt b/requirements.txt index 8b0d1074d1a985409392bdacc3e82325b3c8d6e9..51eb1bc08cc6903c7bae82f0b95a2cd890069c89 100644 --- a/requirements.txt +++ b/requirements.txt @@ -7,6 +7,7 @@ Flask==1.1.1 Flask-Bootstrap==3.3.7.1 Flask-SocketIO==4.2.1 Flask-Testing==0.7.1 +Flask-Cors==3.0.10 gevent==1.4.0 greenlet==0.4.15 importlib-metadata==1.5.0 diff --git a/run.py b/run.py index ff6b02509478326d87d84364bab4c9601b0025b2..f69a20825a47ab2d526807240273a5737a878ac5 100644 --- a/run.py +++ b/run.py @@ -7,40 +7,33 @@ import vars from flask import session from flask_socketio import SocketIO, join_room - from app import create_app - from gevent import monkey monkey.patch_all(subprocess=True) config_name = os.getenv('FLASK_CONFIG') app = create_app(config_name) app.config['SECRET_KEY'] = vars.key -socketio = SocketIO(app, message_queue= vars.message_queue) - - +socketio = SocketIO(app, cors_allowed_origins=vars.cors_allowed_origins, message_queue=vars.message_queue) @socketio.on('join_room') def on_room(json): - room = str(session['uid']) referrer = json['referrer'] join_room(room) print('\t\t\t|-----Room ID: ' + room) print('\t\t\t|-----Referrer: ' + referrer) - @socketio.on('request account') def request_account(json, methods=['GET', 'POST']): print (time.strftime("%m-%d-%Y_%H:%M:%S") + '\tQueue request received: ' + str(json)) room = str(session['uid']) print("Room: {}".format(room)) try: - tasks.celery_create_account.delay(json['username'], json['fullname'], json['reason'], session=room) + tasks.celery_create_account.delay(json, session=room ) except Exception as e: print(time.strftime("%m-%d-%Y_%H:%M:%S") + "\tError in account creation: ", e) socketio.emit("Account creation failed", room) - if __name__ == '__main__': socketio.run(app, host='0.0.0.0') diff --git a/tasks.py b/tasks.py index 7deec3a983efced1851970ae9359b17d211862ae..300a58cec84162213a749dbe825746299a59f3a9 100644 --- a/tasks.py +++ b/tasks.py @@ -1,29 +1,63 @@ -from celery import Celery +import vars +import sys +import json import time +import signal + +from celery import Celery from flask_socketio import SocketIO -import subprocess -import vars -from gevent import monkey -monkey.patch_all(subprocess=True) +sys.path.append(vars.rabbitmq_agents_loc) +import rc_util broker_url = vars.broker_url celery = Celery('flask_user_reg', broker=broker_url) socketio = SocketIO(message_queue=vars.message_queue) +timeout = 30 + +def gen_f(room): + def callback(channel, method, properties, body): + msg = json.loads(body) + username = msg['username'] + if msg['success']: + print(f'Account for {username} has been created.') + send_msg('account ready', room) + else: + print(f"There's some issue while creating account for {username}") + errmsg = msg.get('errmsg', []) + for err in errmsg: + print(err) + socketio.emit('account error', errmsg, room= room) + + rc_util.rc_rmq.stop_consume() + rc_util.rc_rmq.delete_queue() + return callback def send_msg(event, room): - print("Post '{}' to room '{}'".format(event,room)) - socketio.emit(event, room=room) + socketio.emit(event, room=room) +def timeout_handler(signum, frame): + print("Process timeout, there's might some issue with agents") + socketio.emit('account error', errmsg, room= room) + rc_util.rc_rmq.stop_consume() + rc_util.rc_rmq.delete_queue() @celery.task -def celery_create_account(username, fullname, reason, session): +def celery_create_account(json, session): room = session + username= json['username'] + email= json['email'] + fullname= json['fullname'] + reason= json['reason'] + aup= json['aup'] + queuename= rc_util.encode_name(username) + print(time.strftime("%m-%d-%Y_%H:%M:%S") + '\tUser ' + username + ' added to queue') send_msg('creating account', room) print(username) - subprocess.call(["/opt/rabbitmq_agents/flask_producer.py", "ohpc_account_create", username]) - print(time.strftime("%m-%d-%Y_%H:%M:%S") + '\tAccount successfully created for ' + username) - send_msg('account ready', room) + rc_util.add_account(username, queuename, email, fullname, reason, aup) + print('sent account info') + print('Waiting for completion...') + rc_util.consume(queuename, routing_key=f'complete.{queuename}', callback=gen_f(room)) diff --git a/vars.py b/vars.py deleted file mode 100644 index 8314f9d955c4c3029bf374de2dee84fd74298817..0000000000000000000000000000000000000000 --- a/vars.py +++ /dev/null @@ -1,6 +0,0 @@ -id = '' -password = '' -key = '' -broker_url = 'amqp://' + id + ':' + password + '@ohpc:5672/' -message_queue = broker_url + 'socketio' -default_referrer = "https://docs.uabgrid.uab.edu/wiki/Cheaha_Quick_Start"