Skip to content

Commit

Permalink
docs: Add Solana Playground quickstart page, and add examples page fo…
Browse files Browse the repository at this point in the history
…r anchor contraints and types (#2703)
  • Loading branch information
ZYJLiu authored Nov 20, 2023
1 parent c58d2f2 commit 227ccb2
Show file tree
Hide file tree
Showing 10 changed files with 633 additions and 0 deletions.
Binary file added docs/public/solpg-anchor.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/public/solpg-build-deploy.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/public/solpg-github.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/public/solpg-import.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/public/solpg-test.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/public/solpg-wallet.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
3 changes: 3 additions & 0 deletions docs/src/pages/_app.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ const navigation = [
title: 'Getting Started',
links: [
{ title: 'Introduction', href: '/' },
{ title: 'Quickstart', href: '/docs/solana-playground' },
{ title: 'Installation', href: '/docs/installation' },
{ title: 'Hello World', href: '/docs/hello-world' },
{ title: 'Intro to Solana', href: '/docs/intro-to-solana' },
Expand Down Expand Up @@ -67,6 +68,8 @@ const navigation = [
{
title: 'References',
links: [
{ title: 'Account Constraints', href: '/docs/account-constraints' },
{ title: 'Account Types', href: '/docs/account-types' },
{ title: 'Anchor.toml', href: '/docs/manifest' },
{ title: 'CLI', href: '/docs/cli' },
{ title: 'AVM', href: '/docs/avm' },
Expand Down
331 changes: 331 additions & 0 deletions docs/src/pages/docs/account-constraints.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,331 @@
---
title: Account Constraints
description: Anchor Account Constraint Examples
---

Minimal reference examples for Anchor account [constraints](https://docs.rs/anchor-lang/latest/anchor_lang/derive.Accounts.html).

## Instruction Attribute

{% table %}

- Attribute
- Example
- Description

---

- ```rust
#[derive(Accounts)]
#[instruction(...)]
pub struct Initialize<'info> {
...
}
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/instruction)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/instruction)
- You can access the instruction’s arguments with the #[instruction(..)] attribute.
You have to list them in the same order as in the instruction but you can omit all arguments after the last one you need.

{% /table %}

## Normal Constraints

{% table %}

- Attribute
- Example
- Description

---

- ```rust
#[account(signer)]
#[account(signer @ <custom_error>)]
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/signer)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/signer)
- Checks the given account signed the transaction. Custom errors are supported via @. Consider using the Signer type if you would only have this constraint on the account.

---

- ```rust
#[account(mut)]
#[account(mut @ <custom_error>)]
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/mut)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/mut)
- Checks the given account is mutable.
Makes anchor persist any state changes.
Custom errors are supported via @.

---

- ```rust
#[account(
init,
payer = <target_account>,
space = <num_bytes>
)]
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/init)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/init)
- Creates the account via a CPI to the system program and initializes it (sets its account discriminator).

---

- ```rust
#[account(
init_if_needed,
payer = <target_account>
)]

#[account(
init_if_needed,
payer = <target_account>,
space = <num_bytes>
)]
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/init_if_needed)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/init_if_needed)
- Exact same functionality as the init constraint but only runs if the account does not exist yet.

This feature should be used with care and is therefore behind a feature flag. You can enable it by importing anchor-lang with the init-if-needed cargo feature.
When using init_if_needed, you need to make sure you properly protect yourself against re-initialization attacks.

---

- ```rust
#[account(
seeds = <seeds>,
bump
)]

#[account(
seeds = <seeds>,
bump,
seeds::program = <expr>
)]

#[account(
seeds = <seeds>,
bump = <expr>
)]

#[account(
seeds = <seeds>,
bump = <expr>,
seeds::program = <expr>
)]
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/seed-bump)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/seed-bump)
- Checks that given account is a PDA derived from the currently executing program, the seeds, and if provided, the bump.
If not provided, anchor uses the canonical bump.
Add seeds::program = <expr> to derive the PDA from a different program than the currently executing one.

---

