# Genex Chain 区块链开发指南 > 自建EVM兼容应用链 + 智能合约体系 --- ## 1. 链架构总览 | 组件 | 技术选型 | 说明 | |------|---------|------| | **链框架** | Cosmos SDK(最新版本) | 200+生产链验证,模块化 | | **共识引擎** | CometBFT(原Tendermint) | 拜占庭容错,**即时终结性** | | **EVM模块** | **cosmos/evm**(官方Cosmos EVM) | Apache 2.0,替代已弃用的Ethermint | | **跨链通信** | IBC | Cosmos生态原生跨链协议 | | **跨链桥** | Axelar(主)/ Wormhole(备) | 稳定币从Ethereum桥入 | | **撮合架构** | 链下内存订单簿 + 链上结算 | 参考dYdX v4 | ### 参考链 | 链 | 价值 | 关键参考 | |----|------|---------| | **Cronos** | Cosmos SDK + EVM最成熟实现 | <1s出块、Block-STM并行执行 | | **dYdX v4** | 交易平台专用链标杆 | 链下订单簿+链上结算 | | **Injective** | 金融应用Layer-1 | 链上CLOB、机构级合规 | --- ## 2. 链设计参数 | 参数 | 目标值 | |------|--------| | 共识机制 | CometBFT PoS(初期平台运营验证节点) | | EVM兼容 | 完全兼容(Solidity、Hardhat、MetaMask全套工具链) | | 出块时间 | **≤ 1秒**(CometBFT即时终结性) | | TPS | ≥ 5,000(Block-STM并行执行) | | Gas策略 | 平台前期全额补贴,用户零Gas | | 原生代币 | GNX(Gas + 治理;前期Gas补贴,用户不接触) | | 节点运营 | 平台自营验证节点 + 未来开放合格机构节点 | | 跨链 | IBC连接Cosmos生态 + Axelar桥连接Ethereum | ### 为什么自建链 | 维度 | 公链/L2 | Genex Chain | |------|---------|-------------| | Gas控制 | 受市场波动 | 平台完全控制,可设为零 | | 合规执行 | 链层面无法强制 | 链级OFAC/Travel Rule内置 | | 性能调优 | 共享资源 | 独享资源,针对券业务优化 | | 升级自主 | 依赖链治理 | 平台自主决定升级 | | 数据主权 | 完全公开 | 可控可见性 | | 监管对接 | 难以定制 | 专属节点/API | --- ## 3. 开发环境搭建 ### 3.1 前置依赖 ```bash # Go 1.21+ go version # Node.js 20+(合约开发工具) node --version # Foundry(合约开发框架) curl -L https://foundry.paradigm.xyz | bash foundryup # Cosmos SDK CLI go install cosmossdk.io/tools/cosmovisor/cmd/cosmovisor@latest ``` ### 3.2 Genex Chain本地开发 ```bash # 克隆Genex Chain仓库 git clone https://git.gogenex.com/genex-chain.git cd genex-chain # 编译 make build # 初始化本地测试链 ./genexd init test-node --chain-id genex-localnet # 创建创世账户 ./genexd keys add validator ./genexd genesis add-genesis-account validator 1000000000ugnx # 启动本地节点 ./genexd start ``` ### 3.3 合约开发环境 ```bash # 创建合约工程 mkdir genex-contracts && cd genex-contracts # 使用Foundry初始化 forge init # 项目结构 genex-contracts/ ├── src/ │ ├── CouponFactory.sol │ ├── Coupon.sol │ ├── Settlement.sol │ ├── Redemption.sol │ ├── Treasury.sol │ ├── Compliance.sol │ └── Governance.sol ├── test/ │ ├── CouponFactory.t.sol │ ├── Settlement.t.sol │ └── ... ├── script/ │ └── Deploy.s.sol └── foundry.toml ``` --- ## 4. 智能合约体系(7合约系统) ### 4.1 合约架构 ``` ┌─────────────────────────────────────────────┐ │ Governance(治理) │ │ Gas参数调整 | 紧急冻结多签 | 合约升级管理 │ ├─────────────────────────────────────────────┤ │ │ │ ┌──────────────┐ ┌───────────────────┐ │ │ │CouponFactory │ │ Compliance │ │ │ │ 券发行工厂 │ │ OFAC筛查 │ │ │ │ 铸造+类型标记 │ │ Travel Rule │ │ │ └──────┬───────┘ │ 紧急冻结 │ │ │ │ └───────────────────┘ │ │ ┌──────┴───────┐ │ │ │ Coupon │ ┌───────────────────┐ │ │ │ ERC-721/1155 │ │ Treasury │ │ │ │ 所有权+转移 │ │ 资金托管 │ │ │ └──────┬───────┘ │ 退款原子交换 │ │ │ │ └───────────────────┘ │ │ ┌──────┴───────────────────────┐ │ │ │ │ │ │ │ Settlement Redemption │ │ │ │ 交易结算 兑付清算 │ │ │ │ 原子交换 券销毁 │ │ │ └──────────────────────────────┘ │ └─────────────────────────────────────────────┘ ``` ### 4.2 CouponFactory — 券发行工厂 ```solidity // SPDX-License-Identifier: MIT pragma solidity ^0.8.20; import "@openzeppelin/contracts-upgradeable/proxy/utils/Initializable.sol"; import "@openzeppelin/contracts-upgradeable/access/AccessControlUpgradeable.sol"; contract CouponFactory is Initializable, AccessControlUpgradeable { enum CouponType { Utility, Security } struct CouponConfig { CouponType couponType; // 券类型(铸造后不可更改) bool transferable; // 是否可转让 uint8 maxResaleCount; // 最大转售次数(Utility默认2-3) uint256 maxPrice; // 价格上限(Utility = 面值) uint256 expiryDate; // 到期日 uint256 minPurchase; // 最低消费金额 bool stackable; // 是否可叠加 bytes32[] allowedStores; // 限定门店 } event CouponBatchMinted( address indexed issuer, uint256 indexed batchId, uint256 faceValue, uint256 quantity, CouponType couponType ); function mintBatch( address issuer, uint256 faceValue, uint256 quantity, CouponConfig calldata config ) external onlyRole(MINTER_ROLE) returns (uint256[] memory tokenIds) { // MVP阶段只允许Utility类型 require(config.couponType == CouponType.Utility, "Only Utility Track in MVP"); // Utility Track强制:价格上限 = 面值 if (config.couponType == CouponType.Utility) { require(config.maxPrice <= faceValue, "Utility: maxPrice <= faceValue"); require(config.expiryDate <= block.timestamp + 365 days, "Utility: max 12 months"); } // 铸造逻辑 tokenIds = _mintTokens(issuer, faceValue, quantity, config); emit CouponBatchMinted(issuer, batchId, faceValue, quantity, config.couponType); } } ``` ### 4.3 Settlement — 交易结算 ```solidity contract Settlement is Initializable, AccessControlUpgradeable { ICoupon public couponContract; IERC20 public stablecoin; // USDC ICompliance public compliance; event TradeSettled( uint256 indexed tokenId, address indexed buyer, address indexed seller, uint256 price ); /// @notice 原子交换:券 ↔ 稳定币 同时转移 function executeSwap( uint256 tokenId, address buyer, address seller, uint256 price ) external onlyRole(SETTLER_ROLE) { // 合规检查 require(!compliance.isBlacklisted(buyer), "Buyer blacklisted"); require(!compliance.isBlacklisted(seller), "Seller blacklisted"); // Utility Track: 价格 ≤ 面值 CouponConfig memory config = couponContract.getConfig(tokenId); if (config.couponType == CouponType.Utility) { require(price <= config.maxPrice, "Utility: price exceeds face value"); } // 转售次数检查 require( couponContract.getResaleCount(tokenId) < config.maxResaleCount, "Max resale count exceeded" ); // 原子交换(要么全部成功,要么全部回滚) stablecoin.transferFrom(buyer, seller, price); couponContract.safeTransferFrom(seller, buyer, tokenId); couponContract.incrementResaleCount(tokenId); emit TradeSettled(tokenId, buyer, seller, price); } /// @notice 退款:反向原子交换 function executeRefund( uint256 tokenId, address buyer, address seller, uint256 refundAmount ) external onlyRole(SETTLER_ROLE) { couponContract.safeTransferFrom(buyer, seller, tokenId); stablecoin.transferFrom(seller, buyer, refundAmount); } } ``` ### 4.4 Redemption — 兑付合约 ```solidity contract Redemption is Initializable { ICoupon public couponContract; event CouponRedeemed( uint256 indexed tokenId, address indexed consumer, address indexed issuer, bytes32 storeId ); /// @notice 消费者直接与发行方结算,平台不介入 function redeem( uint256 tokenId, bytes32 storeId ) external { require(couponContract.ownerOf(tokenId) == msg.sender, "Not owner"); CouponConfig memory config = couponContract.getConfig(tokenId); // 验证到期 require(block.timestamp <= config.expiryDate, "Coupon expired"); // 验证门店限定 if (config.allowedStores.length > 0) { require(_isAllowedStore(storeId, config.allowedStores), "Store not allowed"); } // 销毁券(burn) couponContract.burn(tokenId); // 通知发行方(event),平台不介入消费数据 emit CouponRedeemed(tokenId, msg.sender, config.issuer, storeId); } } ``` ### 4.5 Compliance — 合规合约 ```solidity contract Compliance is Initializable, AccessControlUpgradeable { mapping(address => bool) private _blacklist; // OFAC黑名单 /// @notice OFAC筛查 function isBlacklisted(address account) external view returns (bool) { return _blacklist[account]; } /// @notice Travel Rule(≥$3,000强制) function recordTravelRule( address sender, address receiver, bytes32 senderInfoHash, // 身份信息哈希(明文链下保存) bytes32 receiverInfoHash ) external { emit TravelRuleRecorded(sender, receiver, senderInfoHash, receiverInfoHash); } /// @notice 紧急冻结(需Governance多签) function freezeAccount(address account) external onlyRole(GOVERNANCE_ROLE) { _blacklist[account] = true; emit AccountFrozen(account); } } ``` ### 4.6 Governance — 治理合约 ```solidity contract Governance is Initializable { uint256 public constant REQUIRED_SIGNATURES = 3; // 3/5多签 uint256 public constant TIMELOCK = 48 hours; // 时间锁 uint256 public constant EMERGENCY_TIMELOCK = 4 hours; struct Proposal { bytes callData; address target; uint256 executeAfter; uint256 approvalCount; bool executed; mapping(address => bool) approvals; } function propose(address target, bytes calldata data) external onlyMultisig { // 创建提案,设置时间锁 } function approve(uint256 proposalId) external onlyMultisig { // 审批提案 } function execute(uint256 proposalId) external { Proposal storage p = proposals[proposalId]; require(p.approvalCount >= REQUIRED_SIGNATURES, "Not enough approvals"); require(block.timestamp >= p.executeAfter, "Timelock not expired"); require(!p.executed, "Already executed"); p.executed = true; (bool success,) = p.target.call(p.callData); require(success, "Execution failed"); } } ``` --- ## 5. 合约升级策略 **模式:Transparent Proxy(透明代理)** ``` 用户/前端 → Proxy合约(地址不变)→ Implementation合约(可替换) ``` **升级流程:** ``` 发起升级提案 → 多签审批(3/5)→ 时间锁48h → 自动执行 ↓ 紧急通道:4/5多签 → 4h时间锁 ``` **不可升级的逻辑(安全红线):** - 券类型标记(Utility/Security)— 不可修改 - 所有权记录 — 不可被升级篡改 - 链上转售计数器 — 防止绕过Utility Track限制 --- ## 6. 链级合规能力 | 能力 | 实现 | |------|------| | 链级OFAC过滤 | 验证节点拒绝处理制裁地址交易 | | 链级Travel Rule | 大额转移必须携带身份哈希,否则拒绝打包 | | 链级监控 | 节点内置异常交易检测模块 | | 监管API | 监管机构专属只读API | | 紧急冻结 | Governance多签冻结涉案地址 | --- ## 7. Gas费策略 ### 前期(全额补贴) | 操作 | Gas承担方 | |------|----------| | 券发行(铸造) | 平台补贴 | | 一级/二级市场交易 | 平台补贴 | | P2P转移 | 平台补贴 | | 券兑付(消费) | 平台补贴 | > 自建链Gas = 平台运营成本(服务器/节点),非公链ETH支付。 ### 技术实现 ```toml # 创世配置 [app_state.evm.params] min_gas_price = "0" # 或使用ERC-4337 Paymaster ``` Gas参数通过Governance合约动态调整(无需硬分叉)。 --- ## 8. 测试策略 ### 8.1 合约测试(Foundry) ```solidity // test/Settlement.t.sol contract SettlementTest is Test { Settlement settlement; MockCoupon coupon; MockERC20 usdc; function setUp() public { usdc = new MockERC20("USDC", "USDC", 6); coupon = new MockCoupon(); settlement = new Settlement(); settlement.initialize(address(coupon), address(usdc)); } function test_UtilityCannotExceedFaceValue() public { // 面值100的Utility券,尝试以110价格交易,应被拒绝 vm.expectRevert("Utility: price exceeds face value"); settlement.executeSwap(tokenId, buyer, seller, 110e6); } function test_AtomicSwapSuccess() public { // 正常交易:券和稳定币同时转移 settlement.executeSwap(tokenId, buyer, seller, 85e6); assertEq(coupon.ownerOf(tokenId), buyer); assertEq(usdc.balanceOf(seller), 85e6); } function test_RefundReverseSwap() public { // 退款:反向原子交换 settlement.executeRefund(tokenId, buyer, seller, 85e6); assertEq(coupon.ownerOf(tokenId), seller); assertEq(usdc.balanceOf(buyer), 85e6); } } ``` ### 8.2 测试覆盖要求 | 测试类型 | 覆盖 | |---------|------| | 单元测试 | 每个合约函数 | | Fuzz测试 | 价格边界、数量溢出 | | 集成测试 | 完整发行→交易→核销流程 | | Gas优化 | 批量操作Gas消耗 | | 安全审计 | 第三方审计(上线前必须) | --- ## 9. 部署流程 ```bash # 部署到本地测试链 forge script script/Deploy.s.sol --rpc-url http://localhost:8545 --broadcast # 部署到Genex Chain测试网 forge script script/Deploy.s.sol \ --rpc-url https://testnet-rpc.gogenex.com \ --broadcast \ --verify # 部署到Genex Chain主网(需多签审批) forge script script/Deploy.s.sol \ --rpc-url https://rpc.gogenex.com \ --broadcast \ --verify \ --etherscan-api-key $GENEX_EXPLORER_KEY ``` ### 合约验证 ```bash forge verify-contract \ --chain-id 8888 \ --compiler-version v0.8.20 \ $CONTRACT_ADDRESS \ src/CouponFactory.sol:CouponFactory ``` --- ## 10. GCFN全球清算节点架构 ``` ┌─────────────────────────────────────────────┐ │ Global Coupon Financial Network (GCFN) │ ├─────────────────────────────────────────────┤ │ ROOT NODE │ │ (US / Global Hub) │ │ 全球路由 | 跨境清算 | 合规协调 │ ├──────────────┬──────────────┬───────────────┤ │ ASIA-PACIFIC │ EMEA │ AMERICAS │ ├──────────────┼──────────────┼───────────────┤ │ 新加坡(MAS) │ 伦敦(FCA) │ 美国(FinCEN) │ │ 香港(SFC) │ 法兰克福 │ │ │ 日本(FSA) │ (BaFin) │ │ └──────────────┴──────────────┴───────────────┘ ``` | 节点类型 | 职责 | |---------|------| | 根节点 | 全球路由、跨境清算、主验证节点 | | 区域节点 | 区域清算、监管报送、本地化 | | 本地节点 | 用户服务、本地支付、法规遵从 | | 监管节点 | 只读审计、实时监控 | --- ## 11. 安全规范 - 所有合约上线前必须通过第三方安全审计 - 核心合约采用Transparent Proxy部署 - 升级需3/5多签 + 48小时时间锁 - Bug Bounty计划:严重漏洞奖励$10K-$100K - MPC/HSM密钥管理 - 合约代码开源并在区块浏览器验证 --- *文档版本: v1.0* *基于: Genex 券交易平台 - 软件需求规格说明书 v4.1 + 技术架构开发需求 v3.0* *技术栈: Cosmos SDK + cosmos/evm + CometBFT + Solidity + Foundry*