2019-06-08 02:46:31 +02:00
|
|
|
syntax = "proto3";
|
|
|
|
|
|
|
|
package wtclientrpc;
|
|
|
|
|
|
|
|
option go_package = "github.com/lightningnetwork/lnd/lnrpc/wtclientrpc";
|
|
|
|
|
2023-11-15 02:30:34 +01:00
|
|
|
/*
|
|
|
|
* Comments in this file will be directly parsed into the API
|
|
|
|
* Documentation as descriptions of the associated method, message, or field.
|
|
|
|
* These descriptions should go right above the definition of the object, and
|
|
|
|
* can be in either block or // comment format.
|
|
|
|
*
|
|
|
|
* An RPC method can be matched to an lncli command by placing a line in the
|
|
|
|
* beginning of the description in exactly the following format:
|
|
|
|
* lncli: `methodname`
|
|
|
|
*
|
|
|
|
* Failure to specify the exact name of the command will cause documentation
|
|
|
|
* generation to fail.
|
|
|
|
*
|
|
|
|
* More information on how exactly the gRPC documentation is generated from
|
|
|
|
* this proto file can be found here:
|
|
|
|
* https://github.com/lightninglabs/lightning-api
|
|
|
|
*/
|
|
|
|
|
2020-05-06 16:41:47 +02:00
|
|
|
// WatchtowerClient is a service that grants access to the watchtower client
|
|
|
|
// functionality of the daemon.
|
|
|
|
service WatchtowerClient {
|
2023-11-15 02:30:34 +01:00
|
|
|
/* lncli: `wtclient add`
|
2020-05-06 16:41:47 +02:00
|
|
|
AddTower adds a new watchtower reachable at the given address and
|
|
|
|
considers it for new sessions. If the watchtower already exists, then
|
|
|
|
any new addresses included will be considered when dialing it for
|
|
|
|
session negotiations and backups.
|
|
|
|
*/
|
|
|
|
rpc AddTower (AddTowerRequest) returns (AddTowerResponse);
|
|
|
|
|
2023-11-15 02:30:34 +01:00
|
|
|
/* lncli: `wtclient remove`
|
2020-05-06 16:41:47 +02:00
|
|
|
RemoveTower removes a watchtower from being considered for future session
|
|
|
|
negotiations and from being used for any subsequent backups until it's added
|
|
|
|
again. If an address is provided, then this RPC only serves as a way of
|
|
|
|
removing the address from the watchtower instead.
|
|
|
|
*/
|
|
|
|
rpc RemoveTower (RemoveTowerRequest) returns (RemoveTowerResponse);
|
|
|
|
|
2023-11-28 17:21:44 +01:00
|
|
|
/* lncli: `wtclient deactivate`
|
|
|
|
DeactivateTower sets the given tower's status to inactive so that it
|
|
|
|
is not considered for session negotiation. Its sessions will also not
|
|
|
|
be used while the tower is inactive.
|
|
|
|
*/
|
|
|
|
rpc DeactivateTower (DeactivateTowerRequest)
|
|
|
|
returns (DeactivateTowerResponse);
|
|
|
|
|
2023-11-29 10:06:07 +01:00
|
|
|
/* lncli: `wtclient session terminate`
|
|
|
|
Terminate terminates the given session and marks it as terminal so that
|
|
|
|
it is not used for backups anymore.
|
|
|
|
*/
|
|
|
|
rpc TerminateSession (TerminateSessionRequest)
|
|
|
|
returns (TerminateSessionResponse);
|
|
|
|
|
2023-11-15 02:30:34 +01:00
|
|
|
/* lncli: `wtclient towers`
|
|
|
|
ListTowers returns the list of watchtowers registered with the client.
|
|
|
|
*/
|
2020-05-06 16:41:47 +02:00
|
|
|
rpc ListTowers (ListTowersRequest) returns (ListTowersResponse);
|
|
|
|
|
2023-11-15 02:30:34 +01:00
|
|
|
/* lncli: `wtclient tower`
|
|
|
|
GetTowerInfo retrieves information for a registered watchtower.
|
|
|
|
*/
|
2020-05-06 16:41:47 +02:00
|
|
|
rpc GetTowerInfo (GetTowerInfoRequest) returns (Tower);
|
|
|
|
|
2023-11-15 02:30:34 +01:00
|
|
|
/* lncli: `wtclient stats`
|
|
|
|
Stats returns the in-memory statistics of the client since startup.
|
|
|
|
*/
|
2020-05-06 16:41:47 +02:00
|
|
|
rpc Stats (StatsRequest) returns (StatsResponse);
|
|
|
|
|
2023-11-15 02:30:34 +01:00
|
|
|
/* lncli: `wtclient policy`
|
|
|
|
Policy returns the active watchtower client policy configuration.
|
|
|
|
*/
|
2020-05-06 16:41:47 +02:00
|
|
|
rpc Policy (PolicyRequest) returns (PolicyResponse);
|
|
|
|
}
|
|
|
|
|
2019-06-08 02:46:31 +02:00
|
|
|
message AddTowerRequest {
|
|
|
|
// The identifying public key of the watchtower to add.
|
2020-02-11 14:06:44 +01:00
|
|
|
bytes pubkey = 1;
|
2019-06-08 02:46:31 +02:00
|
|
|
|
|
|
|
// A network address the watchtower is reachable over.
|
2020-02-11 14:06:44 +01:00
|
|
|
string address = 2;
|
2019-06-08 02:46:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
message AddTowerResponse {
|
|
|
|
}
|
|
|
|
|
|
|
|
message RemoveTowerRequest {
|
|
|
|
// The identifying public key of the watchtower to remove.
|
2020-02-11 14:06:44 +01:00
|
|
|
bytes pubkey = 1;
|
2019-06-08 02:46:31 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
If set, then the record for this address will be removed, indicating that is
|
|
|
|
is stale. Otherwise, the watchtower will no longer be used for future
|
|
|
|
session negotiations and backups.
|
|
|
|
*/
|
2020-02-11 14:06:44 +01:00
|
|
|
string address = 2;
|
2019-06-08 02:46:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
message RemoveTowerResponse {
|
|
|
|
}
|
|
|
|
|
2023-11-28 17:21:44 +01:00
|
|
|
message DeactivateTowerRequest {
|
|
|
|
// The identifying public key of the watchtower to deactivate.
|
|
|
|
bytes pubkey = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message DeactivateTowerResponse {
|
|
|
|
// A string describing the action that took place.
|
|
|
|
string status = 1;
|
|
|
|
}
|
|
|
|
|
2023-11-29 10:06:07 +01:00
|
|
|
message TerminateSessionRequest {
|
|
|
|
// The ID of the session that should be terminated.
|
|
|
|
bytes session_id = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message TerminateSessionResponse {
|
|
|
|
// A string describing the action that took place.
|
|
|
|
string status = 1;
|
|
|
|
}
|
|
|
|
|
2019-06-08 02:46:31 +02:00
|
|
|
message GetTowerInfoRequest {
|
|
|
|
// The identifying public key of the watchtower to retrieve information for.
|
2020-02-11 14:06:44 +01:00
|
|
|
bytes pubkey = 1;
|
2019-06-08 02:46:31 +02:00
|
|
|
|
|
|
|
// Whether we should include sessions with the watchtower in the response.
|
2020-02-11 14:06:44 +01:00
|
|
|
bool include_sessions = 2;
|
2023-03-20 13:40:40 +01:00
|
|
|
|
|
|
|
// Whether to exclude exhausted sessions in the response info. This option
|
|
|
|
// is only meaningful if include_sessions is true.
|
|
|
|
bool exclude_exhausted_sessions = 3;
|
2019-06-08 02:46:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
message TowerSession {
|
|
|
|
/*
|
|
|
|
The total number of successful backups that have been made to the
|
|
|
|
watchtower session.
|
|
|
|
*/
|
2020-02-11 14:06:44 +01:00
|
|
|
uint32 num_backups = 1;
|
2019-06-08 02:46:31 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
The total number of backups in the session that are currently pending to be
|
|
|
|
acknowledged by the watchtower.
|
|
|
|
*/
|
2020-02-11 14:06:44 +01:00
|
|
|
uint32 num_pending_backups = 2;
|
2019-06-08 02:46:31 +02:00
|
|
|
|
|
|
|
// The maximum number of backups allowed by the watchtower session.
|
2020-02-11 14:06:44 +01:00
|
|
|
uint32 max_backups = 3;
|
2019-06-08 02:46:31 +02:00
|
|
|
|
|
|
|
/*
|
2021-03-11 01:29:50 +01:00
|
|
|
Deprecated, use sweep_sat_per_vbyte.
|
2019-06-08 02:46:31 +02:00
|
|
|
The fee rate, in satoshis per vbyte, that will be used by the watchtower for
|
|
|
|
the justice transaction in the event of a channel breach.
|
|
|
|
*/
|
2021-03-11 01:29:50 +01:00
|
|
|
uint32 sweep_sat_per_byte = 4 [deprecated = true];
|
|
|
|
|
|
|
|
/*
|
|
|
|
The fee rate, in satoshis per vbyte, that will be used by the watchtower for
|
|
|
|
the justice transaction in the event of a channel breach.
|
|
|
|
*/
|
|
|
|
uint32 sweep_sat_per_vbyte = 5;
|
2024-02-09 14:10:32 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
The ID of the session.
|
|
|
|
*/
|
|
|
|
bytes id = 6;
|
2019-06-08 02:46:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
message Tower {
|
|
|
|
// The identifying public key of the watchtower.
|
2020-02-11 14:06:44 +01:00
|
|
|
bytes pubkey = 1;
|
2019-06-08 02:46:31 +02:00
|
|
|
|
|
|
|
// The list of addresses the watchtower is reachable over.
|
2020-02-11 14:06:44 +01:00
|
|
|
repeated string addresses = 2;
|
2019-06-08 02:46:31 +02:00
|
|
|
|
2022-10-18 12:25:22 +02:00
|
|
|
// Deprecated, use the active_session_candidate field under the
|
|
|
|
// correct identifier in the client_type map.
|
2019-06-08 02:46:31 +02:00
|
|
|
// Whether the watchtower is currently a candidate for new sessions.
|
2022-10-18 12:25:22 +02:00
|
|
|
bool active_session_candidate = 3 [deprecated = true];
|
2019-06-08 02:46:31 +02:00
|
|
|
|
2022-10-18 12:25:22 +02:00
|
|
|
// Deprecated, use the num_sessions field under the correct identifier
|
|
|
|
// in the client_type map.
|
2019-06-08 02:46:31 +02:00
|
|
|
// The number of sessions that have been negotiated with the watchtower.
|
2022-10-18 12:25:22 +02:00
|
|
|
uint32 num_sessions = 4 [deprecated = true];
|
2019-06-08 02:46:31 +02:00
|
|
|
|
2022-10-18 12:25:22 +02:00
|
|
|
// Deprecated, use the sessions field under the correct identifier in the
|
|
|
|
// client_type map.
|
2019-06-08 02:46:31 +02:00
|
|
|
// The list of sessions that have been negotiated with the watchtower.
|
2022-10-18 12:25:22 +02:00
|
|
|
repeated TowerSession sessions = 5 [deprecated = true];
|
|
|
|
|
|
|
|
// A list sessions held with the tower.
|
|
|
|
repeated TowerSessionInfo session_info = 6;
|
|
|
|
}
|
|
|
|
|
|
|
|
message TowerSessionInfo {
|
|
|
|
// Whether the watchtower is currently a candidate for new sessions.
|
|
|
|
bool active_session_candidate = 1;
|
|
|
|
|
|
|
|
// The number of sessions that have been negotiated with the watchtower.
|
|
|
|
uint32 num_sessions = 2;
|
|
|
|
|
|
|
|
// The list of sessions that have been negotiated with the watchtower.
|
|
|
|
repeated TowerSession sessions = 3;
|
|
|
|
|
|
|
|
// The session's policy type.
|
|
|
|
PolicyType policy_type = 4;
|
2019-06-08 02:46:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
message ListTowersRequest {
|
|
|
|
// Whether we should include sessions with the watchtower in the response.
|
2020-02-11 14:06:44 +01:00
|
|
|
bool include_sessions = 1;
|
2023-03-20 13:40:40 +01:00
|
|
|
|
|
|
|
// Whether to exclude exhausted sessions in the response info. This option
|
|
|
|
// is only meaningful if include_sessions is true.
|
|
|
|
bool exclude_exhausted_sessions = 2;
|
2019-06-08 02:46:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
message ListTowersResponse {
|
|
|
|
// The list of watchtowers available for new backups.
|
2020-02-11 14:06:44 +01:00
|
|
|
repeated Tower towers = 1;
|
2019-06-08 02:46:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
message StatsRequest {
|
|
|
|
}
|
|
|
|
|
|
|
|
message StatsResponse {
|
|
|
|
/*
|
|
|
|
The total number of backups made to all active and exhausted watchtower
|
|
|
|
sessions.
|
|
|
|
*/
|
2020-02-11 14:06:44 +01:00
|
|
|
uint32 num_backups = 1;
|
2019-06-08 02:46:31 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
The total number of backups that are pending to be acknowledged by all
|
|
|
|
active and exhausted watchtower sessions.
|
|
|
|
*/
|
2020-02-11 14:06:44 +01:00
|
|
|
uint32 num_pending_backups = 2;
|
2019-06-08 02:46:31 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
The total number of backups that all active and exhausted watchtower
|
|
|
|
sessions have failed to acknowledge.
|
|
|
|
*/
|
2020-02-11 14:06:44 +01:00
|
|
|
uint32 num_failed_backups = 3;
|
2019-06-08 02:46:31 +02:00
|
|
|
|
|
|
|
// The total number of new sessions made to watchtowers.
|
2020-02-11 14:06:44 +01:00
|
|
|
uint32 num_sessions_acquired = 4;
|
2019-06-08 02:46:31 +02:00
|
|
|
|
|
|
|
// The total number of watchtower sessions that have been exhausted.
|
2020-02-11 14:06:44 +01:00
|
|
|
uint32 num_sessions_exhausted = 5;
|
2019-06-08 02:46:31 +02:00
|
|
|
}
|
|
|
|
|
2020-11-26 00:07:42 +01:00
|
|
|
enum PolicyType {
|
|
|
|
// Selects the policy from the legacy tower client.
|
|
|
|
LEGACY = 0;
|
|
|
|
|
|
|
|
// Selects the policy from the anchor tower client.
|
|
|
|
ANCHOR = 1;
|
2023-08-28 15:21:16 +02:00
|
|
|
|
|
|
|
// Selects the policy from the taproot tower client.
|
|
|
|
TAPROOT = 2;
|
2020-11-26 00:07:42 +01:00
|
|
|
}
|
|
|
|
|
2019-06-08 02:46:31 +02:00
|
|
|
message PolicyRequest {
|
2020-11-26 00:07:42 +01:00
|
|
|
/*
|
|
|
|
The client type from which to retrieve the active offering policy.
|
|
|
|
*/
|
|
|
|
PolicyType policy_type = 1;
|
2019-06-08 02:46:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
message PolicyResponse {
|
|
|
|
/*
|
|
|
|
The maximum number of updates each session we negotiate with watchtowers
|
|
|
|
should allow.
|
|
|
|
*/
|
2020-02-11 14:06:44 +01:00
|
|
|
uint32 max_updates = 1;
|
2019-06-08 02:46:31 +02:00
|
|
|
|
2021-03-11 01:29:50 +01:00
|
|
|
/*
|
|
|
|
Deprecated, use sweep_sat_per_vbyte.
|
|
|
|
The fee rate, in satoshis per vbyte, that will be used by watchtowers for
|
|
|
|
justice transactions in response to channel breaches.
|
|
|
|
*/
|
|
|
|
uint32 sweep_sat_per_byte = 2 [deprecated = true];
|
|
|
|
|
2019-06-08 02:46:31 +02:00
|
|
|
/*
|
|
|
|
The fee rate, in satoshis per vbyte, that will be used by watchtowers for
|
|
|
|
justice transactions in response to channel breaches.
|
|
|
|
*/
|
2021-03-11 01:29:50 +01:00
|
|
|
uint32 sweep_sat_per_vbyte = 3;
|
2019-06-08 02:46:31 +02:00
|
|
|
}
|