mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-04 09:18:36 +03:00
lvmdbusd: Remove duplicate error handling code
vg, lv, pv code had the same function for handling command execution. Move to utility function and abstract the difference.
This commit is contained in:
parent
25e7bf021a
commit
df38eb49ab
@ -10,7 +10,7 @@
|
|||||||
from .automatedproperties import AutomatedProperties
|
from .automatedproperties import AutomatedProperties
|
||||||
|
|
||||||
from . import utils
|
from . import utils
|
||||||
from .utils import vg_obj_path_generate, log_error
|
from .utils import vg_obj_path_generate, log_error, _handle_execute
|
||||||
import dbus
|
import dbus
|
||||||
from . import cmdhandler
|
from . import cmdhandler
|
||||||
from . import cfg
|
from . import cfg
|
||||||
@ -275,13 +275,7 @@ class LvCommon(AutomatedProperties):
|
|||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def handle_execute(rc, out, err):
|
def handle_execute(rc, out, err):
|
||||||
if rc == 0:
|
_handle_execute(rc, out, err, LV_INTERFACE)
|
||||||
cfg.load()
|
|
||||||
else:
|
|
||||||
# Need to work on error handling, need consistent
|
|
||||||
raise dbus.exceptions.DBusException(
|
|
||||||
LV_INTERFACE,
|
|
||||||
'Exit code %s, stderr = %s' % (str(rc), err))
|
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def validate_dbus_object(lv_uuid, lv_name):
|
def validate_dbus_object(lv_uuid, lv_name):
|
||||||
|
@ -14,7 +14,7 @@ import dbus
|
|||||||
from .cfg import PV_INTERFACE
|
from .cfg import PV_INTERFACE
|
||||||
from . import cmdhandler
|
from . import cmdhandler
|
||||||
from .utils import vg_obj_path_generate, n, pv_obj_path_generate, \
|
from .utils import vg_obj_path_generate, n, pv_obj_path_generate, \
|
||||||
lv_object_path_method
|
lv_object_path_method, _handle_execute
|
||||||
from .loader import common
|
from .loader import common
|
||||||
from .request import RequestEntry
|
from .request import RequestEntry
|
||||||
from .state import State
|
from .state import State
|
||||||
@ -144,13 +144,7 @@ class Pv(AutomatedProperties):
|
|||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def handle_execute(rc, out, err):
|
def handle_execute(rc, out, err):
|
||||||
if rc == 0:
|
return _handle_execute(rc, out, err, PV_INTERFACE)
|
||||||
cfg.load()
|
|
||||||
else:
|
|
||||||
# Need to work on error handling, need consistent
|
|
||||||
raise dbus.exceptions.DBusException(
|
|
||||||
PV_INTERFACE,
|
|
||||||
'Exit code %s, stderr = %s' % (str(rc), err))
|
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def validate_dbus_object(pv_uuid, pv_name):
|
def validate_dbus_object(pv_uuid, pv_name):
|
||||||
|
@ -26,6 +26,15 @@ import signal
|
|||||||
STDOUT_TTY = os.isatty(sys.stdout.fileno())
|
STDOUT_TTY = os.isatty(sys.stdout.fileno())
|
||||||
|
|
||||||
|
|
||||||
|
def _handle_execute(rc, out, err, interface):
|
||||||
|
if rc == 0:
|
||||||
|
cfg.load()
|
||||||
|
else:
|
||||||
|
# Need to work on error handling, need consistent
|
||||||
|
raise dbus.exceptions.DBusException(
|
||||||
|
interface, 'Exit code %s, stderr = %s' % (str(rc), err))
|
||||||
|
|
||||||
|
|
||||||
def rtype(dbus_type):
|
def rtype(dbus_type):
|
||||||
"""
|
"""
|
||||||
Decorator making sure that the decorated function returns a value of
|
Decorator making sure that the decorated function returns a value of
|
||||||
|
@ -10,7 +10,8 @@
|
|||||||
from .automatedproperties import AutomatedProperties
|
from .automatedproperties import AutomatedProperties
|
||||||
|
|
||||||
from . import utils
|
from . import utils
|
||||||
from .utils import pv_obj_path_generate, vg_obj_path_generate, n
|
from .utils import pv_obj_path_generate, vg_obj_path_generate, n, \
|
||||||
|
_handle_execute
|
||||||
import dbus
|
import dbus
|
||||||
from . import cfg
|
from . import cfg
|
||||||
from .cfg import VG_INTERFACE
|
from .cfg import VG_INTERFACE
|
||||||
@ -154,13 +155,7 @@ class Vg(AutomatedProperties):
|
|||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def handle_execute(rc, out, err):
|
def handle_execute(rc, out, err):
|
||||||
if rc == 0:
|
return _handle_execute(rc, out, err, VG_INTERFACE)
|
||||||
cfg.load()
|
|
||||||
else:
|
|
||||||
# Need to work on error handling, need consistent
|
|
||||||
raise dbus.exceptions.DBusException(
|
|
||||||
VG_INTERFACE,
|
|
||||||
'Exit code %s, stderr = %s' % (str(rc), err))
|
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def validate_dbus_object(vg_uuid, vg_name):
|
def validate_dbus_object(vg_uuid, vg_name):
|
||||||
|
Loading…
Reference in New Issue
Block a user