Newer
Older
#!/usr/bin/env python
import json
import rc_util
from os import popen
from rc_rmq import RCRMQ
import rabbit_config as rcfg
Ravi Tripathi
committed
from subprocess import run
import shlex
# Instantiate rabbitmq object
rc_rmq = RCRMQ({"exchange": "RegUsr", "exchange_type": "topic"})
args = rc_util.get_args()
# Logger
logger = rc_util.get_logger()
Ravi Tripathi
committed
logger.info(f"Account creation request received: {msg}")
username = msg["username"]
uid = msg["uid"]
email = msg["email"]
fullname = msg["fullname"]
msg["success"] = False
Ravi Tripathi
committed
if str(rcfg.bright_cm_version).split(".")[0] == "8":
cmd = "/cm/local/apps/cmd/bin/cmsh -c "
cmd += f'"user; add {username}; set userid {uid}; set email {email};'
cmd += f'set commonname \\"{fullname}\\"; '
cmd += 'commit;"'
else:
cmd = "/cm/local/apps/cmd/bin/cmsh -c "
cmd += f'"user; add {username}; set id {uid}; set email {email};'
cmd += f'set commonname \\"{fullname}\\"; '
cmd += 'commit;"'
if not args.dry_run:
Ravi Tripathi
committed
run(shlex.split(cmd))
time.sleep(rcfg.Delay)
logger.info(f"Bright command to create user:{cmd}")
# Define your callback function
def resolve_uid_gid(ch, method, properties, body):
# Retrieve message
msg = json.loads(body)
logger.info("Received {}".format(msg))
username = msg["username"]
msg["success"] = False
# Determine next available UID
try:
user_exists_cmd = f"/usr/bin/getent passwd {username}"
user_exists = popen(user_exists_cmd).read().rstrip()
if user_exists:
logger.info("The user, {} already exists".format(username))
msg["uid"] = user_exists.split(":")[2]
msg["gid"] = user_exists.split(":")[3]
cmd_uid = (
"/usr/bin/getent passwd | awk -F: 'BEGIN { maxuid=10000 }"
" ($3>10000) && ($3<20000) && ($3>maxuid) { maxuid=$3; } END {"
" print maxuid+1; }'"
)
msg["uid"] = popen(cmd_uid).read().rstrip()
logger.info(f"UID query: {cmd_uid}")
cmd_gid = (
"/usr/bin/getent group | awk -F: 'BEGIN { maxgid=10000 }"
" ($3>10000) && ($3<20000) && ($3>maxgid) { maxgid=$3; } END {"
" print maxgid+1; }'"
)
msg["gid"] = popen(cmd_gid).read().rstrip()
logger.info(f"GID query: {cmd_gid}")
msg["task"] = task
msg["success"] = True
msg["errmsg"] = (
"Exception raised during account creation, check logs for stack"
" trace"
)
# Acknowledge message
ch.basic_ack(delivery_tag=method.delivery_tag)
# Send confirm message
logger.debug("rc_rmq.publish_msg()")
rc_rmq.publish_msg(
{"routing_key": "confirm." + msg["queuename"], "msg": msg}
)
logger.info("confirmation sent")
logger.info("Start listening to queue: {}".format(task))
rc_rmq.start_consume(
{"queue": task, "routing_key": "request.*", "cb": resolve_uid_gid}
)
logger.info("Disconnected")