• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2021 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 DSLM_CRED_H
17 #define DSLM_CRED_H
18 
19 #include <stdbool.h>
20 #include <stdint.h>
21 
22 #include "device_security_defines.h"
23 
24 #define CRED_INFO_VERSION_LEN 32
25 #define CRED_INFO_TYPE_LEN 32
26 #define CRED_INFO_SIGNTIME_LEN 32
27 #define CRED_INFO_UDID_LEN 80
28 #define CRED_INFO_MANU_LEN 64
29 #define CRED_INFO_MODEL_LEN 64
30 #define CRED_INFO_BRAND_LEN 64
31 #define CRED_INFO_LEVEL_LEN 16
32 #define CRED_INFO_SOFTVERSION_LEN 64
33 
34 typedef enum {
35     CRED_TYPE_MINI = 1000,
36     CRED_TYPE_SMALL = 2000,
37     CRED_TYPE_STANDARD = 3000,
38     CRED_TYPE_LARGE = 4000,
39 } CredType;
40 
41 typedef struct DslmCredInfo {
42     char version[CRED_INFO_VERSION_LEN]; // the cred version
43     char type[CRED_INFO_TYPE_LEN];       // debug or release
44     char signTime[CRED_INFO_SIGNTIME_LEN];
45     char udid[CRED_INFO_UDID_LEN];
46     char manufacture[CRED_INFO_MANU_LEN];
47     char model[CRED_INFO_MODEL_LEN];
48     char brand[CRED_INFO_BRAND_LEN];
49     char securityLevel[CRED_INFO_LEVEL_LEN];
50     char softwareVersion[CRED_INFO_SOFTVERSION_LEN];
51     CredType credType;  // the parsed and validated type value, assigned only after verification.
52     uint32_t credLevel; // the parsed level value, assigned only after verification.
53 } DslmCredInfo;
54 
55 #define MAX_CRED_ARRAY_SIZE 48
56 typedef struct RequestObject {
57     uint32_t version;
58     uint64_t challenge;
59     uint32_t arraySize;
60     CredType credArray[MAX_CRED_ARRAY_SIZE];
61 } RequestObject;
62 
63 typedef struct DslmCredBuff {
64     CredType type;
65     uint32_t credLen;
66     uint8_t *credVal;
67 } DslmCredBuff;
68 
69 typedef int32_t InitDslmCredFunc(DslmCredInfo *credInfo);
70 
71 typedef int32_t RequestDslmCredFunc(const DeviceIdentify *device, const RequestObject *obj, DslmCredBuff **credBuff);
72 typedef int32_t VerifyDslmCredFunc(const DeviceIdentify *device, uint64_t challenge, const DslmCredBuff *credBuff,
73     DslmCredInfo *credInfo);
74 
75 typedef struct ProcessDslmCredFunctions {
76     InitDslmCredFunc *initFunc;
77     RequestDslmCredFunc *requestFunc;
78     VerifyDslmCredFunc *verifyFunc;
79     uint32_t credTypeCnt;
80     CredType credTypeArray[MAX_CRED_ARRAY_SIZE];
81 } ProcessDslmCredFunctions;
82 
83 #ifdef __cplusplus
84 extern "C" {
85 #endif
86 
87 bool InitDslmCredentialFunctions(const ProcessDslmCredFunctions *func);
88 
89 DslmCredBuff *CreateDslmCred(CredType type, uint32_t len, uint8_t *value);
90 
91 void DestroyDslmCred(DslmCredBuff *credBuff);
92 
93 #ifdef __cplusplus
94 }
95 #endif
96 #endif // DSLM_CRED_H
97