Matter学习笔记(3)——交互模型

news2025/1/16 21:43:30

一、简介

1.1 交互方式

交互模型层定义了客户端和服务器设备之间可以执行哪些交互。发起交互的节点称为发起者(通常为客户端设备),作为交互的接收者的节点称为目标(通常为服务器设备)。

节点通过以下方式进行交互:

  • 读取属性和事件
  • 订阅属性和事件(此交互用于创建与目标的订阅,以便定期接收来自目标的数据报告,而不是轮询数据。)
  • 写入属性
  • 调用命令

Matter 设备实现互联互通,主要是靠在上层定义了一套统一的 Data Model(数据模型), 在这套设备模型里面,设备内的逻辑功能单元是用 EndPoint 来表示的。每个 EndPoint 的功能有若干个 Culsters 来描述。 通讯的过程是有本地的 EndPoint 和远端的 EndPoint 来交互完成的,这个交互过程称之为 Interaction

1.2 群组

Matter 中的节点可以属于一个。设备组是一种机制,用于在同一 Action 中同时寻址和向多台设备发送消息。一个群组中的所有节点共享同一群组 ID(一个 16 位整数)。

为了完成群组级别的通信(群组广播),Matter 利用 IPv6 Multicast 消息,并且所有群组成员具有相同的 Multicast 地址。

1.3 路径

每当我们想要与属性、事件或命令互动时,都必须指定此互动的路径:属性、事件或命令在节点数据模型层次结构中的位置。需要注意的是,路径可能还会使用通配符运算符来同时寻址多个节点或集群,从而聚合这些互动,从而减少操作数量。

此机制对于提高通信的响应速度非常重要。例如,当用户想要关闭所有灯时,语音助理可以与一组灯中的多个灯建立单次互动,而不是与一系列单独的互动互动。如果发起者与每个指示灯创建单独的交互,则可能会在设备响应速度方面产生人可感知的延迟。这种效果会导致多台设备对命令做出响应,且设备之间会有明显延迟。

可以使用以下某个选项组合 Matter 中的路径:

<path> = <node> <endpoint> <cluster> <attribute | event | command>
<path> = <group ID>        <cluster> <attribute | event | command>

在这些路径构建块中,endpointcluster 还可能包含用于选择多个节点实例的通配符运算符。

1.4 可计时和无计时

有两种执行写入或调用 Matter 的方式:计时的和非计时的。计时事务为写入/调用操作的发送建立了一个超时上限。这个超时的目的是为了防止针对事务的拦截攻击。它特别适用于对控制资产进行访问的设备,如车库开门器和锁。

二、交互模型的层次结构

每当节点与另一个节点建立加密的通信序列时,它们就构成了交互关系。每次交互都由一个或多个事务组成,事务由一项或多项操作组成,这些操作可理解为节点之间的即时通讯级消息。

事务支持多项 Action,如从其他节点请求属性或事件的读取请求操作,或其响应,即报告数据操作,用于将信息从服务器传回客户端。

三、读取交互

3.1 读取请求操作

  • 属性请求:包含零个或多个 Target 属性的列表。此列表包含零个或多个指向目标所请求属性的路径。
  • 事件请求:包含目标所请求事件的零个或多个路径的列表。
    在目标收到读取请求操作后,它会使用所请求的信息组合一个报告数据操作。

3.2 报告数据操作

  • 属性报告:读取操作请求中请求的零个或多个已报告属性的列表。
  • 事件报告:包含零个或多个被报告事件的列表。
  • 抑制响应:一个标志,用于确定是否应抑制对此操作的状态响应
  • 订阅 ID:如果此报告是订阅交互的一部分,则必须包含一个用于标识订阅交互的整数。

3.3 状态响应操作

Initiator 收到请求的数据后,默认情况下必须生成状态响应操作。此操作从 Initiator 发送,确认已收到所报告的数据。如果已设置“抑制状态响应”标志,Initiator 不得发送状态响应操作。

Initiator 发送状态响应操作后,或启用“禁止响应”标志的 Initiator 收到报告数据操作后,读取交互完成。

状态响应操作只包含一个 status 字段,该字段将确认操作成功或显示失败代码。

3.4 读取限制

读取请求操作和报告数据操作仅限 Unicast。此外,这些请求的路径不能定位一组节点。

状态响应操作仅限 Unicast,不能作为对组播的响应生成。

四、写入交互(非定时)

4.1 写入请求操作

  • 写入请求:包含一个或多个元组(包含路径和数据)的列表。
  • 定时请求:指示此操作是否属于定时写入交互的标志。
  • 抑制响应:一个标志,用于确定是否应抑制对此操作的状态响应

