prysm-pulse/proto/validator/accounts/v2/web_api.proto
Raul Jordan afce363e00
Update Protos for Wallet Creation (#7157)
* web api changes
* Merge branch 'master' into wallet-creation-protos
* protos checked in
* Merge branch 'wallet-creation-protos' of github.com:prysmaticlabs/prysm into wallet-creation-protos
2020-09-02 02:13:42 +00:00

214 lines
5.9 KiB
Protocol Buffer

syntax = "proto3";
package ethereum.validator.accounts.v2;
import "google/api/annotations.proto";
import "google/protobuf/empty.proto";
service Wallet {
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"
};
}
}
service Accounts {
rpc CreateAccount(google.protobuf.Empty) returns (CreateAccountResponse) {
option (google.api.http) = {
post: "/v2/validator/accounts/create",
body: "*"
};
}
rpc ListAccounts(ListAccountsRequest) returns (ListAccountsResponse) {
option (google.api.http) = {
get: "/v2/validator/accounts"
};
}
}
service Health {
rpc ListBalances(AccountRequest) returns (ListBalancesResponse) {
option (google.api.http) = {
get: "/v2/validator/balances"
};
}
rpc ListStatuses(AccountRequest) returns (ListStatusesResponse) {
option (google.api.http) = {
get: "/v2/validator/statuses"
};
}
rpc ListPerformance(AccountRequest) returns (ListPerformanceResponse) {
option (google.api.http) = {
get: "/v2/validator/performances"
};
}
}
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: "*"
};
}
}
message CreateWalletRequest {
// Path on disk where the wallet will be stored.
string wallet_path = 1;
// Type of key manager for the wallet, either direct, derived, or remote.
enum KeymanagerKind {
DERIVED = 0;
DIRECT = 1;
REMOTE = 2;
}
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 bytes keystores_imported = 6;
// Password to unlock imported keystore files.
repeated bytes 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;
// Key manager configs, this is meant to be some what generic.
// It'll later be encoded with json to represent in front end UI.
message KeymanagerConfig {
map<string, string> configs = 1;
}
KeymanagerConfig keymanager_config = 2;
}
message CreateAccountResponse {
Account account = 1;
}
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 ListBalancesResponse {
// A list of validator public keys.
repeated bytes public_keys = 1;
// A list of validator indices.
repeated uint64 indices = 2;
// A list of validator balances that maps to public keys and indices.
repeated uint64 balances = 3;
}
message ListStatusesResponse {
// A list of validator public keys.
repeated bytes public_keys = 1;
// A list of validator indices.
repeated uint64 indices = 2;
// A list of validator statuses that maps to public keys and indices.
enum ValidatorStatus {
UNKNOWN_STATUS = 0;
DEPOSITED = 1;
PENDING = 2;
ACTIVE = 3;
EXITING = 4;
SLASHING = 5;
EXITED = 6;
INVALID = 7;
}
repeated ValidatorStatus statuses = 3;
}
message ListPerformanceResponse {
// A list of validator public keys.
repeated bytes public_keys = 1;
// A list of validator indices.
repeated uint64 indices = 2;
// A list of block / attestation submission count since last launch.
message Submission {
uint64 block_count = 1;
uint64 attestation_count = 2;
}
repeated Submission submissions = 3;
}
message AuthRequest {
string password = 1;
}
message AuthResponse {
string token = 1;
uint64 token_expiration = 2;
}