2020-10-28 14:41:35 -07:00
|
|
|
syntax = "proto3";
|
|
|
|
|
|
|
|
package node.v1;
|
|
|
|
|
2021-08-26 01:35:09 -07:00
|
|
|
option go_package = "github.com/certusone/wormhole/node/pkg/proto/node/v1;nodev1";
|
2020-10-28 14:41:35 -07:00
|
|
|
|
2021-08-21 15:34:58 -07:00
|
|
|
// NodePrivilegedService exposes an administrative API. It runs on a UNIX socket and is authenticated
|
2020-11-19 03:53:19 -08:00
|
|
|
// using Linux filesystem permissions.
|
2021-08-21 15:34:58 -07:00
|
|
|
service NodePrivilegedService {
|
2021-01-19 04:01:45 -08:00
|
|
|
// InjectGovernanceVAA injects a governance VAA into the guardian node.
|
|
|
|
// The node will inject the VAA into the aggregator and sign/broadcast the VAA signature.
|
|
|
|
//
|
|
|
|
// A consensus majority of nodes on the network will have to inject the VAA within the
|
|
|
|
// VAA timeout window for it to reach consensus.
|
|
|
|
//
|
|
|
|
rpc InjectGovernanceVAA (InjectGovernanceVAARequest) returns (InjectGovernanceVAAResponse);
|
2020-11-19 03:53:17 -08:00
|
|
|
}
|
|
|
|
|
2021-01-19 04:01:45 -08:00
|
|
|
message InjectGovernanceVAARequest {
|
|
|
|
// Index of the current guardian set.
|
|
|
|
uint32 current_set_index = 1;
|
|
|
|
|
2021-09-30 11:57:44 -07:00
|
|
|
// Sequence number. This is critical for replay protection - make sure the sequence number
|
|
|
|
// is unique for every new manually injected governance VAA. Sequences are tracked
|
|
|
|
// by emitter, and manually injected VAAs all use a single hardcoded emitter.
|
2021-01-19 04:01:45 -08:00
|
|
|
//
|
2021-09-30 11:57:44 -07:00
|
|
|
// We use random sequence numbers for the manual emitter.
|
|
|
|
uint64 sequence = 2;
|
2020-11-19 03:53:19 -08:00
|
|
|
|
2021-09-30 11:57:44 -07:00
|
|
|
// Random nonce for disambiguation. Must be identical across all nodes.
|
|
|
|
uint32 nonce = 3;
|
2020-11-19 03:53:19 -08:00
|
|
|
|
2021-01-19 04:01:45 -08:00
|
|
|
oneof payload{
|
2021-10-01 03:26:05 -07:00
|
|
|
// Core module
|
|
|
|
|
2021-09-30 11:57:44 -07:00
|
|
|
GuardianSetUpdate guardian_set = 10;
|
|
|
|
ContractUpgrade contract_upgrade = 11;
|
2021-10-01 03:26:05 -07:00
|
|
|
|
|
|
|
// Token bridge and NFT module
|
|
|
|
|
|
|
|
BridgeRegisterChain bridge_register_chain = 12;
|
2021-01-19 04:01:45 -08:00
|
|
|
}
|
2020-11-19 03:53:19 -08:00
|
|
|
}
|
|
|
|
|
2021-01-19 04:01:45 -08:00
|
|
|
message InjectGovernanceVAAResponse {
|
|
|
|
// Canonical digest of the submitted VAA.
|
|
|
|
bytes digest = 1;
|
2020-11-19 03:53:19 -08:00
|
|
|
}
|
|
|
|
|
2021-01-19 04:01:45 -08:00
|
|
|
// GuardianSet represents a new guardian set to be submitted to and signed by the node.
|
|
|
|
// During the genesis procedure, this data structure will be assembled using off-chain collaborative tooling
|
|
|
|
// like GitHub using a human-readable encoding, so readability is a concern.
|
|
|
|
message GuardianSetUpdate {
|
|
|
|
// List of guardian set members.
|
|
|
|
message Guardian {
|
|
|
|
// Guardian key pubkey. Stored as hex string with 0x prefix for human readability -
|
|
|
|
// this is the canonical Ethereum representation.
|
|
|
|
string pubkey = 1;
|
|
|
|
// Optional descriptive name. Not stored on any chain, purely informational.
|
|
|
|
string name = 2;
|
|
|
|
};
|
|
|
|
repeated Guardian guardians = 3;
|
2020-11-19 03:53:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
// GuardianKey specifies the on-disk format for a node's guardian key.
|
2020-11-19 03:53:17 -08:00
|
|
|
message GuardianKey {
|
2021-01-19 04:01:45 -08:00
|
|
|
// data is the binary representation of the secp256k1 private key.
|
|
|
|
bytes data = 1;
|
2021-01-29 03:40:55 -08:00
|
|
|
// Whether this key is deterministically generated and unsuitable for production mode.
|
2021-07-30 15:12:28 -07:00
|
|
|
bool unsafe_deterministic_key = 2;
|
2021-01-19 04:01:45 -08:00
|
|
|
}
|
|
|
|
|
2021-10-01 03:26:05 -07:00
|
|
|
message BridgeRegisterChain {
|
|
|
|
// Module identifier of the token or NFT bridge (typically "TokenBridge" or "NFTBridge")
|
|
|
|
string module = 1;
|
|
|
|
|
2021-09-30 11:57:44 -07:00
|
|
|
// ID of the chain to be registered.
|
2021-10-01 03:26:05 -07:00
|
|
|
uint32 chain_id = 2;
|
2021-09-30 11:57:44 -07:00
|
|
|
|
|
|
|
// Hex-encoded emitter address to be registered (without leading 0x).
|
2021-10-01 03:26:05 -07:00
|
|
|
string emitter_address = 3;
|
2021-09-30 11:57:44 -07:00
|
|
|
}
|
|
|
|
|
2021-01-19 04:01:45 -08:00
|
|
|
// ContractUpgrade represents a Wormhole contract update to be submitted to and signed by the node.
|
|
|
|
message ContractUpgrade {
|
|
|
|
// ID of the chain where the Wormhole contract should be updated (uint8).
|
|
|
|
uint32 chain_id = 1;
|
|
|
|
|
|
|
|
// Address of the new program/contract.
|
|
|
|
bytes new_contract = 2;
|
2020-11-19 03:53:17 -08:00
|
|
|
}
|