|
|
e4ffb1 |
From d452969b172da23604d58e14a7b60d19f87967df Mon Sep 17 00:00:00 2001
|
|
|
e4ffb1 |
From: Marek 'marx' Grac <mgrac@redhat.com>
|
|
|
e4ffb1 |
Date: Wed, 17 Jun 2015 19:34:53 +0200
|
|
|
e4ffb1 |
Subject: [PATCH 02/10] fence_scsi: Add support for monitor action
|
|
|
e4ffb1 |
|
|
|
e4ffb1 |
Resolves: rhbz#1196068
|
|
|
e4ffb1 |
---
|
|
|
e4ffb1 |
fence/agents/scsi/fence_scsi.py | 18 ++++++++++++++++++
|
|
|
e4ffb1 |
1 file changed, 18 insertions(+)
|
|
|
e4ffb1 |
|
|
|
e4ffb1 |
diff --git a/fence/agents/scsi/fence_scsi.py b/fence/agents/scsi/fence_scsi.py
|
|
|
e4ffb1 |
index 3a899d1..de301a5 100644
|
|
|
e4ffb1 |
--- a/fence/agents/scsi/fence_scsi.py
|
|
|
e4ffb1 |
+++ b/fence/agents/scsi/fence_scsi.py
|
|
|
e4ffb1 |
@@ -83,6 +83,21 @@ def set_status(conn, options):
|
|
|
e4ffb1 |
sys.exit(1)
|
|
|
e4ffb1 |
|
|
|
e4ffb1 |
|
|
|
e4ffb1 |
+# check if host is ready to execute actions
|
|
|
e4ffb1 |
+def do_action_monitor(options):
|
|
|
e4ffb1 |
+ if bool(run_cmd(options, options["--sg_persist-path"] + " -V")["err"]):
|
|
|
e4ffb1 |
+ logging.error("Unable to run " + options["--sg_persist-path"])
|
|
|
e4ffb1 |
+ return 1
|
|
|
e4ffb1 |
+ elif bool(run_cmd(options, options["--sg_turs-path"] + " -V")["err"]):
|
|
|
e4ffb1 |
+ logging.error("Unable to run " + options["--sg_turs-path"])
|
|
|
e4ffb1 |
+ return 1
|
|
|
e4ffb1 |
+ elif ("--devices" not in options and
|
|
|
e4ffb1 |
+ bool(run_cmd(options, options["--vgs-path"] + " --version")["err"])):
|
|
|
e4ffb1 |
+ logging.error("Unable to run " + options["--vgs-path"])
|
|
|
e4ffb1 |
+ return 1
|
|
|
e4ffb1 |
+ return 0
|
|
|
e4ffb1 |
+
|
|
|
e4ffb1 |
+
|
|
|
e4ffb1 |
#run command, returns dict, ret["err"] = exit code; ret["out"] = output
|
|
|
e4ffb1 |
def run_cmd(options, cmd):
|
|
|
e4ffb1 |
ret = {}
|
|
|
e4ffb1 |
@@ -423,6 +438,9 @@ longer be able to write to the device(s). A manual reboot is required."
|
|
|
e4ffb1 |
options["store_path"] = STORE_PATH
|
|
|
e4ffb1 |
|
|
|
e4ffb1 |
# Input control BEGIN
|
|
|
e4ffb1 |
+ if options["--action"] == "monitor":
|
|
|
e4ffb1 |
+ sys.exit(do_action_monitor(options))
|
|
|
e4ffb1 |
+
|
|
|
e4ffb1 |
if not (("--nodename" in options and options["--nodename"])\
|
|
|
e4ffb1 |
or ("--key" in options and options["--key"])):
|
|
|
e4ffb1 |
fail_usage("Failed: nodename or key is required")
|
|
|
e4ffb1 |
--
|
|
|
e4ffb1 |
1.9.3
|
|
|
e4ffb1 |
|