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>&#9;<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>&#9;<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>&#9;<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"