• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2022-2023 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 #ifndef COMMUNICATIONNETMANAGER_BASE_NETMANAGER_BASE_MODULE_TEMPLATE_H
17 #define COMMUNICATIONNETMANAGER_BASE_NETMANAGER_BASE_MODULE_TEMPLATE_H
18 
19 #include <initializer_list>
20 
21 #include <napi/native_api.h>
22 #include <napi/native_common.h>
23 
24 #include "base_context.h"
25 #include "napi_utils.h"
26 #include "netmanager_base_log.h"
27 
28 #define MAX_PARAM_NUM 64
29 
30 namespace OHOS {
31 namespace NetManagerStandard {
32 namespace ModuleTemplate {
33 using Finalizer = void (*)(napi_env env, void *data, void *);
34 
35 template <class Context>
InterfaceWithoutManager(napi_env env,napi_callback_info info,const std::string & asyncWorkName,bool (* Work)(napi_env,napi_value,Context *),AsyncWorkExecutor executor,AsyncWorkCallback callback)36 napi_value InterfaceWithoutManager(napi_env env, napi_callback_info info, const std::string &asyncWorkName,
37                                    bool (*Work)(napi_env, napi_value, Context *), AsyncWorkExecutor executor,
38                                    AsyncWorkCallback callback)
39 {
40     static_assert(std::is_base_of<BaseContext, Context>::value);
41 
42     napi_value thisVal = nullptr;
43     size_t paramsCount = MAX_PARAM_NUM;
44     napi_value params[MAX_PARAM_NUM] = {nullptr};
45     NAPI_CALL(env, napi_get_cb_info(env, info, &paramsCount, params, &thisVal, nullptr));
46 
47     std::shared_ptr<EventManager> manager = nullptr;
48     auto context = new Context(env, manager);
49     context->ParseParams(params, paramsCount);
50     if (context->IsNeedThrowException()) { // only api9 or later need throw exception.
51         napi_throw_error(env, std::to_string(context->GetErrorCode()).c_str(), context->GetErrorMessage().c_str());
52         delete context;
53         context = nullptr;
54         return NapiUtils::GetUndefined(env);
55     }
56     if (Work != nullptr) {
57         if (!Work(env, thisVal, context)) {
58             NETMANAGER_BASE_LOGE("work failed error code = %{public}d", context->GetErrorCode());
59         }
60     }
61 
62     context->CreateAsyncWork(asyncWorkName, executor, callback);
63     if (NapiUtils::GetValueType(env, context->GetCallback()) != napi_function && context->IsNeedPromise()) {
64         return context->CreatePromise();
65     }
66     return NapiUtils::GetUndefined(env);
67 }
68 
69 template <class Context>
Interface(napi_env env,napi_callback_info info,const std::string & asyncWorkName,bool (* Work)(napi_env,napi_value,Context *),AsyncWorkExecutor executor,AsyncWorkCallback callback)70 napi_value Interface(napi_env env, napi_callback_info info, const std::string &asyncWorkName,
71                      bool (*Work)(napi_env, napi_value, Context *), AsyncWorkExecutor executor,
72                      AsyncWorkCallback callback)
73 {
74     static_assert(std::is_base_of<BaseContext, Context>::value);
75 
76     napi_value thisVal = nullptr;
77     size_t paramsCount = MAX_PARAM_NUM;
78     napi_value params[MAX_PARAM_NUM] = {nullptr};
79     NAPI_CALL(env, napi_get_cb_info(env, info, &paramsCount, params, &thisVal, nullptr));
80 
81     std::shared_ptr<EventManager> *sharedManager = nullptr;
82     napi_unwrap(env, thisVal, reinterpret_cast<void **>(&sharedManager));
83     std::shared_ptr<EventManager> manager = nullptr;
84     if (sharedManager != nullptr && *sharedManager != nullptr) {
85         manager = *sharedManager;
86     }
87 
88     auto context = new Context(env, manager);
89     context->ParseParams(params, paramsCount);
90     if (context->IsNeedThrowException()) { // only api9 or later need throw exception.
91         napi_throw_error(env, std::to_string(context->GetErrorCode()).c_str(), context->GetErrorMessage().c_str());
92         delete context;
93         context = nullptr;
94         return NapiUtils::GetUndefined(env);
95     }
96     if (Work != nullptr) {
97         if (!Work(env, thisVal, context)) {
98             NETMANAGER_BASE_LOGE("work failed error code = %{public}d", context->GetErrorCode());
99         }
100     }
101 
102     context->CreateAsyncWork(asyncWorkName, executor, callback);
103     if (NapiUtils::GetValueType(env, context->GetCallback()) != napi_function && context->IsNeedPromise()) {
104         return context->CreatePromise();
105     }
106     return NapiUtils::GetUndefined(env);
107 }
108 
109 template <class Context>
InterfaceSync(napi_env env,napi_callback_info info,const std::string & asyncWorkName,bool (* Work)(napi_env,napi_value,Context *),bool (* executor)(Context *),napi_value (* callback)(Context *))110 napi_value InterfaceSync(napi_env env, napi_callback_info info, const std::string &asyncWorkName,
111                          bool (*Work)(napi_env, napi_value, Context *), bool (*executor)(Context *),
112                          napi_value (*callback)(Context *))
113 {
114     static_assert(std::is_base_of<BaseContext, Context>::value);
115 
116     napi_value thisVal = nullptr;
117     size_t paramsCount = MAX_PARAM_NUM;
118     napi_value params[MAX_PARAM_NUM] = {nullptr};
119     NAPI_CALL(env, napi_get_cb_info(env, info, &paramsCount, params, &thisVal, nullptr));
120     std::shared_ptr<EventManager> *sharedManager = nullptr;
121     napi_unwrap(env, thisVal, reinterpret_cast<void **>(&sharedManager));
122     std::shared_ptr<EventManager> manager = nullptr;
123     if (sharedManager != nullptr && *sharedManager != nullptr) {
124         manager = *sharedManager;
125     }
126 
127     auto deleter = [](Context *context) { delete context; };
128     auto text = new Context(env, manager);
129     std::unique_ptr<Context, decltype(deleter)> context(text, deleter);
130     if (!context) {
131         return NapiUtils::GetUndefined(env);
132     }
133 
134     context->ParseParams(params, paramsCount);
135     if (!context->IsParseOK()) {
136         napi_throw_error(env, std::to_string(context->GetErrorCode()).c_str(), context->GetErrorMessage().c_str());
137         return NapiUtils::GetUndefined(env);
138     }
139     if (Work != nullptr) {
140         if (!Work(env, thisVal, context.get())) {
141             NETMANAGER_BASE_LOGE("work failed error code = %{public}d", context->GetErrorCode());
142         }
143     }
144 
145     if (!executor || !callback) {
146         NETMANAGER_BASE_LOGE("executor or callback is null");
147         return NapiUtils::GetUndefined(context->GetEnv());
148     }
149 
150     if (!executor(context.get())) {
151         NETMANAGER_BASE_LOGE("executor is fail, errorcode= %{public}d", context->GetErrorCode());
152         napi_throw_error(env, std::to_string(context->GetErrorCode()).c_str(), context->GetErrorMessage().c_str());
153         return NapiUtils::GetUndefined(env);
154     }
155     return callback(context.get());
156 }
157 
158 template <class Context>
InterfaceWithOutAsyncWork(napi_env env,napi_callback_info info,bool (* Work)(napi_env,napi_value,Context *))159 napi_value InterfaceWithOutAsyncWork(napi_env env, napi_callback_info info,
160                                      bool (*Work)(napi_env, napi_value, Context *))
161 {
162     static_assert(std::is_base_of<BaseContext, Context>::value);
163 
164     napi_value thisVal = nullptr;
165     size_t paramsCount = MAX_PARAM_NUM;
166     napi_value params[MAX_PARAM_NUM] = {nullptr};
167     NAPI_CALL(env, napi_get_cb_info(env, info, &paramsCount, params, &thisVal, nullptr));
168 
169     std::shared_ptr<EventManager> *sharedManager = nullptr;
170     napi_unwrap(env, thisVal, reinterpret_cast<void **>(&sharedManager));
171     std::shared_ptr<EventManager> manager = nullptr;
172     if (sharedManager != nullptr && *sharedManager != nullptr) {
173         manager = *sharedManager;
174     }
175 
176     auto context = new Context(env, manager);
177     context->ParseParams(params, paramsCount);
178     if (Work != nullptr) {
179         if (!Work(env, thisVal, context)) {
180             NETMANAGER_BASE_LOGE("work failed error code = %{public}d", context->GetErrorCode());
181         }
182     }
183 
184     if (NapiUtils::GetValueType(env, context->GetCallback()) != napi_function && context->IsNeedPromise()) {
185         return context->CreatePromise();
186     }
187     return NapiUtils::GetUndefined(env);
188 }
189 
190 napi_value On(napi_env env, napi_callback_info info, const std::initializer_list<std::string> &events,
191               bool asyncCallback);
192 
193 napi_value Once(napi_env env, napi_callback_info info, const std::initializer_list<std::string> &events,
194                 bool asyncCallback);
195 
196 napi_value Off(napi_env env, napi_callback_info info, const std::initializer_list<std::string> &events);
197 
198 void DefineClass(napi_env env, napi_value exports, const std::initializer_list<napi_property_descriptor> &properties,
199                  const std::string &className);
200 
201 napi_value NewInstance(napi_env env, napi_callback_info info, const std::string &className,
202     void *(*MakeData)(napi_env, size_t, napi_value *, std::shared_ptr<EventManager>&), Finalizer finalizer);
203 } // namespace ModuleTemplate
204 } // namespace NetManagerStandard
205 } // namespace OHOS
206 #endif // COMMUNICATIONNETMANAGER_BASE_NETMANAGER_BASE_MODULE_TEMPLATE_H
207