Geen omschrijving

Fernando Otero d05d10807f p-token: Add `unsafe` qualifier to validate owner (#66) 3 maanden geleden
.github 001b6a256c dependabot: Auto-approve PRs (#54) 5 maanden geleden
clients 7433164b2a Publish JS client v0.5.1 7 maanden geleden
interface e734eb983b p-token: Add unsafe to transmutable trait (#65) 3 maanden geleden
p-token d05d10807f p-token: Add `unsafe` qualifier to validate owner (#66) 3 maanden geleden
program c149143b18 Update workspace dependencies (#67) 3 maanden geleden
scripts da8d9bd364 p-token: Add `spl-token` test fixtures (#39) 6 maanden geleden
.gitattributes 8fa926bde8 Initial commit 1 jaar geleden
.gitignore 8fa926bde8 Initial commit 1 jaar geleden
.prettierrc a7ca79e32f Update repo from latest `create-solana-program` (#5) 1 jaar geleden
Cargo.lock c149143b18 Update workspace dependencies (#67) 3 maanden geleden
Cargo.toml c149143b18 Update workspace dependencies (#67) 3 maanden geleden
LICENSE f476906122 Update License 1 jaar geleden
README.md f89ab407b2 Update README.md (#33) 7 maanden geleden
SECURITY.md 8921377ea5 Create SECURITY.md 4 maanden geleden
package.json 4c467485a4 p-token: Add error logging (#41) 6 maanden geleden
pnpm-lock.yaml 06677863f6 Bump Codama to 1.2.8 and use @solana/kit (#29) 7 maanden geleden
rust-toolchain.toml 2f189b15e7 CI: Add automated publish job (#34) 7 maanden geleden
rustfmt.toml f8bbbb7a5f CI: Add program and all extra steps (#13) 9 maanden geleden

README.md

SPL Token

This template should help get you started developing Solana programs. Let's walk through this generated program repository and see what's included.

Project setup

The first thing you'll want to do is install NPM dependencies which will allow you to access all the scripts and tools provided by this template.

pnpm install

Managing programs

You'll notice a program folder in the root of this repository. This is where your generated Solana program is located.

Whilst only one program gets generated, note that you can have as many programs as you like in this repository. Whenever you add a new program folder to this repository, remember to add it to the members array of your root Cargo.toml file. That way, your programs will be recognized by the following scripts that allow you to build, test, format and lint your programs respectively.

pnpm programs:build
pnpm programs:test
pnpm programs:format
pnpm programs:lint

Generating IDLs

You may use the following command to generate the IDLs for your programs.

pnpm generate:idls

Depending on your program's framework, this will either use Shank or Anchor to generate the IDLs. Note that, to ensure IDLs are generated using the correct framework version, the specific version used by the program will be downloaded and used locally.

Generating clients

Once your programs' IDLs have been generated, you can generate clients for them using the following command.

pnpm generate:clients

Alternatively, you can use the generate script to generate both the IDLs and the clients at once.

pnpm generate

Managing clients

The following clients are available for your programs. You may use the following links to learn more about each client.

Starting and stopping the local validator

The following script is available to start your local validator.

pnpm validator:start

By default, if a local validator is already running, the script will be skipped. You may use the validator:restart script instead to force the validator to restart.

pnpm validator:restart

Finally, you may stop the local validator using the following command.

pnpm validator:stop

Using external programs in your validator

If your program requires any external programs to be running, you'll want to add them to your local validator.

You can do this by adding their program addresses to the program-dependencies array in the Cargo.toml of your program.

program-dependencies = [
  "metaqbxxUerdq28cj1RbAWkYQm3ybzjb6a8bt518x1s",
  "noopb9bkMVfRPU8AsbpTUg8AQkHtKwMYZiFUjNRtMmV",
]

Next time you build your program and run your validator, these external programs will automatically be fetched from mainnet and used in your local validator.

pnpm programs:build
pnpm validator:restart