4.2 写入回复操作

  • 写入响应:针对写入请求操作发送的每个写入请求的路径和错误代码列表。

4.3 非定时写入限制

写入请求操作可能是组播,但在这种情况下必须设置“禁止响应”标志。其原因在于,网络可能会被群组中每个成员的同步响应所淹没。

如需启用此行为,“写入请求”列表中使用的路径可以包含群组,也可能包含通配符,但仅限于“端点”字段。

五、写入交互(定时)

5.1 定时请求操作

  • Timeout:此事务可以保持打开状态的毫秒数。在此期间,Initiator 发送的下一项操作将被视为有效。

收到定时请求操作后,Target 必须使用状态响应操作确认定时请求操作。一旦 Initiator 收到未报告任何错误的状态响应操作,就会发送写入请求操作。

5.2 写入请求操作

与上文所述的写入请求操作相同。

5.3 写入回复操作

与上文所述的写入回复操作相同。

5.4 定时写入限制

定时请求操作、写入请求操作和写入响应操作是单播操作。

六、调用命令交互(非定时)

6.1 调用请求操作

  • 调用请求:集群命令的路径列表,以及命令的可选参数(名为命令字段)。
  • 定时请求:一个标志,用于指示此操作是否为定时调用命令交互的一部分。
  • 抑制响应:一个标志,用于指示是否应抑制调用响应操作。
  • 互动 ID:一个整数,用于将调用请求操作与调用响应操作进行匹配。

6.2 调用响应操作

  • 调用响应:每个发送的调用请求的命令响应或状态列表。
  • 互动 ID:一个整数,用于将调用请求操作与调用响应操作进行匹配。

6.2 非定时调用限制

调用请求操作可能是组播,但在这种情况下必须设置“禁止响应”标志。其原因在于,网络可能会被组中每个成员的同步响应应所淹没。

如需启用此行为,“调用请求”列表中使用的路径可能包含群组,也可能包含通配符,但仅限于“端点”字段。此外,如果 Action 是组播,则事务将终止,并且没有响应。

七、调用命令交互(定时)

7.1 定时请求操作

  • Timeout:此事务可以保持打开状态的毫秒数。在此期间,Initiator 发送的下一项操作将被视为有效。

收到定时请求操作后,Target 必须使用状态响应操作确认定时请求操作。一旦 Initiator 收到未报告任何错误的状态响应操作,就会发送调用请求操作。

7.2 调用请求操作

与上文所述的调用请求操作相同。

7.3 调用响应操作

与上文所述的调用响应操作相同。

7.4 定时调用限制

定时请求操作、调用请求操作和调用响应操作仅限 Unicast,因此是单播操作。

调用请求操作支持使用包含群组的路径以及通配符,但调用响应操作不支持通配符。

八、订阅交互

8.1 订阅请求操作

  • 最小间隔时间:报告之间的最小时间间隔。
  • 最大间隔时间:报告之间的最大时间间隔。
  • 属性报告:读取操作请求中请求的零个或多个已报告属性的列表。
  • 最大间隔时间:包含零个或多个所报告事件的列表。

发出订阅请求后,Target 会使用一个包含第一批报告数据的报告数据操作来响应发起方:Primed Publish Data

然后,Initiator 会确认报告数据操作,并将状态响应操作发送至目标。一旦目标收到没有报告任何错误的状态响应操作,就会发送订阅响应操作。

随后,Target 将按协商的时间间隔定期发送报告数据操作,Initiator 将响应这些操作,直到订阅丢失或取消订阅。

8.2 订阅请求操作

  • 订阅 ID:用于标识订阅的整数。
  • 最小间隔:报告之间的最终确定的最小间隔。
  • 最大间隔:报告之间的最终确定的最大间隔。

8.3 订阅限制

  • 订阅请求操作和订阅响应操作是仅限 Unicast 的操作。
  • 订阅互动中的所有报告数据操作都必须具有相同的订阅 ID。
  • 如果 Initiator 未在操作之间的最大协商间隔内收到报告数据操作,订阅将终止。
  • 由于上述规则,Initiator 只需停止发送定期报告数据操作即可终止订阅互动。
  • Initiator 可通过使用 INACTIVE_SUBSCRIPTION 状态代码响应报告数据操作来终止订阅互动。

九、交互示例:门锁

