目录 |
---|
一、需求描述
去中心化公司治理协作平台。类似Web2的钉钉和飞书。功能包括:
...
代码块 |
---|
package 0x1.ExtensionPoint; syntax = "proto3"; service IApp { rpc bootstrap(); rpc mount(map<string, string>); rpc unmount(map<string, string>); rpc update(map<string, string>); } |
扩展点接口通过protobuf定义。
注意:
由于Move不支持合约动态调用合约代码,所以扩展点定义的接口都是通过JS实现。所有动态调用需求都由前端中转。
四、详细设计
1、扩展点管理
1.1 扩展点资源定义
代码块 | ||
---|---|---|
| ||
module ExtensionPoint { struct ExtensionPoint<ExtT> has key { id: u64, //扩展点的ID,按注册顺序自增 name: vector<u8>, //名字,例如 DAOSpace.IApp/v1 describe: vector<u8>, //描述 protobuf: vector<u8>, //扩展点接口定义,通过protobuf定义 created_at: u64, //创建时间 } struct ExtensionPointRegistry has key{ next_id: u64, } } |
...
代码块 | ||
---|---|---|
| ||
{ "id": 1, // 在DAOSpace注册的插件ID "name": "hello-world", // 插件名称 "version": "v0.1.1" // 插件版本 "icon": "ipfs://xxxxxxxxx/xxxxxxx.svg" "implements": [ "0x1::ExtensionPoint::IApp" // 实现应用接口 ], "depends": [ "0x1::Starcoin::IToken" // 依赖Token依赖Token接口 ], "required_caps": [ "0x1::DAOSpace::DAOUpgradeModuleCap", // 需要DAO升级能力 "0x1::DAOSpace::DAOMemberCap" // 需要DAO成员管理能力 ], "contact": "./constract/Move.toml", "web": "./web/package.json" } |
...