/* * Copyright (c) 2021 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 WATCHER_MANAGER_H_ #define WATCHER_MANAGER_H_ #include #include #include #include #include #include #include "iremote_stub.h" #include "iwatcher.h" #include "message_parcel.h" #include "param_utils.h" #include "parcel.h" #include "system_ability.h" #include "watcher_manager_stub.h" namespace OHOS { namespace init_param { class WatcherManager : public SystemAbility, public WatcherManagerStub { public: DECLARE_SYSTEM_ABILITY(WatcherManager); DISALLOW_COPY_AND_MOVE(WatcherManager); explicit WatcherManager(int32_t systemAbilityId, bool runOnCreate = true) : SystemAbility(systemAbilityId, runOnCreate) {} ~WatcherManager() override { watcherGroups_.clear(); groupMap_.clear(); }; class ParamWatcher { public: ParamWatcher(uint32_t watcherId, const sptr &watcher) : watcherId_(watcherId), watcher_(watcher) {} ~ParamWatcher() = default; uint32_t GetWatcherId() { return watcherId_; } void ProcessParameterChange(const std::string &name, const std::string &value) { #ifndef STARTUP_INIT_TEST watcher_->OnParamerterChange(name, value); #endif } private: uint32_t watcherId_ = { 0 }; sptr watcher_; }; using ParamWatcherPtr = std::shared_ptr; class WatcherGroup { public: WatcherGroup(uint32_t groupId, const std::string &key) : groupId_(groupId), keyPrefix_(key) {} ~WatcherGroup() = default; void AddWatcher(const ParamWatcherPtr &watcher); void DelWatcher(uint32_t watcherId); void ProcessParameterChange(const std::string &name, const std::string &value); const std::string GetKeyPrefix() { return keyPrefix_; } bool Emptry() { return watchers_.size() == 0; } uint32_t GetGroupId() { return groupId_; } private: uint32_t groupId_; std::string keyPrefix_ { }; std::map watchers_; }; using WatcherGroupPtr = std::shared_ptr; uint32_t AddWatcher(const std::string &keyPrefix, const sptr &watcher) override; int32_t DelWatcher(const std::string &keyPrefix, uint32_t watcherId) override; #ifndef STARTUP_INIT_TEST protected: #endif void OnStart() override; void OnStop() override; #ifndef STARTUP_INIT_TEST private: #endif void ProcessWatcherMessage(const std::vector &buffer, uint32_t dataSize); WatcherGroupPtr GetWatcherGroup(uint32_t groupId); WatcherGroupPtr GetWatcherGroup(const std::string &keyPrefix); void AddWatcherGroup(const std::string &keyPrefix, WatcherGroupPtr group); void DelWatcherGroup(WatcherGroupPtr group); void RunLoop(); void StartLoop(); void StopLoop(); void SendLocalChange(const std::string &keyPrefix, ParamWatcherPtr watcher); int SendMessage(WatcherGroupPtr group, int type); int GetServerFd(bool retry); private: std::atomic watcherId_ { 0 }; std::atomic groupId_ { 0 }; std::mutex mutex_; std::mutex watcherMutex_; int serverFd_ { -1 }; std::thread *pRecvThread_ { nullptr }; std::atomic stop_ { false }; std::map groupMap_ {}; std::map watcherGroups_ {}; }; } // namespace init_param } // namespace OHOS #endif // WATCHER_MANAGER_H_