以下部分介绍了交互类型的示例。这些示例使用虚构的 Matter 控制器作为交互发起者,使用门锁设备作为交互目标。

  • 读取交互
    Matter 控制器可以使用读取交互从门锁设备的数据模型层读取一个或多个属性或事件。例如,Matter 控制器可以读取集群 LockType 的属性 DoorLock,以向用户显示适当的图标。下图显示了完成此交互需要交换的操作。

  • 写入交互
    写入交互可用于修改门锁设备的一个或多个属性。例如,Matter 控制器可以更改集群 OperatingMode 的属性 DoorLock,将锁置于隐私模式,在该模式下,门只能从建筑物内部手动解锁。下图显示了完成此交互需要交换的操作。

  • 调用命令交互
    调用命令交互允许 Matter 控制器调用来自门锁设备的数据模型层的命令之一。例如,Matter 控制器可以使用集群 UnlockDoor 的命令 DoorLock 远程解锁门。下图显示了完成此交互需要交换的操作。

注:这是调用命令交互的一种特殊情况,即计时交互,它需要在发送实际命令之前再交换两条消息。需要这两条消息来确保攻击者无法在房主外出时拦截并重放该命令来解锁门。

  • 订阅交互
    订阅交互可用于监视门锁设备的一个或多个属性或事件的状态。例如,Matter 控制器可以订阅集群 LockState 的属性 DoorLock,以便在门被其他用户解锁时接收通知。下图显示了完成此交互需要交换的操作。

注:这是一个长时间运行的交互,由执行的多个事务组成,直到任何一方停止响应或响应失败状态。


• 由 Leung 写于 2023 年 12 月 3 日

• 参考:互动模型  |  Matter  |  Google Home Developers
    nRF Connect SDK - Matter

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1280948.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

短线买入卖出有哪些交易技巧?

前面两节课&#xff0c;我们认识了短线交易&#xff0c;知道了短线交易常见的买入卖出时机&#xff0c;这节课&#xff0c;我们来讲解一下短线买入卖出的一些交易技巧。话不多时&#xff0c;直接进入重点&#xff01; 一、短线交易要果断 短线波动快&#xff0c;在出现买卖信号…

pytorch 中的dim 的作用范围

1. 二维矩阵时 不同的运算&#xff0c; dim 的作用域都是一样的思想&#xff1b; 当数据是二维矩阵时&#xff0c; 可以按照下面的思想理解&#xff1a; 对于矩阵&#xff1a; dim0 按列操作&#xff08;沿列向下&#xff09;。 dim1 按行操作&#xff08;跨行&#xff09;。 …

6-15 复制字符串

#include<stdio.h> #include<string.h> int main(){int i;char s1[80],s2[80];printf("输入的s2是&#xff1a;");scanf("%s",s2);for(i0;i<strlen(s2);i)s1[i]s2[i];printf("复制后的s1是&#xff1a;%s\n",s1); return 0;}

计算机组成原理-指令格式

文章目录 现代计算机的结构回忆&#xff1a;计算机的工作过程总览指令的定义指令格式零地址指令一地址指令二三地址指令四地址指令小结 指令-按指令长度分类指令-按操作码长度分类指令-按操作类型分类总结 现代计算机的结构 回忆&#xff1a;计算机的工作过程 总览 指令的定义 …

【专题】【数列极限】

【整体思路】 【常用不等式】

【并发编程】CountDownLatch详解与原理

&#x1f4eb;作者简介&#xff1a;小明Java问道之路&#xff0c;2022年度博客之星全国TOP3&#xff0c;专注于后端、中间件、计算机底层、架构设计演进与稳定性建设优化&#xff0c;文章内容兼具广度、深度、大厂技术方案&#xff0c;对待技术喜欢推理加验证&#xff0c;就职于…

MQTT客户端、代理(broker)和连接建立

在前篇文章&#xff08;http://t.csdnimg.cn/IamPz&#xff09;中&#xff0c;介绍了发布/订阅架构和MQTT如何据此交换信息&#xff0c;其中的关键概念是&#xff1a; 发布/订阅架构触耦了负责发布信息的客户端&#xff08;发布者&#xff09;和负责接收信息的客户端&#xff…

CSS——复合选择器、CSS特性、背景属性、显示模式

1、复合选择器 复合选择器&#xff1a;由两个或多个基础选择器&#xff0c;通过不同的方式组合而成。 作用&#xff1a;更准确、更高效的选择目标元素&#xff08;标签&#xff09; 1.1 后代选择器 后代选择器&#xff1a;选中某元素的后代元素 选择器写法&#xff1a;父选…

domain参数错误导致讯飞星火大模型:发生错误,错误码为:10404

问题 开通讯飞星火大模型api调用后&#xff0c;使用官方demo调用报错10404&#xff0c;最终发现是domain参数需要跟调用的版本保持一致&#xff0c;1.5&#xff0c;2&#xff0c;3版本分别传general,generalv2,generalv3&#xff0c;传错了还报错10404&#xff0c;感觉真没这必…