- ```rust
#[account(
has_one = <target_account>
)]

#[account(
has_one = <target_account> @ <custom_error>
)]
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/has_one)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/has_one)
- Checks the target_account field on the account matches the key of the target_account field in the Accounts struct.
Custom errors are supported via @.

---

- ```rust
#[account(address = <expr>)]
#[account(address = <expr> @ <custom_error>)]
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/address)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/address)
- Checks the account key matches the pubkey.
Custom errors are supported via @.

---

- ```rust
#[account(owner = <expr>)]
#[account(owner = <expr> @ <custom_error>)]
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/owner)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/owner)
- Checks the account owner matches expr.
Custom errors are supported via @.

---

- ```rust
#[account(executable)]
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/executable)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/executable)
- Checks the account is executable (i.e. the account is a program).
You may want to use the Program type instead.

---

- ```rust
#[account(rent_exempt = skip)]
#[account(rent_exempt = enforce)]
```

- Github
Solpg
- Enforces rent exemption with = enforce.
Skips rent exemption check that would normally be done through other constraints with = skip, e.g. when used with the zero constraint

---

- ```rust
#[account(zero)]
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/zero)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/zero)
- Checks the account discriminator is zero.

Use this constraint if you want to create an account in a previous instruction and then initialize it in your instruction instead of using init. This is necessary for accounts that are larger than 10 Kibibyte because those accounts cannot be created via a CPI (which is what init would do).

---

- ```rust
#[account(close = <target_account>)]
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/close)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/close)
- Marks the account as closed at the end of the instruction’s execution (sets its discriminator to the CLOSED_ACCOUNT_DISCRIMINATOR) and sends its lamports to the specified account.

Setting the discriminator to a special variant makes account revival attacks (where a subsequent instruction adds the rent exemption lamports again) impossible.

Requires mut to exist on the account.

---

- ```rust
#[account(constraint = <expr>)]
#[account(
constraint = <expr> @ <custom_error>
)]
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/constraint)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/constraint)
- Constraint that checks whether the given expression evaluates to true.
Use this when no other constraint fits your use case.

---

- ```rust
#[account(
realloc = <space>,
realloc::payer = <target>,
realloc::zero = <bool>
)]
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/realloc)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/realloc)
- Used to realloc program account space at the beginning of an instruction.

{% /table %}

## SPL Constraints

{% table %}

- Attribute
- Example
- Description

---

- ```rust
#[account(
token::mint = <target_account>,
token::authority = <target_account>
)]

#[account(
token::mint = <target_account>,
token::authority = <target_account>,
token::token_program = <target_account>
)]
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/token)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/token)
- Can be used as a check or with init to create a token account with the given mint address and authority.
When used as a check, it's possible to only specify a subset of the constraints.

---

- ```rust
#[account(
mint::authority = <target_account>,
mint::decimals = <expr>
)]

#[account(
mint::authority = <target_account>,
mint::decimals = <expr>,
mint::freeze_authority = <target_account>
)]
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/mint)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/mint)
- Can be used as a check or with init to create a mint account with the given mint decimals and mint authority.
The freeze authority is optional when used with init.
When used as a check, it's possible to only specify a subset of the constraints.

---

- ```rust
#[account(
associated_token::mint = <target_account>,
associated_token::authority = <target_account>
)]

#[account(
associated_token::mint = <target_account>,
associated_token::authority = <target_account>,
associated_token::token_program = <target_account>
)]
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/associated_token)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/associated_token)
- Can be used as a standalone as a check or with init to create an associated token account with the given mint address and authority.

---

- ```rust
#[account(*::token_program = <target_account>)]
```

- [Github](https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/token_program)
[Solpg](https://beta.solpg.io/https://github.com/solana-developers/anchor-examples/tree/main/account-constraints/token_program)
- The token_program can optionally be overridden.

{% /table %}
Loading

1 comment on commit 227ccb2

@vercel
Copy link

@vercel vercel bot commented on 227ccb2 Nov 20, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Successfully deployed to the following URLs:

anchor-docs – ./

anchor-lang.com
anchor-docs-200ms.vercel.app
www.anchor-lang.com
anchor-docs-git-master-200ms.vercel.app

Please sign in to comment.