Source code for ElementsServices.DataSync.IrodsSynchronizer

#
# Copyright (C) 2012-2020 Euclid Science Ground Segment
#
# This library is free software; you can redistribute it and/or modify it under
# the terms of the GNU Lesser General Public License as published by the Free
# Software Foundation; either version 3.0 of the License, or (at your option)
# any later version.
#
# This library 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 Lesser General Public License for more
# details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with this library; if not, write to the Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
#

import subprocess
import shlex

from .DataSynchronizer import DataSynchronizer

[docs]def irodsIsInstalled(): """Check whether an iRODS client is installed. """ try: subprocess.check_call(shlex.split("iget --help")) return True except OSError: return False
[docs]class IrodsSynchronizer(DataSynchronizer): """A data synchronizer for iRods hosts. """ def __init__ (self, connection, dependencies): super(IrodsSynchronizer, self).__init__(connection, dependencies) if not irodsIsInstalled(): raise RuntimeError( 'You are trying to use iRODS, ' 'but it does not seem to be installed.')
[docs] def createDownloadCommand(self, distant_file, local_file): if not irodsIsInstalled(): return "" cmd = "irsync i:" cmd += distant_file + " " + local_file # Number of retries cannot be set with irsync # -s option allows comparing only file size (no checksum) to save time return cmd