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.鸿蒙版性能优化指南
.......
相关推荐
此木|西贝20 分钟前
【Kafka】Kafka生产者如何实现冥等的?
分布式·kafka
mysql学习中29 分钟前
kafka基础
分布式·kafka
__Benco6 小时前
OpenHarmony子系统开发 - 电源管理(二)
人工智能·harmonyos
嗯嗲和滴7 小时前
消息队列(Kafka及RocketMQ等对比联系)
分布式·kafka·rocketmq
FreakStudio7 小时前
一文速通Python并行计算:03 Python多线程编程-多线程同步(上)—基于互斥锁、递归锁和信号量
python·嵌入式·多线程·面向对象·并行计算·线程同步·电子diy
Vic101018 小时前
基于Zookeeper的微服务配置管理与灰度发布实战指南
分布式·微服务·zookeeper
无级程序员11 小时前
银行分布式新核心的部署架构(两地三中心)
分布式·架构
天草二十六_简村人12 小时前
Rabbitmq消息被消费时抛异常,进入Unacked 状态,进而导致消费者不断尝试消费(下)
java·spring boot·分布式·后端·rabbitmq
RainbowJie112 小时前
RabbitMQ 快速入门
分布式·rabbitmq