| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- # {{ programName | titleCase }}
- {# TODO: Uncomment when CI is generated. #}
- {# <a href="https://github.com/{{ organizationName }}/{{ programName }}/actions/workflows/main.yml"><img src="https://img.shields.io/github/actions/workflow/status/{{ organizationName }}/{{ programName }}/main.yml?logo=GitHub" /></a> #}
- <a href="https://explorer.solana.com/address/{{ programAddress }}"><img src="https://img.shields.io/badge/dynamic/json?url=https%3A%2F%2Fraw.githubusercontent.com%2F{{ organizationName }}%2F{{ programName }}%2Fmain%2Fprogram%2Fidl.json&query=%24.version&label=program&logo=&color=9945FF" /></a>
- {% if clients.includes('js') %}
- <a href="https://www.npmjs.com/package/{{ jsClientPackageName }}"><img src="https://img.shields.io/npm/v/{{ jsClientPackageName | urlencode }}?logo=npm&color=377CC0" /></a>
- {% endif %}
- {% if clients.includes('rust') %}
- <a href="https://crates.io/crates/{{ rustClientCrateName }}"><img src="https://img.shields.io/crates/v/{{ rustClientCrateName }}?logo=rust" /></a>
- {% else %}
- <a href="https://crates.io/crates/{{ programCrateName }}"><img src="https://img.shields.io/crates/v/{{ programCrateName }}?logo=rust" /></a>
- {% endif %}
- 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.
- ```sh
- {{ getNpmCommand("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.
- ```sh
- {{ getNpmCommand("programs:build") }}
- {{ getNpmCommand("programs:test") }}
- {{ getNpmCommand("programs:format") }}
- {{ getNpmCommand("programs:lint") }}
- ```
- ## Generating IDLs
- You may use the following command to generate the IDLs for your programs.
- ```sh
- {{ getNpmCommand("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.
- {% if clients.length > 0 %}
- ## Generating clients
- Once your programs' IDLs have been generated, you can generate clients for them using the following command.
- ```sh
- {{ getNpmCommand("generate:clients") }}
- ```
- Alternatively, you can use the `generate` script to generate both the IDLs and the clients at once.
- ```sh
- {{ getNpmCommand("generate") }}
- ```
- ## Managing clients
- The following clients are available for your programs. You may use the following links to learn more about each client.
- {% for client in clients %}
- {% if ['js'].includes(client) %}
- - [{{ client | upper }} client](./clients/{{ client }})
- {% else %}
- - [{{ client | titleCase }} client](./clients/{{ client }})
- {% endif %}
- {% endfor %}
- ## Starting and stopping the local validator
- The following script is available to start your local validator.
- ```sh
- {{ getNpmCommand("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.
- ```sh
- {{ getNpmCommand("validator:restart") }}
- ```
- Finally, you may stop the local validator using the following command.
- ```sh
- {{ getNpmCommand("validator:stop") }}
- ```
- ## Using external programs in your validator
- If your program requires any external programs to be running, you'll want to in your local validator.
- You can do this by adding their program addresses to the `program-dependencies` array in the `Cargo.toml` of your program.
- ```toml
- 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.
- ```sh
- {{ getNpmCommand("programs:build") }}
- {{ getNpmCommand("validator:restart") }}
- ```
- {% endif %}
|