OpenHarmony源码分析之分布式软总线:authmanager/auth_conn.h

一、概述

该头文件定义了与设备认证连接相关的接口、宏和结构体,本文将对其深刻含义进行介绍。

二、源码分析

auth_conn.h

arduino 复制代码
/*
 * Copyright (c) 2020 Huawei Device Co., Ltd.
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *    http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
#ifndef LITE_AUTH_CONN_H
#define LITE_AUTH_CONN_H
#include "cJSON.h"
#include "common_info_manager.h"
#include "comm_defs.h"
#define MESSAGE_INDEX_LEN 4     //消息索引长度
#define MESSAGE_GCM_NONCE_LEN 12    //GCM加密的消息的NONCE长度
#define MESSAGE_GCM_MAC_LEN 16      //GCM加密的消息的MAC长度
#define MESSAGE_ENCRYPT_OVER_HEAD_LEN (MESSAGE_INDEX_LEN + MESSAGE_GCM_NONCE_LEN + MESSAGE_GCM_MAC_LEN)     //GCM加密的消息的头部长度
#define DEFAULT_BUF_SIZE 1536   //默认缓冲区大小
#define PACKET_HEAD_SIZE 24     //认证协议数据包头部长度
#define PACKET_DATA_SIZE (DEFAULT_BUF_SIZE - PACKET_HEAD_SIZE)
#define PKG_HEADER_IDENTIFIER 0xBABEFACE    //数据包标识号
#define ONLINE_UNKNOWN 0    //未知状态设备
#define ONLINE_YES 1        //在线设备
#define ONLINE_NO (-1)      //离线设备
/*数据包类型*/
#define MODULE_NONE 0
#define MODULE_TRUST_ENGINE 1   //可信设备
#define MODULE_HICHAIN 2
#define MODULE_AUTH_SDK 3       //待认证设备
#define MODULE_HICHAIN_SYNC 4
#define MODULE_CONNECTION 5     //验证IP和设备id
#define MODULE_SESSION 6
#define MODULE_SMART_COMM 7
#define MODULE_AUTH_CHANNEL 8
#define MODULE_AUTH_MSG 9
#define FLAG_REPLY 1    //表示回复消息
#define AUTH_UNKNOWN 0  
#define AUTH_INIT 1
/*用于设备通信的数据缓冲区*/
typedef struct DataBuffer {
    char *buf;//缓冲区首地址
    int size;//缓冲区大小
    int used;//缓冲区已使用量
} DataBuffer;
/*AuthConn结构体用于保存已建立socket连接的身份认证设备的基本信息以及状态信息*/
typedef struct AuthConn {
    int fd;//通信套接字描述符
    char authId[MAX_AUTH_ID_LEN];//身份认证id
    char deviceId[MAX_DEV_ID_LEN];//设备id
    char deviceIp[MAX_DEV_IP_LEN];//设备IP
    int busVersion;//总线版本
    int authPort;//认证通道端口
    int sessionPort;//会话通道端口
    int authState;//认证状态
    int onlineState;//设备在线状态
    DataBuffer db;//数据缓冲区
} AuthConn;
/*设备身份认证连接节点*/
typedef struct AuthConnNode {
    List head;
    AuthConn *aconn;
} AuthConnNode;
/*设备连接信息*/
typedef struct ConnInfo {
    int maxVersion;//最大版本号
    int minVersion;//最小版本号
    char deviceName[MAX_DEV_NAME_LEN];//设备名称
    char deviceType[MAX_DEV_TYPE_LEN];//设备类型
} ConnInfo;
int AuthConnRecv(int fd, char *buf, int offset, int count, int timeout);//接收设备认证过程中传输的数据
int AuthConnPostBytes(int fd, int module, int flags, long long seq, const char *data);//按字节构造身份认证连接的POST消息并通过TCP协议发送
int AuthConnPostMessage(int fd, int module, int flags, long long seqNum, const cJSON *msg);//构造/封装身份认证Post消息并发送给对端
bool ModuleUseCipherText(int module);//根据module参数判断是否使用密文传输
unsigned char* AuthConnPackBytes(int module, int flags, long long seqNum, const char *str, int *bufLen);//按字节构造设备身份认证数据包
#endif

DD一下: 欢迎大家关注公众号<程序猿百晓生>,可以了解到一下知识点。

erlang 复制代码
1.OpenHarmony开发基础
2.OpenHarmony北向开发环境搭建
3.鸿蒙南向开发环境的搭建
4.鸿蒙生态应用开发白皮书V2.0 & V3.0
5.鸿蒙开发面试真题(含参考答案) 
6.TypeScript入门学习手册
7.OpenHarmony 经典面试题(含参考答案)
8.OpenHarmony设备开发入门【最新版】
9.沉浸式剖析OpenHarmony源代码
10.系统定制指南
11.【OpenHarmony】Uboot 驱动加载流程
12.OpenHarmony构建系统--GN与子系统、部件、模块详解
13.ohos开机init启动流程
14.鸿蒙版性能优化指南
.......
相关推荐
Bug退退退1235 小时前
RabbitMQ 高级特性之死信队列
java·分布式·spring·rabbitmq
Georgewu6 小时前
【HarmonyOS】鸿蒙应用开发Text控件常见错误
harmonyos
prince056 小时前
Kafka 生产者和消费者高级用法
分布式·kafka·linq
菜萝卜子7 小时前
【Project】基于kafka的高可用分布式日志监控与告警系统
分布式·kafka
Georgewu7 小时前
【HarmonyOS】富文本编辑器RichEditor详解
harmonyos
kyle~9 小时前
计算机视觉---RealSense深度相机技术
人工智能·数码相机·计算机视觉·机器人·嵌入式·ros·传感器
zhanshuo14 小时前
鸿蒙应用调试与测试实战全指南:高效定位问题,性能优化必备技巧+实用代码示例
harmonyos
幼稚园的山代王14 小时前
RabbitMQ 4.1.1初体验-队列和交换机
分布式·rabbitmq·ruby
小新学习屋15 小时前
Spark从入门到熟悉(篇三)
大数据·分布式·spark
万少18 小时前
2025中了 聊一聊程序员为什么都要做自己的产品
前端·harmonyos