// Copyright 2023 Huawei Cloud Computing Technology Co., Ltd. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #include #include #include #include "src/buildtool/common/remote/remote_common.hpp" class RemoteServeConfig { public: // Obtain global instance [[nodiscard]] static auto Instance() noexcept -> RemoteServeConfig& { static RemoteServeConfig config; return config; } // Set remote execution and cache address, unsets if parsing `address` fails [[nodiscard]] static auto SetRemoteAddress( std::string const& address) noexcept -> bool { auto& inst = Instance(); return static_cast(inst.remote_address_ = ParseAddress(address)); } // Set the list of known repositories [[nodiscard]] static auto SetKnownRepositories( std::vector const& repos) noexcept -> bool { auto& inst = Instance(); inst.repositories_ = std::vector( std::make_move_iterator(repos.begin()), std::make_move_iterator(repos.end())); return repos.size() == inst.repositories_.size(); } // Remote execution address, if set [[nodiscard]] static auto RemoteAddress() noexcept -> std::optional { return Instance().remote_address_; } // Repositories known to 'just serve' [[nodiscard]] static auto KnownRepositories() noexcept -> const std::vector& { return Instance().repositories_; } private: // Server address of remote execution. std::optional remote_address_{}; // Known Git repositories to serve server. std::vector repositories_{}; };