zabbix 监控

zabbit 监控 非常成熟的监控软件。 运维人员&#xff0c;尽快系统服务器的状态&#xff0c;网站的流量&#xff0c;服务进程的运行状态。 保证整个集群的工作正常。7*24 zabbix是什么&#xff1a; web界面提供的一种可视化监控服务软件。 分布式的方式系统监控以及网络监控…

Spring MVC数据绑定的几种方法(一)

这篇文章包含spring mvc的默认数据类型绑定和简单数据类型绑定。内容来自实验。 准备&#xff1a; &#xff08;1&#xff09;在IDEA环境中从archetye创建webapp类型的maven项目exp6。 &#xff08;2&#xff09;在src\main目录下创建并标注java源代码文件夹和resources资源文…

栈和队列的OJ题--13.用队列实现栈

13. 用队列实现栈 225. 用队列实现栈 - 力扣&#xff08;LeetCode&#xff09; /*解题思路&#xff1a; 此题可以用两个队列去实现一个栈&#xff0c;每次始终保持一个队列为空&#xff0c; 入栈操作相当于给非空队列进行入队操作 出栈操作相当于非空队列的队尾元素出队&…

Bean的加载控制

Bean的加载控制 文章目录 Bean的加载控制编程式注解式ConditionalOn*** 编程式 public class MyImportSelector implements ImportSelector {Overridepublic String[] selectImports(AnnotationMetadata annotationMetadata) {try {Class<?> clazz Class.forName("…

Qt OpenCV 学习(二):两个简单图片识别案例

1. 寻找匹配物体 1.1 mainwindow.h #ifndef MAINWINDOW_H #define MAINWINDOW_H#include <QMainWindow> #include <opencv2/opencv.hpp>#include <QImage> #include <QString> #include <QPixmap>QT_BEGIN_NAMESPACE namespace Ui { class Main…

易宝OA ExecuteSqlForSingle SQL注入漏洞复现

0x01 产品简介 易宝OA系统是一种专门为企业和机构的日常办公工作提供服务的综合性软件平台,具有信息管理、 流程管理 、知识管理(档案和业务管理)、协同办公等多种功能。 0x02 漏洞概述 易宝OA ExecuteSqlForSingle、IsPartNumber接口处存在SQL注入漏洞,未经身份认证的攻…

openGauss学习笔记-140 openGauss 数据库运维-例行维护-例行维护表

文章目录 openGauss学习笔记-140 openGauss 数据库运维-例行维护-例行维护表140.1 相关概念140.2 操作步骤140.3 维护建议 openGauss学习笔记-140 openGauss 数据库运维-例行维护-例行维护表 为了保证数据库的有效运行&#xff0c;数据库必须在插入/删除操作后&#xff0c;基于…

【数据库】数据库元素的层次,树形结构的下的多粒度加锁,以及幻象的正确处理

数据库元素的层次 ​专栏内容&#xff1a; 手写数据库toadb 本专栏主要介绍如何从零开发&#xff0c;开发的步骤&#xff0c;以及开发过程中的涉及的原理&#xff0c;遇到的问题等&#xff0c;让大家能跟上并且可以一起开发&#xff0c;让每个需要的人成为参与者。 本专栏会定期…

ESP32-Web-Server编程综合项目1-结合 Web Server 实现 WiFi 配网和网页 OTA 更新

ESP32-Web-Server编程综合项目1-结合 Web Server 实现 WiFi 配网和网页 OTA 更新 概述 前述的内容多是一个个小功能的演示&#xff0c;本章节讲述一些实际项目中使用到的综合项目。 首先要讲述的案例是通过ESP32 上的 Web Server 实现对 ESP32 的 WiFi 配网和网页 OTA 更新功…

送女朋友一个猜数字小游戏,猜对了会显示爱心(给你心爱的他或她一个惊喜)

起因是我在学习C语言完成老师布置C语言写一个猜数字的作业&#xff0c;突发奇想&#xff0c;能不能在这个猜对了之后弹出一个不一样的页面&#xff0c;然后就试试看能不能实现。基本思路是这样的&#xff1a; 1&#xff1a;先写一个C语言的猜数字的小游戏&#xff0c;在我上个文…

DevEco Studio 调整开发工具中的字体大小与行高

我们打开编辑器 选择 左上角 File 下的 Settings 将左侧菜单栏 编辑 展开 我们在编辑下面 选择 Font 然后 如下图指向的两个位置 我们可以调整它的字体大小和行高 设置好之后 右下角 点击 Apply 应用 然后点击 OK即可 当然 你按着 Ctrl 然后鼠标滚动 也可以像浏览器那样 拉…