1 /*
2  * Copyright (C) 2021-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 COMMON_DEFS_H
17 #define COMMON_DEFS_H
18 
19 #include "device_auth.h"
20 #include "device_auth_defines.h"
21 #include "hc_string.h"
22 #include "hc_vector.h"
23 #include "json_utils.h"
24 
25 #define FIELD_DEVICE_PK "devicePk"
26 #define FIELD_UDID "udid"
27 #define FIELD_PK_INFO_SIGNATURE "pkInfoSignature"
28 #define FIELD_CREDENTIAL "credential"
29 #define FIELD_SERVER_PK "serverPk"
30 
31 #define FIELD_ADD_TYPE "addType"
32 #define FIELD_ADD_ID "addId"
33 #define FIELD_ADD_KEY "addKey"
34 #define FIELD_AUTH_DATA "authData"
35 #define FIELD_AUTH_RETURN "authReturn"
36 #define FIELD_AUTH_ID "authId"
37 #define FIELD_AUTH_PK "authPk"
38 #define FIELD_ADD_AUTH_INFO "addAuthInfo"
39 #define FIELD_ADD_RETURN "addReturn"
40 #define FIELD_APP_ID "appId"
41 #define FIELD_BIND_SESSION_TYPE "bindSessionType"
42 #define FIELD_CHALLENGE "challenge"
43 #define FIELD_CHANNEL_ID "channelId"
44 #define FIELD_CHANNEL_TYPE "channelType"
45 #define FIELD_CONN_DEVICE_ID "connDeviceId"
46 #define FIELD_CONNECT_PARAMS "connectParams"
47 #define FIELD_CROSS_USER_ID_LIST "crossUserIdList"
48 #define FIELD_CURRENT_VERSION "currentVersion"
49 #define FIELD_DELETE_ID "deleteId"
50 #define FIELD_DELETED_RESULT "deletedResult"
51 #define FIELD_DEVICE_CLOUD_CREDENTIAL "devCloudCred"
52 #define FIELD_DEV_ID "devId"
53 #define FIELD_DEVICES_CREDENTIAL "devicesCredential"
54 #define FIELD_ENC_AUTH_TOKEN "encAuthToken"
55 #define FIELD_ENC_RESULT "encResult"
56 #define FIELD_ENC_DATA "encData"
57 #define FIELD_EPK "epk"
58 #define FIELD_EPK_LEN "epkLen"
59 #define FIELD_EX_AUTH_INFO "exAuthInfo"
60 #define FIELD_EXPIRE_TIME "expireTime"
61 #define FIELD_ERROR_CODE "errorCode"
62 #define FIELD_GROUP_INFO "groupInfo"
63 #define FIELD_GROUP_MANAGERS "groupManagers"
64 #define FIELD_GROUP_NAME "groupName"
65 #define FIELD_GROUP_OP "groupOp"
66 #define FIELD_GROUP_TYPE "groupType"
67 #define FIELD_GROUP_VISIBILITY "groupVisibility"
68 #define FIELD_IS_ADMIN "isAdmin"
69 #define FIELD_IS_ACCOUNT_BIND "isAccountBind"
70 #define FIELD_IS_BIND "isBind"
71 #define FIELD_IS_FORCE_DELETE "isForceDelete"
72 #define FIELD_IS_CREDENTIAL_EXISTS "isCredentialExists"
73 #define FIELD_IS_DIRECT_AUTH "isDirectAuth"
74 #define FIELD_KCF_DATA "kcfData"
75 #define FIELD_KEY_TYPE "keyType"
76 #define FIELD_TRUST_TYPE "trustType"
77 #define FIELD_MESSAGE "message"
78 #define FIELD_GROUP_ERROR_MSG "groupErrorMsg"
79 #define FIELD_MIN_VERSION "minVersion"
80 #define FIELD_GROUP_AND_MODULE_VERSION "groupAndModuleVersion"
81 #define FIELD_NONCE "nonce"
82 #define FIELD_OP_CODE "opCode"
83 #define FIELD_OPERATION_CODE "operationCode"
84 #define FIELD_OPERATION_PARAMS "operationParams"
85 #define FIELD_OWNER_ID "ownerId"
86 #define FIELD_OWNER_NAME "ownerName"
87 #define FIELD_PERMISSION "Permission"
88 #define FIELD_PAYLOAD "payload"
89 #define FIELD_PIN_CODE "pinCode"
90 #define FIELD_PUBLIC_KEY "publicKey"
91 #define FIELD_SIGN_ALG "signAlg"
92 #define FIELD_PK_INFO "pkInfo"
93 #define FIELD_REAL_INFO "realInfo"
94 #define FIELD_PSEUDONYM_ID "pseudonymId"
95 #define FIELD_INDEX_KEY "indexKey"
96 #define FIELD_PKG_NAME "pkgName"
97 #define FIELD_SELF_AUTH_ID "selfAuthId"
98 #define FIELD_SELF_DEVICE_ID "selfDeviceId"
99 #define FIELD_SELF_DEV_ID "selfDevId"
100 #define FIELD_SELF_USER_ID "selfUserId"
101 #define FIELD_REQUEST_ID "requestId"
102 #define FIELD_RECEIVED_DATA "receivedData"
103 #define FIELD_RETURN_CODE "returnCode"
104 #define FIELD_RETURN_DATA "returnData"
105 #define FIELD_RETURN_CODE_MAC "returnCodeMac"
106 #define FIELD_RMV_TYPE "rmvType"
107 #define FIELD_RMV_ID "rmvId"
108 #define FIELD_RMV_AUTH_INFO "rmvAuthInfo"
109 #define FIELD_RMV_RETURN "rmvReturn"
110 #define FIELD_SALT "salt"
111 #define FIELD_ISO_SALT "isoSalt"
112 #define FIELD_SEED "seed"
113 #define FIELD_SELF_TYPE "selfType"
114 #define FIELD_SEND_TO_PEER "sendToPeer"
115 #define FIELD_SEND_TO_SELF "sendToSelf"
116 #define FIELD_SHARED_USER_ID_LIST "sharedUserIdList"
117 #define FIELD_SUPPORT_256_MOD "support256mod"
118 #define FIELD_TOKEN "token"
119 #define FIELD_IS_UUID "uuIdAsDeviceId"
120 #define FIELD_VERSION "version"
121 #define FIELD_MK_AGREE_MSG "mkaMsg"
122 #define FIELD_PEER_ID_FROM_REQUEST "peerIdFromRequest"
123 #define FIELD_STEP "step"
124 #define FIELD_DATA "data"
125 #define FIELD_EPK "epk"
126 #define FIELD_AUTH_KEY_ALG_ENCODE "authKeyAlgEncode"
127 #define FIELD_AUTH_PK_INFO "authPkInfo"
128 #define FIELD_AUTH_PK_INFO_SIGN "authPkInfoSign"
129 #define FIELD_AUTH_RESULT_MAC "authResultMac"
130 #define FIELD_LOCAL_DEVICE_TYPE "localDeviceType"
131 #define FIELD_PLUGIN_EXT_DATA "originPeerData"
132 #define FIELD_META_NODE_TYPE "metaNodeType"
133 #define FIELD_UPGRADE_FLAG "upgradeFlag"
134 
135 #define INVALID_MODULE_TYPE (-1)
136 #define GROUP_ERR_MSG 0x8080
137 
138 #define CLIENT 1
139 #define SERVER 0
140 
141 #define CREATE_KEY_PAIR 1
142 #define DELETE_KEY_PAIR 2
143 
144 /* DefaultValue */
145 #define DEFAULT_MEMORY_SIZE 64
146 #define DEFAULT_USER_ID_HASH ""
147 #define DEFAULT_REQUEST_ID 0
148 #define DEFAULT_CHANNEL_ID (-1)
149 #define DEFAULT_EXPIRE_TIME 90
150 #define DEFAULT_SERVICE_TYPE "service.type.default"
151 #define SERVICE_TYPE_IMPORT "service.type.import"
152 #define DEFAULT_PACKAGE_NAME "deviceauth_service"
153 #define GROUP_MANAGER_PACKAGE_NAME "com.huawei.devicegroupmanage"
154 #define DM_APP_ID "ohos.distributedhardware.devicemanager"
155 #define SOFTBUS_APP_ID "softbus_auth"
156 #define DEFAULT_RETURN_KEY_LENGTH 32
157 #define MAX_BUFFER_LEN 1024
158 #define MAX_DATA_BUFFER_SIZE 4096
159 #define MAX_AUTH_ID_LEN 256
160 
161 #define IS_UPGRADE 1
162 #define IS_NOT_UPGRADE 0
163 
164 #define COMPATIBLE_GROUP 512
165 #define GROUP_TYPE_INVALID (-1)
166 #define INVALID_OS_ACCOUNT (-1)
167 #define ALL_GROUP_VISIBILITY (-2)
168 #define INVALID_CRED 0
169 #define PUBLIC_KEY_MAX_LENGTH 128
170 #define PIN_CODE_LEN_SHORT 6
171 #define PIN_CODE_LEN_LONG 128
172 #define INVALID_PROTOCOL_EXPAND_VALUE (-1)
173 
174 typedef enum {
175     NO_CHANNEL = 1,
176     SERVICE_CHANNEL = 2,
177     SOFT_BUS = 3,
178 } ChannelType;
179 
180 typedef enum {
181     SELF_CREATED = 0,
182     IMPORTED_FROM_CLOUD = 1,
183 } RelationShipSource;
184 
185 #define MAX_IN_PARAM_LEN 4096
186 
187 #define CHECK_PTR_RETURN_NULL(ptr, paramTag) \
188     do { \
189         if ((ptr) == NULL) { \
190             LOGE(paramTag " is null ptr"); \
191             return NULL; \
192         } \
193     } while (0)
194 
195 #define CHECK_PTR_RETURN_ERROR_CODE(ptr, paramTag) \
196     do { \
197         if ((ptr) == NULL) { \
198             LOGE(paramTag " is null ptr"); \
199             return HC_ERR_NULL_PTR; \
200         } \
201     } while (0)
202 
203 #define CHECK_PTR_RETURN_NONE(ptr, paramTag) \
204         do { \
205             if ((ptr) == NULL) { \
206                 LOGE(paramTag " is null ptr"); \
207                 return; \
208             } \
209         } while (0)
210 
211 #define GOTO_IF_ERR(x) do { \
212         int32_t res = x; \
213         if ((res) != HC_SUCCESS) { \
214             goto ERR; \
215         } \
216     } while (0)
217 
218 #define GOTO_IF_CHECK_NULL(ptr, paramTag) \
219     do { \
220         if ((ptr) == NULL) { \
221             LOGE(paramTag " is null ptr"); \
222             goto ERR; \
223         } \
224     } while (0)
225 
226 #define GOTO_ERR_AND_SET_RET(x, res) do { \
227         res = x; \
228         if ((res) != HC_SUCCESS) { \
229             goto ERR; \
230         } \
231     } while (0)
232 
233 #define RETURN_IF_ERR(x) do { \
234         int32_t res = x; \
235         if ((res) != HC_SUCCESS) { \
236             return res; \
237         } \
238     } while (0)
239 
240 typedef enum {
241     ACCOUNT_RELATED_PLUGIN = 0x0010,
242 } EnumCredPluginType;
243 
244 typedef enum {
245     DAS_MODULE = 0x0001,
246     ACCOUNT_MODULE = 0x0010,
247 } EnumModuleType;
248 
249 typedef enum {
250     CONTINUE = 0,
251     IGNORE_MSG = 1,
252     FINISH,
253 } TaskStatus;
254 
255 typedef enum {
256     CODE_NULL = 0,
257     OP_BIND = 1,
258     AUTHENTICATE = 2,
259     ADD_AUTH_INFO = 3,
260     REMOVE_AUTH_INFO = 4,
261     OP_UNBIND = 5,
262     AUTH_KEY_AGREEMENT = 6,
263     REGISTER = 7,
264     SECURE_CLONE = 8,
265 } OperationCode;
266 
267 typedef enum {
268     IMPORT_SELF_CREDENTIAL = 0,
269     DELETE_SELF_CREDENTIAL = 1,
270     QUERY_SELF_CREDENTIAL_INFO = 2,
271     IMPORT_TRUSTED_CREDENTIALS = 3,
272     DELETE_TRUSTED_CREDENTIALS = 4,
273     QUERY_TRUSTED_CREDENTIALS = 5,
274     REQUEST_SIGNATURE = 6,
275     GET_SHARED_SECRET_BY_PEER_CERT = 8,
276     UPGRADE_DATA = 10,
277     CHECK_UPGRADE_IDENTITY = 11,
278     CHECK_UPGRADE_DATA = 12,
279 } CredentialCode;
280 
281 #endif
282