1 /*
2  * Copyright (C) 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 #include "compatible_sub_session.h"
17 
18 #include "compatible_bind_sub_session.h"
19 #include "compatible_auth_sub_session.h"
20 #include "hc_log.h"
21 
CreateCompatibleSubSession(SubSessionTypeValue sessionType,CJson * jsonParams,const DeviceAuthCallback * callback,CompatibleBaseSubSession ** session)22 int32_t CreateCompatibleSubSession(SubSessionTypeValue sessionType, CJson *jsonParams,
23     const DeviceAuthCallback *callback, CompatibleBaseSubSession **session)
24 
25 {
26     if (jsonParams == NULL || callback == NULL || session == NULL) {
27         LOGE("Invalid input params!");
28         return HC_ERR_INVALID_PARAMS;
29     }
30     switch (sessionType) {
31         case TYPE_CLIENT_BIND_SUB_SESSION:
32             return CreateClientBindSubSession(jsonParams, callback, session);
33         case TYPE_SERVER_BIND_SUB_SESSION:
34             return CreateServerBindSubSession(jsonParams, callback, session);
35         case TYPE_CLIENT_AUTH_SUB_SESSION:
36             return CreateClientAuthSubSession(jsonParams, callback, session);
37         case TYPE_SERVER_AUTH_SUB_SESSION:
38             return CreateServerAuthSubSession(jsonParams, callback, session);
39         default:
40             LOGE("Invalid session type!");
41             return HC_ERR_INVALID_PARAMS;
42     }
43 }
44 
ProcessCompatibleSubSession(CompatibleBaseSubSession * session,CJson * in,CJson ** out,int32_t * status)45 int32_t ProcessCompatibleSubSession(CompatibleBaseSubSession *session, CJson *in, CJson **out, int32_t *status)
46 {
47     if (session == NULL || in == NULL || out == NULL || status == NULL) {
48         LOGE("Invalid input params!");
49         return HC_ERR_INVALID_PARAMS;
50     }
51     switch (session->type) {
52         case TYPE_CLIENT_BIND_SUB_SESSION:
53             return ProcessClientBindSubSession(session, in, out, status);
54         case TYPE_SERVER_BIND_SUB_SESSION:
55             return ProcessServerBindSubSession(session, in, status);
56         case TYPE_CLIENT_AUTH_SUB_SESSION:
57             return ProcessClientAuthSubSession(session, in, out, status);
58         case TYPE_SERVER_AUTH_SUB_SESSION:
59             return ProcessServerAuthSubSession(session, in, status);
60         default:
61             LOGE("Invalid session type!");
62             return HC_ERR_INVALID_PARAMS;
63     }
64 }
65 
DestroyCompatibleSubSession(CompatibleBaseSubSession * session)66 void DestroyCompatibleSubSession(CompatibleBaseSubSession *session)
67 {
68     if (session == NULL) {
69         LOGE("Input session is null!");
70         return;
71     }
72     switch (session->type) {
73         case TYPE_CLIENT_BIND_SUB_SESSION:
74         case TYPE_SERVER_BIND_SUB_SESSION:
75             DestroyCompatibleBindSubSession(session);
76             return;
77         case TYPE_CLIENT_AUTH_SUB_SESSION:
78         case TYPE_SERVER_AUTH_SUB_SESSION:
79             DestroyCompatibleAuthSubSession(session);
80             return;
81         default:
82             LOGE("Invalid session type!");
83     }
84 }