prysm-pulse/proto/validator/accounts/v2/web_api.proto
Raul Jordan 2d4bfbbe31
Web UI Security Improvements (#7676)
* remove delete accounts

* check if user has not yet signed up
2020-10-29 16:38:47 -05:00

273 lines
7.5 KiB
Protocol Buffer

syntax = "proto3";
package ethereum.validator.accounts.v2;
import "google/api/annotations.proto";
import "google/protobuf/empty.proto";
import "github.com/gogo/protobuf/gogoproto/gogo.proto";
service Wallet {
rpc HasWallet(google.protobuf.Empty) returns (HasWalletResponse) {
option (google.api.http) = {
get: "/v2/validator/wallet/exists"
};
}
rpc CreateWallet(CreateWalletRequest) returns (CreateWalletResponse) {
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 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 ChangePassword(ChangePasswordRequest) returns (google.protobuf.Empty) {
option (google.api.http) = {
post: "/v2/validator/password/edit",
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: "*"
};
}
rpc Logout(google.protobuf.Empty) returns (google.protobuf.Empty) {
option (google.api.http) = {
post: "/v2/validator/logout",
body: "*"
};
}
}
// Type of key manager for the wallet, either direct, derived, or remote.
enum KeymanagerKind {
DERIVED = 0;
IMPORTED = 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;
// Remote address such as host.example.com:4000 for a gRPC remote signer server.
string remote_addr = 6;
// Path to client.crt for secure TLS connections to a remote signer server.
string remote_crt_path = 7;
// Path to client.key for secure TLS connections to a remote signer server.
string remote_key_path = 8;
// Path to ca.crt for secure TLS connections to a remote signer server.
string remote_ca_crt_path = 9;
}
message CreateWalletResponse {
WalletResponse wallet = 1;
DepositDataResponse accounts_created = 2;
}
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;
// The maximum number of accounts to return in the response.
// This field is optional.
int32 page_size = 2;
// A pagination token returned from a previous call to `ListAccounts`
// that indicates where this listing should continue from.
// This field is optional.
string page_token = 3;
// Whether to return all available accounts in a single response.
bool all = 4;
}
message ListAccountsResponse {
repeated Account accounts = 1;
// A pagination token returned from a previous call to `ListAccounts`
// that indicates from where listing should continue.
// This field is optional.
string next_page_token = 2;
// Total count matching the request.
int32 total_size = 3;
}
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;
string wallet_dir = 2;
}
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 current_password = 1;
string password = 2;
string password_confirmation = 3;
}
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 DepositMessage {
bytes pubkey = 1 [(gogoproto.moretags) = "ssz-size:\"48\""];
bytes withdrawal_credentials = 2 [(gogoproto.moretags) = "ssz-size:\"32\""];
uint64 amount = 3;
}
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 {
map<string, string> data = 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;
}