Source code for oio.cli.volume.client
# Copyright (C) 2015-2017 OpenIO SAS, as part of OpenIO SDS
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
from logging import getLogger
LOG = getLogger(__name__)
API_NAME = 'volume'
[docs]class VolumeClientCli(object):
def __init__(self, namespace, **kwargs):
self.conf = {'namespace': namespace}
self.conf.update(kwargs)
self._rdir = None
self._rdir_lb = None
@property
def volume(self):
if not self._rdir:
from oio.rdir.client import RdirClient
self._rdir = RdirClient(self.conf)
return self._rdir
@property
def rdir_lb(self):
if not self._rdir_lb:
from oio.rdir.client import RdirDispatcher
self._rdir_lb = RdirDispatcher(self.conf)
return self._rdir_lb
[docs] def volume_admin_show(self, volume):
return self.volume.admin_show(volume)
[docs] def volume_admin_clear(self, volume, **kwargs):
return self.volume.admin_clear(volume, **kwargs)
[docs] def volume_show(self, volume):
from oio.common.json import json
info = self.volume.status(volume)
data = {}
containers = info.get('container')
data['chunk'] = info.get('chunk')
for ct in containers:
data['container.%s' % ct] = json.dumps(containers[ct])
return data
[docs] def volume_admin_lock(self, volume, key):
return self.volume.admin_lock(volume, key)
[docs] def volume_admin_unlock(self, volume):
return self.volume.admin_unlock(volume)
[docs] def volume_admin_incident(self, volume, date):
return self.volume.admin_incident_set(volume, date)
[docs]def make_client(instance):
"""
Build a VolumeClientCli that will be added as "volume"
field of `instance`.
:param instance: an instance of ClientManager
:returns: an instance of VolumeClientCli
"""
client = VolumeClientCli(
**instance.cli_conf()
)
return client