Skip to content

Commit 7c6eb49

Browse files
committed
update readme
1 parent fd76592 commit 7c6eb49

File tree

1 file changed

+38
-79
lines changed

1 file changed

+38
-79
lines changed

README.md

Lines changed: 38 additions & 79 deletions
Original file line numberDiff line numberDiff line change
@@ -1,103 +1,62 @@
1-
# Feature Gate
1+
# Solana Feature Gate Program
22

33
<a href="https://github.com/solana-program/feature-gate/actions/workflows/main.yml"><img src="https://img.shields.io/github/actions/workflow/status/solana-program/feature-gate/main.yml?logo=GitHub" /></a>
44
<a href="https://explorer.solana.com/address/Feature111111111111111111111111111111111111"><img src="https://img.shields.io/badge/dynamic/json?url=https%3A%2F%2Fraw.githubusercontent.com%2Fsolana-program%2Ffeature-gate%2Fmain%2Fprogram%2Fidl.json&query=%24.version&label=program&logo=&color=9945FF" /></a>
55
<a href="https://www.npmjs.com/package/@solana-program/feature-gate"><img src="https://img.shields.io/npm/v/%40solana-program%2Ffeature-gate?logo=npm&color=377CC0" /></a>
66
<a href="https://crates.io/crates/solana-feature-gate-client"><img src="https://img.shields.io/crates/v/solana-feature-gate-client?logo=rust" /></a>
77

8-
This template should help get you started developing Solana programs. Let's walk through this generated program repository and see what's included.
8+
The Solana Feature Gate program is a new Core BPF program introduced in
9+
[SIMD 0089](https://github.com/solana-foundation/solana-improvement-documents/blob/main/proposals/0089-programify-feature-gate-program.md).
910

10-
## Project setup
11+
Currently, it's sole responsibility is to enable core contributors to revoke
12+
pending feature activations. With all feature accounts owned by
13+
`Feature111111111111111111111111111111111111` (this program's ID), that means
14+
this program can manipulate feature accounts.
1115

12-
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.
16+
As per SIMD 0089, the single instruction `RevokePendingActivation` can -
17+
provided a signature from the feature keypair - revoke a feature activation that
18+
has been recently queued for activation, but not yet activated.
1319

14-
```sh
15-
pnpm install
20+
```rust
21+
enum FeatureGateInstruction {
22+
/// Revoke a pending feature activation.
23+
///
24+
/// This instruction will burn any lamports in the feature account.
25+
///
26+
/// A "pending" feature activation is a feature account that has been
27+
/// allocated and assigned, but hasn't yet been updated by the runtime
28+
/// with an `activation_slot`.
29+
///
30+
/// Features that _have_ been activated by the runtime cannot be revoked.
31+
///
32+
/// Accounts expected by this instruction:
33+
///
34+
/// 0. `[w+s]` Feature account
35+
/// 1. `[w]` Incinerator
36+
/// 2. `[ ]` System program
37+
RevokePendingActivation,
38+
}
1639
```
1740

18-
## Managing programs
41+
Support for this revoke instruction has been added to the Solana CLI.
1942

20-
You'll notice a `program` folder in the root of this repository. This is where your generated Solana program is located.
43+
## Build & Test
2144

22-
Whilst only one program gets generated, note that you can have as many programs as you like in this repository.
23-
Whenever you add a new program folder to this repository, remember to add it to the `members` array of your root `Cargo.toml` file.
24-
That way, your programs will be recognized by the following scripts that allow you to build, test, format and lint your programs respectively.
45+
This repository is managed with [`pnpm`](https://pnpm.io/).
2546

26-
```sh
27-
pnpm programs:build
28-
pnpm programs:test
29-
pnpm programs:format
30-
pnpm programs:lint
31-
```
32-
33-
## Generating IDLs
34-
35-
You may use the following command to generate the IDLs for your programs.
36-
37-
```sh
38-
pnpm generate:idls
39-
```
40-
41-
Depending on your program's framework, this will either use Shank or Anchor to generate the IDLs.
42-
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.
47+
All scripts can be found in `package.json` and under the `scripts` folder.
4348

44-
## Generating clients
49+
Build & test the program:
4550

46-
Once your programs' IDLs have been generated, you can generate clients for them using the following command.
47-
48-
```sh
49-
pnpm generate:clients
5051
```
51-
52-
Alternatively, you can use the `generate` script to generate both the IDLs and the clients at once.
53-
54-
```sh
55-
pnpm generate
52+
pnpm programs:build
53+
pnpm programs:test
5654
```
5755

58-
## Managing clients
56+
## Clients
5957

60-
The following clients are available for your programs. You may use the following links to learn more about each client.
58+
The following clients are available for the Feature Gate program.
6159

6260
- [JS client](./clients/js)
6361
- [Rust client](./clients/rust)
6462

65-
## Starting and stopping the local validator
66-
67-
The following script is available to start your local validator.
68-
69-
```sh
70-
pnpm validator:start
71-
```
72-
73-
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.
74-
75-
```sh
76-
pnpm validator:restart
77-
```
78-
79-
Finally, you may stop the local validator using the following command.
80-
81-
```sh
82-
pnpm validator:stop
83-
```
84-
85-
## Using external programs in your validator
86-
87-
If your program requires any external programs to be running, you'll want to in your local validator.
88-
89-
You can do this by adding their program addresses to the `program-dependencies` array in the `Cargo.toml` of your program.
90-
91-
```toml
92-
program-dependencies = [
93-
"metaqbxxUerdq28cj1RbAWkYQm3ybzjb6a8bt518x1s",
94-
"noopb9bkMVfRPU8AsbpTUg8AQkHtKwMYZiFUjNRtMmV",
95-
]
96-
```
97-
98-
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.
99-
100-
```sh
101-
pnpm programs:build
102-
pnpm validator:restart
103-
```

0 commit comments

Comments
 (0)