• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2024 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 "appaccount_parameter_parse.h"
17 
18 #include <cinttypes>
19 #include "array_wrapper.h"
20 #include "bool_wrapper.h"
21 #include "double_wrapper.h"
22 #include "int_wrapper.h"
23 #include "long_wrapper.h"
24 #include "securec.h"
25 #include "string_wrapper.h"
26 #include "want_params_wrapper.h"
27 #include "appaccount_ffi.h"
28 
29 namespace OHOS::AccountSA {
30 const char *FD = "FD";
31 const char *TYPE_PROPERTY = "type";
32 const char *VALUE_PROPERTY = "value";
33 const int8_t I32_TYPE = 0;
34 const int8_t DOUBLE_TYPE = 1;
35 const int8_t STR_TYPE = 2;
36 const int8_t BOOL_TYPE = 3;
37 const int8_t FD_TYPE = 4;
38 const int8_t STR_PTR_TYPE = 5;
39 const int8_t I32_PTR_TYPE = 6;
40 const int8_t I64_PTR_TYPE = 7;
41 const int8_t BOOL_PTR_TYPE = 8;
42 const int8_t DOUBLE_PTR_TYPE = 9;
43 const int8_t FD_PTR_TYPE = 10;
44 const int32_t NONE_VALUE = 1;
45 const int8_t NO_ERROR = 0;
46 const int8_t ERR_CES_FAILED = 1;
47 const int8_t ERR_NO_MEMORY = -2;
48 using Want = OHOS::AAFwk::Want;
49 using WantParams = OHOS::AAFwk::WantParams;
50 
charPtrToVector(char ** charPtr,int size,std::vector<std::string> & result)51 void charPtrToVector(char **charPtr, int size, std::vector<std::string> &result)
52 {
53     for (int i = 0; i < size; i++) {
54         result.push_back(std::string(charPtr[i]));
55     }
56 }
57 
SetFdData(std::string key,int * value,WantParams & wantP)58 void SetFdData(std::string key, int *value, WantParams &wantP)
59 {
60     WantParams wp;
61     wp.SetParam(TYPE_PROPERTY, OHOS::AAFwk::String::Box(FD));
62     wp.SetParam(VALUE_PROPERTY, OHOS::AAFwk::Integer::Box(*value));
63     sptr<OHOS::AAFwk::IWantParams> pWantParams = OHOS::AAFwk::WantParamWrapper::Box(wp);
64     wantP.SetParam(key, pWantParams);
65 }
66 
InnerSetWantParamsArrayString(const std::string & key,const std::vector<std::string> & value,AAFwk::WantParams & wantParams)67 bool InnerSetWantParamsArrayString(
68     const std::string &key, const std::vector<std::string> &value, AAFwk::WantParams &wantParams)
69 {
70     size_t size = value.size();
71     sptr<AAFwk::IArray> ao = new (std::nothrow) AAFwk::Array(size, AAFwk::g_IID_IString);
72     if (ao != nullptr) {
73         for (size_t i = 0; i < size; i++) {
74             ao->Set(i, AAFwk::String::Box(value[i]));
75         }
76         wantParams.SetParam(key, ao);
77         return true;
78     } else {
79         return false;
80     }
81 }
82 
InnerSetWantParamsArrayInt(const std::string & key,const std::vector<int> & value,AAFwk::WantParams & wantParams)83 bool InnerSetWantParamsArrayInt(const std::string &key, const std::vector<int> &value,
84     AAFwk::WantParams &wantParams)
85 {
86     size_t size = value.size();
87     sptr<AAFwk::IArray> ao = new (std::nothrow) AAFwk::Array(size, AAFwk::g_IID_IInteger);
88     if (ao != nullptr) {
89         for (size_t i = 0; i < size; i++) {
90             ao->Set(i, AAFwk::Integer::Box(value[i]));
91         }
92         wantParams.SetParam(key, ao);
93         return true;
94     } else {
95         return false;
96     }
97 }
98 
InnerSetWantParamsArrayLong(const std::string & key,const std::vector<long> & value,AAFwk::WantParams & wantParams)99 bool InnerSetWantParamsArrayLong(const std::string &key, const std::vector<long> &value,
100     AAFwk::WantParams &wantParams)
101 {
102     size_t size = value.size();
103     sptr<AAFwk::IArray> ao = new (std::nothrow) AAFwk::Array(size, AAFwk::g_IID_ILong);
104     if (ao != nullptr) {
105         for (size_t i = 0; i < size; i++) {
106             ao->Set(i, AAFwk::Long::Box(value[i]));
107         }
108         wantParams.SetParam(key, ao);
109         return true;
110     } else {
111         return false;
112     }
113 }
114 
InnerSetWantParamsArrayBool(const std::string & key,const std::vector<bool> & value,AAFwk::WantParams & wantParams)115 bool InnerSetWantParamsArrayBool(const std::string &key, const std::vector<bool> &value,
116     AAFwk::WantParams &wantParams)
117 {
118     size_t size = value.size();
119     sptr<AAFwk::IArray> ao = new (std::nothrow) AAFwk::Array(size, AAFwk::g_IID_IBoolean);
120     if (ao != nullptr) {
121         for (size_t i = 0; i < size; i++) {
122             ao->Set(i, AAFwk::Boolean::Box(value[i]));
123         }
124         wantParams.SetParam(key, ao);
125         return true;
126     } else {
127         return false;
128     }
129 }
130 
InnerSetWantParamsArrayDouble(const std::string & key,const std::vector<double> & value,AAFwk::WantParams & wantParams)131 bool InnerSetWantParamsArrayDouble(
132     const std::string &key, const std::vector<double> &value, AAFwk::WantParams &wantParams)
133 {
134     size_t size = value.size();
135     sptr<AAFwk::IArray> ao = new (std::nothrow) AAFwk::Array(size, AAFwk::g_IID_IDouble);
136     if (ao != nullptr) {
137         for (size_t i = 0; i < size; i++) {
138             ao->Set(i, AAFwk::Double::Box(value[i]));
139         }
140         wantParams.SetParam(key, ao);
141         return true;
142     } else {
143         return false;
144     }
145 }
146 
InnerSetWantParamsArrayFD(CParameters * head,int64_t size,AAFwk::WantParams & wantParams)147 void InnerSetWantParamsArrayFD(CParameters* head, int64_t size, AAFwk::WantParams &wantParams)
148 {
149     sptr<AAFwk::IArray> ao = new (std::nothrow) AAFwk::Array(size, AAFwk::g_IID_IWantParams);
150     if (ao != nullptr) {
151         for (size_t i = 0; i < static_cast<size_t>(size); i++) {
152             WantParams wp;
153             SetFdData(std::string(head->key), static_cast<int *>(head->value) + i, wp);
154             wp.DumpInfo(0);
155             ao->Set(i, OHOS::AAFwk::WantParamWrapper::Box(wp));
156         }
157         wantParams.SetParam(std::string(head->key), ao);
158     }
159     return;
160 }
161 
SetDataParameters(CArrParameters parameters,WantParams & wantP)162 void SetDataParameters(CArrParameters parameters, WantParams &wantP)
163 {
164     for (int i = 0; i < parameters.size; i++) {
165         auto head = parameters.head + i;
166         auto key = std::string(head->key);
167         if (head->valueType == I32_TYPE) { // int32_t
168             wantP.SetParam(key, OHOS::AAFwk::Integer::Box(*static_cast<int32_t *>(head->value)));
169         } else if (head->valueType == DOUBLE_TYPE) { // double
170             wantP.SetParam(key, OHOS::AAFwk::Double::Box(*static_cast<double *>(head->value)));
171         } else if (head->valueType == STR_TYPE) { // std::string
172             wantP.SetParam(key, OHOS::AAFwk::String::Box(std::string(static_cast<char *>(head->value))));
173         } else if (head->valueType == BOOL_TYPE) { // bool
174             wantP.SetParam(key, OHOS::AAFwk::Boolean::Box(*static_cast<bool *>(head->value)));
175         } else if (head->valueType == FD_TYPE) { // "FD"
176             SetFdData(key, static_cast<int *>(head->value), wantP);
177         } else if (head->valueType == STR_PTR_TYPE) { // char**
178             char **strPtr = static_cast<char **>(head->value);
179             std::vector<std::string> strVec;
180             charPtrToVector(strPtr, head->size, strVec);
181             InnerSetWantParamsArrayString(key, strVec, wantP);
182         } else if (head->valueType == I32_PTR_TYPE) { // int32_t*
183             int *intArr = static_cast<int *>(head->value);
184             std::vector<int> intVec(intArr, intArr + head->size);
185             InnerSetWantParamsArrayInt(key, intVec, wantP);
186         } else if (head->valueType == I64_PTR_TYPE) { // int64_t*
187             long *longArr = static_cast<long *>(head->value);
188             std::vector<long> longVec(longArr, longArr + head->size);
189             InnerSetWantParamsArrayLong(key, longVec, wantP);
190         } else if (head->valueType == BOOL_PTR_TYPE) { // bool*
191             bool *boolArr = static_cast<bool *>(head->value);
192             std::vector<bool> boolVec(boolArr, boolArr + head->size);
193             InnerSetWantParamsArrayBool(key, boolVec, wantP);
194         } else if (head->valueType == DOUBLE_PTR_TYPE) { // double*
195             double *doubleArr = static_cast<double *>(head->value);
196             std::vector<double> doubleVec(doubleArr, doubleArr + head->size);
197             InnerSetWantParamsArrayDouble(key, doubleVec, wantP);
198         } else if (head->valueType == FD_PTR_TYPE) { // FD*
199             InnerSetWantParamsArrayFD(head, head->size, wantP);
200         }
201     }
202 }
203 
MallocCString(const std::string & origin)204 char *MallocCString(const std::string &origin)
205 {
206     if (origin.empty()) {
207         return nullptr;
208     }
209     auto len = origin.length() + 1;
210     char *res = static_cast<char *>(malloc(sizeof(char) * len));
211     if (res == nullptr) {
212         return nullptr;
213     }
214     return std::char_traits<char>::copy(res, origin.c_str(), len);
215 }
216 
MallocCString(const std::string & origin,int32_t & code)217 char *MallocCString(const std::string &origin, int32_t &code)
218 {
219     if (origin.empty() || code != NO_ERROR) {
220         return nullptr;
221     }
222     auto len = origin.length() + 1;
223     char *res = static_cast<char *>(malloc(sizeof(char) * len));
224     if (res == nullptr) {
225         code = ERR_NO_MEMORY;
226         return nullptr;
227     }
228     return std::char_traits<char>::copy(res, origin.c_str(), len);
229 }
230 
InnerWrapWantParamsString(WantParams & wantParams,CParameters * p)231 int32_t InnerWrapWantParamsString(WantParams &wantParams, CParameters *p)
232 {
233     auto value = wantParams.GetParam(p->key);
234     AAFwk::IString *ao = AAFwk::IString::Query(value);
235     if (ao == nullptr) {
236         return NONE_VALUE;
237     }
238     std::string natValue = OHOS::AAFwk::String::Unbox(ao);
239     p->value = MallocCString(natValue);
240     p->size = static_cast<int64_t>(natValue.length()) + 1;
241     p->valueType = STR_TYPE;
242     return NO_ERROR;
243 }
244 
245 template <class TBase, class T, class NativeT>
InnerWrapWantParamsT(WantParams & wantParams,CParameters * p)246 int32_t InnerWrapWantParamsT(WantParams &wantParams, CParameters *p)
247 {
248     auto value = wantParams.GetParam(p->key);
249     TBase *ao = TBase::Query(value);
250     if (ao == nullptr) {
251         return NONE_VALUE;
252     }
253     NativeT natValue = T::Unbox(ao);
254     NativeT *ptr = static_cast<NativeT *>(malloc(sizeof(NativeT)));
255     if (ptr == nullptr) {
256         return ERR_NO_MEMORY;
257     }
258     *ptr = natValue;
259     p->value = static_cast<void*>(ptr);
260     p->size = sizeof(NativeT);
261     return NO_ERROR;
262 }
263 
InnerWrapWantParamsArrayString(sptr<AAFwk::IArray> & ao,CParameters * p)264 int32_t InnerWrapWantParamsArrayString(sptr<AAFwk::IArray> &ao, CParameters *p)
265 {
266     long size = 0;
267     if (ao->GetLength(size) != ERR_OK) {
268         return ERR_CES_FAILED;
269     }
270     if (size == 0) {
271         return ERR_CES_FAILED;
272     }
273     char **arrP = static_cast<char **>(malloc(sizeof(char *) * size));
274     if (arrP == nullptr) {
275         return ERR_NO_MEMORY;
276     }
277     for (long i = 0; i < size; i++) {
278         sptr<AAFwk::IInterface> iface = nullptr;
279         if (ao->Get(i, iface) == ERR_OK) {
280             AAFwk::IString *iValue = AAFwk::IString::Query(iface);
281             if (iValue != nullptr) {
282                 auto val = AAFwk::String::Unbox(iValue);
283                 arrP[i] = MallocCString(val);
284             }
285         }
286     }
287     p->size = size;
288     p->value = static_cast<void *>(arrP);
289     return NO_ERROR;
290 }
291 
ClearParametersPtr(CParameters ** ptr,int count,bool isKey)292 void ClearParametersPtr(CParameters **ptr, int count, bool isKey)
293 {
294     CParameters *p = *ptr;
295     for (int i = 0; i < count; i++) {
296         free(p[i].key);
297         free(p[i].value);
298         p[i].key = nullptr;
299         p[i].value = nullptr;
300     }
301     if (!isKey) {
302         free(p[count].key);
303         p[count].key = nullptr;
304     }
305     free(*ptr);
306     *ptr = nullptr;
307 }
308 
309 template <class TBase, class T, class NativeT>
InnerWrapWantParamsArrayT(sptr<AAFwk::IArray> & ao,CParameters * p)310 int32_t InnerWrapWantParamsArrayT(sptr<AAFwk::IArray> &ao, CParameters *p)
311 {
312     long size = 0;
313     if (ao->GetLength(size) != ERR_OK) {
314         return ERR_CES_FAILED;
315     }
316     if (size == 0) {
317         return ERR_CES_FAILED;
318     }
319     NativeT *arrP = static_cast<NativeT *>(malloc(sizeof(NativeT) * size));
320     if (arrP == nullptr) {
321         return ERR_NO_MEMORY;
322     }
323     for (long i = 0; i < size; i++) {
324         sptr<AAFwk::IInterface> iface = nullptr;
325         if (ao->Get(i, iface) == ERR_OK) {
326             TBase *iValue = TBase::Query(iface);
327             if (iValue != nullptr) {
328                 arrP[i] = T::Unbox(iValue);
329             }
330         }
331     }
332     p->size = size;
333     p->value = static_cast<void *>(arrP);
334     return NO_ERROR;
335 }
336 
GetFDValue(WantParams & wantParams,std::string key,int * ptr)337 int32_t GetFDValue(WantParams &wantParams, std::string key, int *ptr)
338 {
339     auto value = wantParams.GetParam(key);
340     AAFwk::IWantParams *o = AAFwk::IWantParams::Query(value);
341     if (o == nullptr) {
342         return NONE_VALUE;
343     }
344     AAFwk::WantParams wp = AAFwk::WantParamWrapper::Unbox(o);
345     value = wp.GetParam(VALUE_PROPERTY);
346     AAFwk::IInteger *ao = AAFwk::IInteger::Query(value);
347     if (ao == nullptr) {
348         return NONE_VALUE;
349     }
350     *ptr = OHOS::AAFwk::Integer::Unbox(ao);
351     return NO_ERROR;
352 }
353 
InnerWrapWantParamsFd(WantParams & wantParams,CParameters * p)354 int32_t InnerWrapWantParamsFd(WantParams &wantParams, CParameters *p)
355 {
356     int *ptr = static_cast<int *>(malloc(sizeof(int)));
357     if (ptr == nullptr) {
358         return ERR_NO_MEMORY;
359     }
360     int error = GetFDValue(wantParams, std::string(p->key), ptr);
361     if (error != NO_ERROR) {
362         free(ptr);
363         return error;
364     }
365     p->value = static_cast<void*>(ptr);
366     p->size = sizeof(int32_t);
367     p->valueType = FD_TYPE;
368     return NO_ERROR;
369 }
370 
InnerWrapWantParamsArrayFd(sptr<AAFwk::IArray> & ao,CParameters * p)371 int32_t InnerWrapWantParamsArrayFd(sptr<AAFwk::IArray> &ao, CParameters *p)
372 {
373     long size = 0;
374     if (ao->GetLength(size) != ERR_OK) {
375         return ERR_CES_FAILED;
376     }
377     if (size == 0) {
378         return ERR_CES_FAILED;
379     }
380     int *arrP = static_cast<int *>(malloc(sizeof(int) * size));
381     if (arrP == nullptr) {
382         return ERR_NO_MEMORY;
383     }
384     for (long i = 0; i < size; i++) {
385         sptr<AAFwk::IInterface> iface = nullptr;
386         if (ao->Get(i, iface) == ERR_OK) {
387             AAFwk::IWantParams *iValue = AAFwk::IWantParams::Query(iface);
388             if (iValue == nullptr) {
389                 free(arrP);
390                 return ERR_CES_FAILED;
391             }
392             WantParams wantP = AAFwk::WantParamWrapper::Unbox(iValue);
393             int ret = GetFDValue(wantP, std::string(p->key), arrP + i);
394             if (ret != NO_ERROR) {
395                 free(arrP);
396                 return ret;
397             }
398         }
399     }
400     p->size = size;
401     p->value = arrP;
402     p->valueType = FD_PTR_TYPE;
403     return NO_ERROR;
404 }
405 
InnerWrapWantParamsArray(WantParams & wantParams,sptr<AAFwk::IArray> & ao,CParameters * p)406 int32_t InnerWrapWantParamsArray(WantParams &wantParams, sptr<AAFwk::IArray> &ao, CParameters *p)
407 {
408     if (AAFwk::Array::IsStringArray(ao)) {
409         p->valueType = STR_PTR_TYPE;
410         return InnerWrapWantParamsArrayString(ao, p);
411     } else if (AAFwk::Array::IsBooleanArray(ao)) {
412         p->valueType = BOOL_PTR_TYPE;
413         return InnerWrapWantParamsArrayT<AAFwk::IBoolean, AAFwk::Boolean, bool>(ao, p);
414     } else if (AAFwk::Array::IsIntegerArray(ao)) {
415         p->valueType = I32_PTR_TYPE;
416         return InnerWrapWantParamsArrayT<AAFwk::IInteger, AAFwk::Integer, int>(ao, p);
417     } else if (AAFwk::Array::IsLongArray(ao)) {
418         p->valueType = I64_PTR_TYPE;
419         return InnerWrapWantParamsArrayT<AAFwk::ILong, AAFwk::Long, int64_t>(ao, p);
420     } else if (AAFwk::Array::IsDoubleArray(ao)) {
421         p->valueType = DOUBLE_PTR_TYPE;
422         return InnerWrapWantParamsArrayT<AAFwk::IDouble, AAFwk::Double, double>(ao, p);
423     } else {
424         p->valueType = FD_PTR_TYPE;
425         return InnerWrapWantParamsArrayFd(ao, p);
426     }
427 }
428 } // namespace::OHOS::AccountSA