/* * @project The CERN Tape Archive (CTA) * @copyright Copyright © 2021-2022 CERN * @license This program is free software, distributed under the terms of the GNU General Public * Licence version 3 (GPL Version 3), copied verbatim in the file "COPYING". You can * redistribute it and/or modify it under the terms of the GPL Version 3, 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 General Public License for more details. * * In applying this licence, CERN does not waive the privileges and immunities * granted to it by virtue of its status as an Intergovernmental Organization or * submit itself to any jurisdiction. */ #pragma once #include "common/log/Logger.hpp" #include "mediachanger/MediaChangerProxy.hpp" namespace cta::mediachanger { /** * Manual media changer proxy that simply logs mount and dismount requests. */ class DmcProxy: public MediaChangerProxy { public: /** * Constructor * * @param log Object representing the API to the CTA logging system */ explicit DmcProxy(log::Logger& log); /** * Requests the media changer to mount the specified tape for read-only * access into the drive in the specified library slot. * * Please note that this method provides a best-effort service because not all * media changers support read-only mounts. * * @param vid The volume identifier of the tape. * @param librarySlot The library slot containing the tape drive. */ void mountTapeReadOnly(const std::string &vid, const LibrarySlot &librarySlot) override; /** * Requests the media changer to mount the specified tape for read/write * access into the drive in the specified library slot. * * @param vid The volume identifier of the tape. * @param librarySlot The library slot containing the tape drive. */ void mountTapeReadWrite(const std::string &vid, const LibrarySlot &librarySlot) override; /** * Requests the media changer to dismount the specified tape from the * drive in the specifed library slot. * * @param vid The volume identifier of the tape. * @param librarySlot The library slot containing the tape drive. */ void dismountTape(const std::string &vid, const LibrarySlot &librarySlot) override; private: /** * Object representing the API to the CTA logging system. */ log::Logger &m_log; }; // class DmcProxy } // namespace cta::mediachanger