Skip to content
Snippets Groups Projects
  • Ravi Tripathi's avatar
    Changes in this commit: · 0eceb2af
    Ravi Tripathi authored
    * Create a queuename variable based on the percent encoding of username.
    * Pass 'queuename' attribute to add_user function.
    * Create routing key based on 'queuename' rather then 'username'
    0eceb2af
create_account.py 1.87 KiB
#!/usr/bin/env python3
import json
import sys
import rc_util
import argparse
import signal

parser = argparse.ArgumentParser()
parser.add_argument('username', help='username that will be created')
parser.add_argument('email', nargs='?', default='', help="User's email")
parser.add_argument('full_name', nargs='?', default='', help="User's full name")
parser.add_argument('reason', nargs='?', default='', help='Reason of requesting')
parser.add_argument('--domain', default='localhost', help='domain of email')
parser.add_argument('-v', '--verbose', action='store_true', help='verbose output')
parser.add_argument('-n', '--dry-run', action='store_true', help='enable dry run mode')
args = parser.parse_args()

timeout = 60

queuename = rc_util.encode_name(args.username)

if args.email == "":
    args.email = args.username
    if '@' not in args.email:
        args.email = args.username + '@' + args.domain

def timeout_handler(signum, frame):
    print("Process timeout, there's might some issue with agents")
    rc_util.rc_rmq.stop_consume()


def callback(channel, method, properties, body):
    msg = json.loads(body)
    username = msg['username']

    if msg['success']:
        print(f'Account for {username} has been created.')
    else:
        print(f"There's some issue while creating account for {username}")
        errmsg = msg.get('errmsg', [])
        for err in errmsg:
            print(err)

    rc_util.rc_rmq.stop_consume()
    rc_util.rc_rmq.delete_queue()


rc_util.add_account(
    args.username,
    queuename=queuename,
    email=args.email,
    full=args.full_name,
    reason=args.reason,
)
print(f"Account for {args.username} requested.")

# Set initial timeout timer
signal.signal(signal.SIGALRM, timeout_handler)
signal.setitimer(signal.ITIMER_REAL, timeout)

print("Waiting for completion...")
rc_util.consume(
    queuename, routing_key=f"complete.{queuename}", callback=callback
)