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 #define FIELD_IS_SINGLE_CRED "isSingleCred" 135 136 #define INVALID_MODULE_TYPE (-1) 137 #define GROUP_ERR_MSG 0x8080 138 139 #define CLIENT 1 140 #define SERVER 0 141 142 #define CREATE_KEY_PAIR 1 143 #define DELETE_KEY_PAIR 2 144 145 /* DefaultValue */ 146 #define DEFAULT_MEMORY_SIZE 64 147 #define DEFAULT_USER_ID_HASH "" 148 #define DEFAULT_REQUEST_ID 0 149 #define DEFAULT_CHANNEL_ID (-1) 150 #define DEFAULT_EXPIRE_TIME 90 151 #define DEFAULT_SERVICE_TYPE "service.type.default" 152 #define SERVICE_TYPE_IMPORT "service.type.import" 153 #define DEFAULT_PACKAGE_NAME "deviceauth_service" 154 #define GROUP_MANAGER_PACKAGE_NAME "com.huawei.devicegroupmanage" 155 #define DM_APP_ID "ohos.distributedhardware.devicemanager" 156 #define SOFTBUS_APP_ID "softbus_auth" 157 #define DEFAULT_RETURN_KEY_LENGTH 32 158 #define MAX_BUFFER_LEN 1024 159 #define MAX_DATA_BUFFER_SIZE 4096 160 #define MAX_AUTH_ID_LEN 256 161 162 #define IS_UPGRADE 1 163 #define IS_NOT_UPGRADE 0 164 165 #define COMPATIBLE_GROUP 512 166 #define GROUP_TYPE_INVALID (-1) 167 #define INVALID_OS_ACCOUNT (-1) 168 #define ALL_GROUP_VISIBILITY (-2) 169 #define INVALID_CRED 0 170 #define PUBLIC_KEY_MAX_LENGTH 128 171 #define PIN_CODE_LEN_SHORT 6 172 #define PIN_CODE_LEN_LONG 128 173 #define INVALID_PROTOCOL_EXPAND_VALUE (-1) 174 175 typedef enum { 176 NO_CHANNEL = 1, 177 SERVICE_CHANNEL = 2, 178 SOFT_BUS = 3, 179 } ChannelType; 180 181 typedef enum { 182 SELF_CREATED = 0, 183 IMPORTED_FROM_CLOUD = 1, 184 } RelationShipSource; 185 186 #define MAX_IN_PARAM_LEN 4096 187 188 #define CHECK_PTR_RETURN_NULL(ptr, paramTag) \ 189 do { \ 190 if ((ptr) == NULL) { \ 191 LOGE(paramTag " is null ptr"); \ 192 return NULL; \ 193 } \ 194 } while (0) 195 196 #define CHECK_PTR_RETURN_ERROR_CODE(ptr, paramTag) \ 197 do { \ 198 if ((ptr) == NULL) { \ 199 LOGE(paramTag " is null ptr"); \ 200 return HC_ERR_NULL_PTR; \ 201 } \ 202 } while (0) 203 204 #define CHECK_PTR_RETURN_NONE(ptr, paramTag) \ 205 do { \ 206 if ((ptr) == NULL) { \ 207 LOGE(paramTag " is null ptr"); \ 208 return; \ 209 } \ 210 } while (0) 211 212 #define GOTO_IF_ERR(x) do { \ 213 int32_t res = x; \ 214 if ((res) != HC_SUCCESS) { \ 215 goto ERR; \ 216 } \ 217 } while (0) 218 219 #define GOTO_IF_CHECK_NULL(ptr, paramTag) \ 220 do { \ 221 if ((ptr) == NULL) { \ 222 LOGE(paramTag " is null ptr"); \ 223 goto ERR; \ 224 } \ 225 } while (0) 226 227 #define GOTO_ERR_AND_SET_RET(x, res) do { \ 228 res = x; \ 229 if ((res) != HC_SUCCESS) { \ 230 goto ERR; \ 231 } \ 232 } while (0) 233 234 #define RETURN_IF_ERR(x) do { \ 235 int32_t res = x; \ 236 if ((res) != HC_SUCCESS) { \ 237 return res; \ 238 } \ 239 } while (0) 240 241 typedef enum { 242 ACCOUNT_RELATED_PLUGIN = 0x0010, 243 } EnumCredPluginType; 244 245 typedef enum { 246 DAS_MODULE = 0x0001, 247 ACCOUNT_MODULE = 0x0010, 248 } EnumModuleType; 249 250 typedef enum { 251 CONTINUE = 0, 252 IGNORE_MSG = 1, 253 FINISH, 254 } TaskStatus; 255 256 typedef enum { 257 CODE_NULL = 0, 258 OP_BIND = 1, 259 AUTHENTICATE = 2, 260 ADD_AUTH_INFO = 3, 261 REMOVE_AUTH_INFO = 4, 262 OP_UNBIND = 5, 263 AUTH_KEY_AGREEMENT = 6, 264 REGISTER = 7, 265 SECURE_CLONE = 8, 266 } OperationCode; 267 268 typedef enum { 269 IMPORT_SELF_CREDENTIAL = 0, 270 DELETE_SELF_CREDENTIAL = 1, 271 QUERY_SELF_CREDENTIAL_INFO = 2, 272 IMPORT_TRUSTED_CREDENTIALS = 3, 273 DELETE_TRUSTED_CREDENTIALS = 4, 274 QUERY_TRUSTED_CREDENTIALS = 5, 275 REQUEST_SIGNATURE = 6, 276 GET_SHARED_SECRET_BY_PEER_CERT = 8, 277 UPGRADE_DATA = 10, 278 CHECK_UPGRADE_IDENTITY = 11, 279 CHECK_UPGRADE_DATA = 12, 280 } CredentialCode; 281 282 #endif 283