48 个版本 (30 个重大更新)

0.30.1 2024年6月20日
0.29.0 2023年10月16日
0.28.0 2023年6月9日
0.27.0 2023年3月8日
0.3.0 2021年3月12日

#14#anchor

Download history 12422/week @ 2024-04-30 14168/week @ 2024-05-07 16239/week @ 2024-05-14 17071/week @ 2024-05-21 18375/week @ 2024-05-28 15909/week @ 2024-06-04 14829/week @ 2024-06-11 15485/week @ 2024-06-18 14853/week @ 2024-06-25 8663/week @ 2024-07-02 11053/week @ 2024-07-09 12792/week @ 2024-07-16 13363/week @ 2024-07-23 12937/week @ 2024-07-30 14138/week @ 2024-08-06 14804/week @ 2024-08-13

56,874 每月下载量
用于 550 个 crate (32 个直接使用)

Apache-2.0

365KB
8K SLoC

Anchor

Solana Sealevel 框架

Build Status Tutorials Discord Chat License

Anchor 是一个用于 Solana 的 Sealevel 运行时的框架,为编写智能合约提供了几个方便的开发工具。

  • Rust eDSL 用于编写 Solana 程序
  • IDL 规范
  • 用于从 IDL 生成客户端的 TypeScript 包
  • 用于开发完整应用的 CLI 和工作区管理

如果您熟悉在 Ethereum 的 SolidityTruffleweb3.js 上开发,那么您将感到熟悉。尽管 DSL 语法和语义针对 Solana,但编写 RPC 请求处理程序、发出 IDL 和从 IDL 生成客户端的高级流程是相同的。

入门指南

有关快速入门指南和深入教程,请参阅 anchor 书籍 和正在逐步淘汰的较旧的 文档。要直接查看示例,请访问 此处。有关最新的 Rust 和 TypeScript API 文档,请参阅 docs.rstypedoc

软件包

软件包 描述 版本 文档
anchor-lang Rust 用于在 Solana 上编写程序的原始工具 Crates.io Docs.rs
anchor-spl Solana 上 SPL 程序的 CPI 客户端 crates Docs.rs
anchor-client 用于 Anchor 程序的 Rust 客户端 crates Docs.rs
@coral-xyz/anchor 用于 Anchor 程序的 TypeScript 客户端 npm Docs
@coral-xyz/anchor-cli CLI支持构建和管理Anchor工作区 npm Docs

注意

  • Anchor正在积极开发中,因此所有API都可能发生变化。
  • 此代码未经审核。使用风险自担。

示例

以下是一个计数器程序,只有指定的权威可以增加计数。

use anchor_lang::prelude::*;

declare_id!("Fg6PaFpoGXkYsidMpWTK6W2BeZ7FEfcYkg476zPFsLnS");

#[program]
mod counter {
    use super::*;

    pub fn initialize(ctx: Context<Initialize>, start: u64) -> Result<()> {
        let counter = &mut ctx.accounts.counter;
        counter.authority = *ctx.accounts.authority.key;
        counter.count = start;
        Ok(())
    }

    pub fn increment(ctx: Context<Increment>) -> Result<()> {
        let counter = &mut ctx.accounts.counter;
        counter.count += 1;
        Ok(())
    }
}

#[derive(Accounts)]
pub struct Initialize<'info> {
    #[account(init, payer = authority, space = 48)]
    pub counter: Account<'info, Counter>,
    pub authority: Signer<'info>,
    pub system_program: Program<'info, System>,
}

#[derive(Accounts)]
pub struct Increment<'info> {
    #[account(mut, has_one = authority)]
    pub counter: Account<'info, Counter>,
    pub authority: Signer<'info>,
}

#[account]
pub struct Counter {
    pub authority: Pubkey,
    pub count: u64,
}

更多信息,请参阅示例测试目录。

许可证

Anchor遵循Apache 2.0许可证。

除非您明确说明,否则根据Apache-2.0许可证定义,您有意提交给Anchor的任何贡献都将按照上述方式授权,不附加任何额外条款或条件。

贡献

感谢您对贡献Anchor的兴趣!请参阅CONTRIBUTING.md了解如何操作。

谢谢 ❤️

依赖项

~1.8–3MB
~58K SLoC