mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-09 11:11:20 +00:00
23181c8629
* begin with delete accounts impl * delete tests passing * started backup, delete tests all passing * implement backup using zip * backup implementation done with unzip tests * full tests done * used proper error codes * remove comment Co-authored-by: prylabs-bulldozer[bot] <58059840+prylabs-bulldozer[bot]@users.noreply.github.com>
266 lines
7.3 KiB
Protocol Buffer
266 lines
7.3 KiB
Protocol Buffer
syntax = "proto3";
|
|
package ethereum.validator.accounts.v2;
|
|
|
|
import "google/api/annotations.proto";
|
|
import "google/protobuf/empty.proto";
|
|
|
|
service Wallet {
|
|
rpc HasWallet(google.protobuf.Empty) returns (HasWalletResponse) {
|
|
option (google.api.http) = {
|
|
get: "/v2/validator/wallet/exists"
|
|
};
|
|
}
|
|
rpc CreateWallet(CreateWalletRequest) returns (WalletResponse) {
|
|
option (google.api.http) = {
|
|
post: "/v2/validator/wallet/create",
|
|
body: "*"
|
|
};
|
|
}
|
|
rpc EditConfig(EditWalletConfigRequest) returns (WalletResponse) {
|
|
option (google.api.http) = {
|
|
post: "/v2/validator/wallet/config/edit",
|
|
body: "*"
|
|
};
|
|
}
|
|
rpc WalletConfig(google.protobuf.Empty) returns (WalletResponse) {
|
|
option (google.api.http) = {
|
|
get: "/v2/validator/wallet"
|
|
};
|
|
}
|
|
rpc GenerateMnemonic(google.protobuf.Empty) returns (GenerateMnemonicResponse) {
|
|
option (google.api.http) = {
|
|
get: "/v2/validator/mnemonic/generate"
|
|
};
|
|
}
|
|
rpc ChangePassword(ChangePasswordRequest) returns (google.protobuf.Empty) {
|
|
option (google.api.http) = {
|
|
post: "/v2/validator/wallet/password/edit",
|
|
body: "*"
|
|
};
|
|
}
|
|
rpc ImportKeystores(ImportKeystoresRequest) returns (ImportKeystoresResponse) {
|
|
option (google.api.http) = {
|
|
post: "/v2/validator/wallet/keystores/import",
|
|
body: "*"
|
|
};
|
|
}
|
|
}
|
|
|
|
service Accounts {
|
|
rpc CreateAccount(CreateAccountRequest) returns (DepositDataResponse) {
|
|
option (google.api.http) = {
|
|
post: "/v2/validator/wallet/accounts/create",
|
|
body: "*"
|
|
};
|
|
}
|
|
rpc ListAccounts(ListAccountsRequest) returns (ListAccountsResponse) {
|
|
option (google.api.http) = {
|
|
get: "/v2/validator/accounts"
|
|
};
|
|
}
|
|
rpc BackupAccounts(BackupAccountsRequest) returns (BackupAccountsResponse) {
|
|
option (google.api.http) = {
|
|
post: "/v2/validator/wallet/accounts/backup",
|
|
body: "*"
|
|
};
|
|
}
|
|
rpc DeleteAccounts(DeleteAccountsRequest) returns (DeleteAccountsResponse) {
|
|
option (google.api.http) = {
|
|
post: "/v2/validator/wallet/accounts/delete",
|
|
body: "*"
|
|
};
|
|
}
|
|
}
|
|
|
|
service Health {
|
|
rpc GetBeaconNodeConnection(google.protobuf.Empty) returns (NodeConnectionResponse) {
|
|
option (google.api.http) = {
|
|
get: "/v2/validator/health/node_connection"
|
|
};
|
|
}
|
|
}
|
|
|
|
service Auth {
|
|
rpc Login(AuthRequest) returns (AuthResponse) {
|
|
option (google.api.http) = {
|
|
post: "/v2/validator/login",
|
|
body: "*"
|
|
};
|
|
}
|
|
rpc Signup(AuthRequest) returns (AuthResponse) {
|
|
option (google.api.http) = {
|
|
post: "/v2/validator/signup",
|
|
body: "*"
|
|
};
|
|
}
|
|
}
|
|
|
|
// Type of key manager for the wallet, either direct, derived, or remote.
|
|
enum KeymanagerKind {
|
|
DERIVED = 0;
|
|
DIRECT = 1;
|
|
REMOTE = 2;
|
|
}
|
|
|
|
message CreateWalletRequest {
|
|
// Path on disk where the wallet will be stored.
|
|
string wallet_path = 1;
|
|
KeymanagerKind keymanager = 2;
|
|
|
|
// Password for the wallet.
|
|
string wallet_password = 3;
|
|
// Mnemonic in case the user is creating a derived wallet.
|
|
string mnemonic = 4;
|
|
// Number of accounts.
|
|
uint64 num_accounts = 5;
|
|
// JSON-encoded keystore files to import during wallet creation.
|
|
repeated string keystores_imported = 6;
|
|
// Password to unlock imported keystore files.
|
|
string keystores_password = 7;
|
|
|
|
// Remote address such as host.example.com:4000 for a gRPC remote signer server.
|
|
string remote_addr = 8;
|
|
// Path to client.crt for secure TLS connections to a remote signer server.
|
|
string remote_crt_path = 9;
|
|
// Path to client.key for secure TLS connections to a remote signer server.
|
|
string remote_key_path = 10;
|
|
// Path to ca.crt for secure TLS connections to a remote signer server.
|
|
string remote_ca_crt_path = 11;
|
|
}
|
|
|
|
message EditWalletConfigRequest {
|
|
string remote_addr = 1;
|
|
string remote_crt_path = 2;
|
|
string remote_key_path = 3;
|
|
string remote_ca_crt_path = 4;
|
|
}
|
|
|
|
message GenerateMnemonicResponse {
|
|
string mnemonic = 1;
|
|
}
|
|
|
|
message WalletResponse {
|
|
string wallet_path = 1;
|
|
|
|
KeymanagerKind keymanager_kind = 2;
|
|
|
|
// Key manager configs, this is meant to be some what generic.
|
|
// It'll later be encoded with json to represent in front end UI.
|
|
map<string, string> keymanager_config = 3;
|
|
}
|
|
|
|
message ListAccountsRequest {
|
|
// Whether or not to return the raw RLP deposit tx data.
|
|
bool get_deposit_tx_data = 1;
|
|
}
|
|
|
|
message ListAccountsResponse {
|
|
repeated Account accounts = 1;
|
|
}
|
|
|
|
message Account {
|
|
// The validating public key.
|
|
bytes validating_public_key = 1;
|
|
// The human readable account name.
|
|
string account_name = 2;
|
|
// The deposit data transaction RLP bytes.
|
|
bytes deposit_tx_data = 3;
|
|
// The derivation path (if using HD wallet).
|
|
string derivation_path = 4;
|
|
}
|
|
|
|
message AccountRequest {
|
|
// A list of validator public keys.
|
|
repeated bytes public_keys = 1;
|
|
// A list of validator indices.
|
|
repeated uint64 indices = 2;
|
|
}
|
|
|
|
message AuthRequest {
|
|
string password = 1;
|
|
}
|
|
|
|
message AuthResponse {
|
|
string token = 1;
|
|
|
|
uint64 token_expiration = 2;
|
|
}
|
|
|
|
message NodeConnectionResponse {
|
|
// The host address of the beacon node the validator
|
|
// client is connected to.
|
|
string beacon_node_endpoint = 1;
|
|
// Whether the connection is active.
|
|
bool connected = 2;
|
|
// Whether the beacon node is currently synchronizing to chain head.
|
|
bool syncing = 3;
|
|
// The chain genesis time.
|
|
uint64 genesis_time = 4;
|
|
// Address of the validator deposit contract in the eth1 chain.
|
|
bytes deposit_contract_address = 5;
|
|
}
|
|
|
|
message ChangePasswordRequest {
|
|
string password = 1;
|
|
string password_confirmation = 2;
|
|
}
|
|
|
|
message HasWalletResponse {
|
|
// Whether or not the user has a wallet on disk.
|
|
bool wallet_exists = 1;
|
|
}
|
|
|
|
message ImportKeystoresRequest {
|
|
// JSON-encoded keystore files to import during wallet creation.
|
|
repeated string keystores_imported = 1;
|
|
|
|
// Password to unlock imported keystore files.
|
|
string keystores_password = 2;
|
|
}
|
|
|
|
message ImportKeystoresResponse {
|
|
repeated bytes imported_public_keys = 1;
|
|
}
|
|
|
|
message CreateAccountRequest {
|
|
uint64 num_accounts = 1;
|
|
}
|
|
|
|
message DepositDataResponse {
|
|
// The deposit data for each created account
|
|
// represented as a list in the same format as
|
|
// the deposit_data.json file from the eth2.0-deposit-cli.
|
|
repeated DepositData deposit_data_list = 1;
|
|
message DepositData {
|
|
string pubkey = 1;
|
|
string withdrawal_credentials = 2;
|
|
uint64 amount = 3;
|
|
string signature = 4;
|
|
string deposit_message_root = 5;
|
|
string deposit_data_root = 6;
|
|
string fork_version = 7;
|
|
}
|
|
}
|
|
|
|
message BackupAccountsRequest {
|
|
// List of public keys to backup.
|
|
repeated bytes public_keys = 1;
|
|
|
|
string backup_password = 2;
|
|
}
|
|
|
|
message BackupAccountsResponse {
|
|
// Zip file containing backed up keystores.
|
|
bytes zip_file = 1;
|
|
}
|
|
|
|
message DeleteAccountsRequest {
|
|
// List of public keys to delete.
|
|
repeated bytes public_keys = 1;
|
|
}
|
|
|
|
message DeleteAccountsResponse {
|
|
// List of public keys successfully deleted.
|
|
repeated bytes deleted_keys = 1;
|
|
}
|