脉波开发者文档
  • 脉波开发者文档
  • 基础主題
    • 脉波简介
    • MAPO币
    • 全链去中心化应用
    • 全链应用与单链或多链应用的区别
    • 第三方信任跨链与点对点跨链方案区别
    • 比特币二层
      • brc-201
    • 预言机 Oracle
      • Supra: MAP Protocol 上的去中心化预言机
    • 帐户
    • 交易
    • 区块
    • MPT树
    • RLP编码
    • Gas费用
    • 消息跨链
    • 轻客户端
      • MAPO轻客户端
    • 全链开发组件层MOS
      • MOS接口和功能
      • MOS的部署
      • Messenger
    • 中继链(atlas)
      • 节点架构
        • 中继链(atlas)架构 - 区块和交易结构
        • 创世
          • 创世配置 - 介绍创世配置文件
          • 创世合约
            • ABI
              • Accounts
              • Election
              • EpochRewards
              • LockedGold
              • Validators
            • 地址
            • 部署
        • 预编译合约 - 支持的预编译合约
        • 协议
          • Proof of Stake
          • 共识
          • 选举
          • 奖励
          • 治理
      • 部署节点 - 包括公共RPC节点
        • 运行节点(中继链)
        • 归档节点(中继链)
        • 引导节点(中继链)
        • 验证节点 (中继链)
        • RPC节点(中继链)
      • Marker工具 - atlas的简易客户端工具
        • Genesis
        • Validator
        • Vote
        • Common
      • 搭建私有网络
      • 公共网络服务信息
        • 公共网络
      • 示例
        • 如何成为一个 Validator 并加入到 Atlas 网络中
        • 如何成为一个 Validator 并加入到 Atlas 网络中[高级]
    • Compass(maintainer,messenger)
      • Compass - 架构及模块说明
      • Compass配置参数
      • Compass环境与部署
      • Compass二次开发 - 基于compass定义自己的路由服务
  • MAPO技术堆栈
    • 堆栈
      • 接入的链
    • EVM兼容
      • 智能合约语言
      • 智能合约结构
      • 智能合约库
      • 编译智能合约
      • 测试智能合约
      • 部署智能合约
      • 可组合性
      • 智能合约安全性
      • 智能合约形式化验证
      • 开发框架
      • 开发网络
    • 实现跨链互通
      • EVM兼容链的跨链互通
        • 轻客户端验证
        • 轻客户端状态更新
        • MOS层
      • 非EVM兼容链的跨链互通
        • 轻客户端验证
        • 轻客户端状态更新
        • MOS层
    • 如何开发全链应用
    • 轻客户端信息
    • SDK/API - mapo支持的API
      • MOS接口
      • 轻客户端接口
      • 中继链RPC
        • json-rpc
          • atlas json rpc
          • atlas consensus rpc
        • javaScript sdk
        • go-sdk
      • 后端API
        • 浏览器API
        • 数据统计与分析API
  • 零知识证明(zk)
    • 零知识证明
Powered by GitBook
On this page
  • 全链开发组件层
  • 怎么运行的
  • 先决条件
  • MOS如何完成跨链消息
  • 流程架构
  1. 基础主題

全链开发组件层MOS

PreviousMAPO轻客户端NextMOS接口和功能

Last updated 1 year ago

全链开发组件层

怎么运行的

MOS消息使得建立在一条链上的项目可以轻松地将一些项目信息同步到其他链上,并且还可以调用其他连接链上的合约方法。

MOS 使用 MAP Protocol 轻客户端来验证跨链消息的交易,以确保跨链消息在链上真实可查。

通过 MOS,您可以实现与两条链的互操作:

  • 从A链调用B链上的合约。

  • 将A链中的消息变化打包写入B链,实现消息同步

先决条件

  • 应用程序必须位于 MAP 协议支持的链之一上。请参阅以获取部署 MAPO 轻客户端的链列表。该列表会随着新链的添加而更新。

  • 跨链消息的可执行合约权限必须授权给对应链上的MOS合约。

  • A链和B链都必须部署MOS消息合约(Near Chain的MOS消息仍在开发中)。

MOS如何完成跨链消息

在源头链

  1. 用户(dApp)整理需要跨链的消息,整理目标链调用的callData

  2. dApp调用MOS的transferOut方法,支付跨链的gas费

  3. MOS发送跨链交易并弹出跨链消息日志。您可以在源链浏览器上查看交易详情。

在地图中继链上

  1. 信使检测源链上的消息日志,并从源链上构建证明数据,并调用方法transferIn通知中继链上的 MOS 合约。

  2. MOS中继合约(MAP中继链上的MOS合约)确认源链的消息日志,通过轻客户端验证源链交易的真实性,判断是要去另一条链,发送交易,并继续弹出跨链消息日志。

  3. 如果MAP中继链是目标链,则执行call方法并弹出执行日志。

在目的地链

  1. Messenger 检测 MAP 中继链上的消息日志,并从中继链上构建证明数据,并调用方法transferIn通知目标链上的 MOS 合约。

  2. MOS合约通过轻客户端验证MAPO消息日志的真实性。

  3. 目的链弹出执行日志,完成消息跨链合约调用。

流程架构

文档
messageFlow