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