1 /*
2 * Copyright (c) 2022 Huawei Device Co., Ltd.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15
16 #include "js_object_wrapper.h"
17
18 #include "logger.h"
19 namespace OHOS::ObjectStore {
JSObjectWrapper(DistributedObjectStore * objectStore,DistributedObject * object)20 JSObjectWrapper::JSObjectWrapper(DistributedObjectStore *objectStore, DistributedObject *object)
21 : objectStore_(objectStore), object_(object)
22 {
23 }
24
~JSObjectWrapper()25 JSObjectWrapper::~JSObjectWrapper()
26 {
27 LOG_INFO("JSObjectWrapper::~JSObjectWrapper");
28 std::unique_lock<std::shared_mutex> cacheLock(watchMutex_);
29 if (watcher_ != nullptr) {
30 watcher_ = nullptr;
31 }
32 LOG_INFO("JSObjectWrapper::~JSObjectWrapper end");
33 }
34
GetObject()35 DistributedObject *JSObjectWrapper::GetObject()
36 {
37 return object_;
38 }
39
AddWatch(napi_env env,const char * type,napi_value handler)40 bool JSObjectWrapper::AddWatch(napi_env env, const char *type, napi_value handler)
41 {
42 std::unique_lock<std::shared_mutex> cacheLock(watchMutex_);
43 if (watcher_ == nullptr) {
44 watcher_ = std::make_unique<JSWatcher>(env, objectStore_, object_);
45 if (watcher_ == nullptr) {
46 LOG_ERROR("JSObjectWrapper::new JSWatcher fail");
47 return false;
48 }
49 }
50 return watcher_->On(type, handler);
51 }
52
DeleteWatch(napi_env env,const char * type,napi_value handler)53 void JSObjectWrapper::DeleteWatch(napi_env env, const char *type, napi_value handler)
54 {
55 std::unique_lock<std::shared_mutex> cacheLock(watchMutex_);
56 if (watcher_ != nullptr) {
57 watcher_->Off(type, handler);
58 LOG_INFO("JSObjectWrapper::DeleteWatch %{public}s", type);
59 } else {
60 LOG_ERROR("JSObjectWrapper::DeleteWatch watcher_ is null");
61 }
62 }
63
isUndefined(char * value)64 bool JSObjectWrapper::isUndefined(char *value)
65 {
66 std::string tmpStr = value;
67 auto it = std::find(undefinedProperties.begin(), undefinedProperties.end(), tmpStr);
68 if (it == undefinedProperties.end()) {
69 return false;
70 }
71 return true;
72 }
73
AddUndefined(char * value)74 void JSObjectWrapper::AddUndefined(char *value)
75 {
76 std::string tmpStr = value;
77 if (std::find(undefinedProperties.begin(), undefinedProperties.end(), tmpStr) == undefinedProperties.end()) {
78 undefinedProperties.push_back(tmpStr);
79 }
80 }
81
DeleteUndefined(char * value)82 void JSObjectWrapper::DeleteUndefined(char *value)
83 {
84 std::string tmpStr = value;
85 auto it = std::find(undefinedProperties.begin(), undefinedProperties.end(), tmpStr);
86 if (it != undefinedProperties.end()) {
87 undefinedProperties.erase(it);
88 }
89 }
90
DestroyObject()91 void JSObjectWrapper::DestroyObject()
92 {
93 object_ = nullptr;
94 }
95
SetObjectId(const std::string & objectId)96 void JSObjectWrapper::SetObjectId(const std::string &objectId)
97 {
98 objectId_ = objectId;
99 }
100
GetObjectId()101 std::string JSObjectWrapper::GetObjectId()
102 {
103 return objectId_;
104 }
105
106 } // namespace OHOS::ObjectStore