13个版本 (主要破坏性)
13.1.0 | 2024年7月15日 |
---|---|
12.1.0 | 2024年6月25日 |
11.1.0 | 2024年6月13日 |
10.1.0 | 2024年5月21日 |
1.0.0 | 2023年10月27日 |
#6 in #bazaar
每月下载量1,663
用于 pallet-encointer-bazaar-r…
73KB
1.5K SLoC
Encointer Pallets
encointer的所有应用程序特定pallet
pallet-encointer-ceremonies
执行encointer仪式的substrate pallet
pallet-encointer-communities
encointer社区及其聚会地点管理的substrate pallet
pallet-encointer-ceremonies
执行encointer仪式的substrate pallet
pallet-encointer-balances
支持多个社区和罚金的balances模块
pallet-encointer-bazaar
社区成员的分类广告注册,链接到IPFS
personhood-oracle & sybil-gate模板 [已弃用]
具有XCM支持的数字人格验证预言机。有关更多信息,请参阅stale demo分支上的README.md:https://github.com/encointer/pallets/tree/demo/xcm-personhood-oracle-and-sybil-gate-template#encointer-pallets
开发提示
基准测试
您可以通过在encointer-node中运行带有脚本(在节点的仓库中)的基准测试来自动更新WeightInfo
定义: ./scripts/benchmark_runtime.sh
并取消注释带有 frame-weight-template-full-info.hbs
的行(请参阅脚本文档)。
序列化
- 在json-rpc crate中序列化u-/i128存在已知问题,请参阅(https://github.com/paritytech/substrate/issues/4641)。这主要影响我们在自定义RPC中序列化定点数时的情况。在ep-core中有一个自定义序列化适配层作为对该问题的解决方案,可以作为自定义serde属性使用。
#[cfg_attr(feature = "serde_derive", derive(Serialize, Deserialize))]
#[cfg_attr(feature = "serde_derive", serde(rename_all = "camelCase"))]
pub struct BalanceEntry<BlockNumber> {
/// The balance of the account after last manual adjustment
#[cfg_attr(feature = "serde_derive", serde(with = "serialize_fixed"))]
pub principal: BalanceType,
/// The time (block height) at which the balance was last adjusted
pub last_update: BlockNumber,
}
我们还遵循substrate的序列化标准,使用camelCase
。
版本管理
主版本号必须在polkadot-sdk发布升级时增加,因为这些始终是破坏性更改。为了方便起见,本仓库中的所有crate应具有相同的主版本号。
我们单独提升crate的次要版本,并使用最高crate版本标记仓库
动机:如果发生了更改,git blame应在crate目录级别显示。这样,在GitHub上浏览仓库时,可以真正显示某个特定的pallet或crate何时被修改。即使只是上游升级的调整,只需将crate版本提升到最新,这将全局标记
pallet仓库版本无需与节点或平行链(或运行时)crate版本对齐——尽管过去一直是这种情况。
crates.io
使用cargo-release
,我们明确在tomls中排除非公开crate
cargo install cargo-release
# check workspace dependency tree
cargo tree --workspace -i ep-core
# add --execute if you're sure
cargo release publish -p ep-core -p encointer-primitives -p pallet-encointer-scheduler -p pallet-encointer-balances -p pallet-encointer-communities
cargo release publish -p encointer-ceremonies-assignment -p encointer-meetup-validation -p pallet-encointer-ceremonies -p pallet-encointer-bazaar -p pallet-encointer-reputation-commitments -p pallet-encointer-faucet -p pallet-encointer-democracy
cargo release publish -p encointer-rpc -p encointer-balances-tx-payment -p encointer-balances-tx-payment-rpc-runtime-api -p encointer-balances-tx-payment-rpc -p pallet-encointer-bazaar-rpc-runtime-api -p pallet-encointer-bazaar-rpc -p pallet-encointer-ceremonies-rpc-runtime-api -p pallet-encointer-ceremonies-rpc -p pallet-encointer-communities-rpc-runtime-api -p pallet-encointer-communities-rpc
lib.rs
:
需要由Bazaar RPC扩展使用的运行时API定义。
依赖项
~21–35MB
~600K SLoC