/* * Copyright (c) 2022 Huawei Device 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. */ #ifndef DISTRIBUTEDDATAMGR_OBJECT_ASSET_LOADER_H #define DISTRIBUTEDDATAMGR_OBJECT_ASSET_LOADER_H #include #include "executor_pool.h" #include "object_types.h" #include "store/general_value.h" #include "concurrent_map.h" #include #include "asset/asset_send_callback_stub.h" namespace OHOS { namespace DistributedObject { using AssetObj = Storage::DistributedFile::AssetObj; using TransferFunc = std::function; struct TransferTask { TransferTask() = default; std::unordered_set downloadAssets; TransferFunc callback; }; class ObjectAssetsSendListener : public Storage::DistributedFile::AssetSendCallbackStub { public: ObjectAssetsSendListener() =default; ~ObjectAssetsSendListener() = default; int32_t OnSendResult(const sptr &assetObj, int32_t result) override; }; class ObjectAssetLoader { public: static ObjectAssetLoader *GetInstance(); void SetThreadPool(std::shared_ptr executors); bool Transfer(const int32_t userId, const std::string& bundleName, const std::string& deviceId, const DistributedData::Asset& asset); void TransferAssetsAsync(const int32_t userId, const std::string& bundleName, const std::string& deviceId, const std::vector& assets, const TransferFunc& callback); int32_t PushAsset(int32_t userId, const sptr &assetObj, const sptr &sendCallback); private: ObjectAssetLoader() = default; ~ObjectAssetLoader() = default; ObjectAssetLoader(const ObjectAssetLoader &) = delete; ObjectAssetLoader &operator=(const ObjectAssetLoader &) = delete; void FinishTask(const std::string& uri, bool result); bool IsDownloading(const DistributedData::Asset& asset); bool IsDownloaded(const DistributedData::Asset& asset); void UpdateDownloaded(const DistributedData::Asset& asset); static constexpr int WAIT_TIME = 60; static constexpr int LAST_DOWNLOAD_ASSET_SIZE = 200; std::shared_ptr executors_; std::mutex mutex_; std::atomic_uint32_t taskSeq_ = 0; std::queue assetQueue_; ConcurrentMap tasks_; ConcurrentMap downloaded_; ConcurrentMap downloading_; }; } // namespace DistributedObject } // namespace OHOS #endif // DISTRIBUTEDDATAMGR_OBJECT_ASSET_LOADER_H