GetTransactions
GetTransactions returns a list describing all the known transactions relevant to the wallet.
Source: lightning.proto
gRPC
rpc GetTransactions (GetTransactionsRequest) returns (TransactionDetails);
REST
HTTP Method | Path |
---|---|
GET | /v1/transactions |
Code Samples
- gRPC
- REST
- Shell
- Javascript
- Python
const fs = require('fs');
const grpc = require('@grpc/grpc-js');
const protoLoader = require('@grpc/proto-loader');
const GRPC_HOST = 'localhost:10009'
const MACAROON_PATH = 'LND_DIR/data/chain/bitcoin/regtest/admin.macaroon'
const TLS_PATH = 'LND_DIR/tls.cert'
const loaderOptions = {
keepCase: true,
longs: String,
enums: String,
defaults: true,
oneofs: true,
};
const packageDefinition = protoLoader.loadSync('lightning.proto', loaderOptions);
const lnrpc = grpc.loadPackageDefinition(packageDefinition).lnrpc;
process.env.GRPC_SSL_CIPHER_SUITES = 'HIGH+ECDSA';
const tlsCert = fs.readFileSync(TLS_PATH);
const sslCreds = grpc.credentials.createSsl(tlsCert);
const macaroon = fs.readFileSync(MACAROON_PATH).toString('hex');
const macaroonCreds = grpc.credentials.createFromMetadataGenerator(function(args, callback) {
let metadata = new grpc.Metadata();
metadata.add('macaroon', macaroon);
callback(null, metadata);
});
let creds = grpc.credentials.combineChannelCredentials(sslCreds, macaroonCreds);
let client = new lnrpc.Lightning(GRPC_HOST, creds);
let request = {
start_height: <int32>,
end_height: <int32>,
account: <string>,
index_offset: <uint32>,
max_transactions: <uint32>,
};
client.getTransactions(request, function(err, response) {
console.log(response);
});
// Console output:
// {
// "transactions": <Transaction>,
// "last_index": <uint64>,
// "first_index": <uint64>,
// }
import codecs, grpc, os
# Generate the following 2 modules by compiling the lightning.proto with the grpcio-tools.
# See https://github.com/lightningnetwork/lnd/blob/master/docs/grpc/python.md for instructions.
import lightning_pb2 as lnrpc, lightning_pb2_grpc as lightningstub
GRPC_HOST = 'localhost:10009'
MACAROON_PATH = 'LND_DIR/data/chain/bitcoin/regtest/admin.macaroon'
TLS_PATH = 'LND_DIR/tls.cert'
# create macaroon credentials
macaroon = codecs.encode(open(MACAROON_PATH, 'rb').read(), 'hex')
def metadata_callback(context, callback):
callback([('macaroon', macaroon)], None)
auth_creds = grpc.metadata_call_credentials(metadata_callback)
# create SSL credentials
os.environ['GRPC_SSL_CIPHER_SUITES'] = 'HIGH+ECDSA'
cert = open(TLS_PATH, 'rb').read()
ssl_creds = grpc.ssl_channel_credentials(cert)
# combine macaroon and SSL credentials
combined_creds = grpc.composite_channel_credentials(ssl_creds, auth_creds)
# make the request
channel = grpc.secure_channel(GRPC_HOST, combined_creds)
stub = lightningstub.LightningStub(channel)
request = lnrpc.GetTransactionsRequest(
start_height=<int32>,
end_height=<int32>,
account=<string>,
index_offset=<uint32>,
max_transactions=<uint32>,
)
response = stub.GetTransactions(request)
print(response)
# {
# "transactions": <Transaction>,
# "last_index": <uint64>,
# "first_index": <uint64>,
# }
- Javascript
- Python
const fs = require('fs');
const request = require('request');
const REST_HOST = 'localhost:8080'
const MACAROON_PATH = 'LND_DIR/data/chain/bitcoin/regtest/admin.macaroon'
let options = {
url: `https://${REST_HOST}/v1/transactions`,
// Work-around for self-signed certificates.
rejectUnauthorized: false,
json: true,
headers: {
'Grpc-Metadata-macaroon': fs.readFileSync(MACAROON_PATH).toString('hex'),
},
}
request.get(options, function(error, response, body) {
console.log(body);
});
// Console output:
// {
// "transactions": <array>, // <Transaction>
// "last_index": <string>, // <uint64>
// "first_index": <string>, // <uint64>
// }
import base64, codecs, json, requests
REST_HOST = 'localhost:8080'
MACAROON_PATH = 'LND_DIR/data/chain/bitcoin/regtest/admin.macaroon'
TLS_PATH = 'LND_DIR/tls.cert'
url = f'https://{REST_HOST}/v1/transactions'
macaroon = codecs.encode(open(MACAROON_PATH, 'rb').read(), 'hex')
headers = {'Grpc-Metadata-macaroon': macaroon}
r = requests.get(url, headers=headers, verify=TLS_PATH)
print(r.json())
# {
# "transactions": <Transaction>,
# "last_index": <uint64>,
# "first_index": <uint64>,
# }
$ lncli listchaintxns --help
NAME:
lncli listchaintxns - List transactions from the wallet.
USAGE:
lncli listchaintxns [command options] [arguments...]
CATEGORY:
On-chain
DESCRIPTION:
List all transactions an address of the wallet was involved in.
This call will return a list of wallet related transactions that paid
to an address our wallet controls, or spent utxos that we held.
By default, this call will get all transactions until the chain tip,
including unconfirmed transactions (end_height=-1).
OPTIONS:
--start_height value the block height from which to list transactions, inclusive (default: 0)
--end_height value the block height until which to list transactions, inclusive; by default this will return all transactions up to the chain tip including unconfirmed transactions (default: -1)
--index_offset value the index of a transaction that will be used in a query to determine which transaction should be returned in the response (default: 0)
--max_transactions value the max number of transactions to return; leave at default of 0 to return all transactions (default: 0)
Messages
lnrpc.GetTransactionsRequest
Source: lightning.proto
Field | gRPC Type | REST Type | REST Placement |
---|---|---|---|
start_height | int32 | integer | query |
end_height | int32 | integer | query |
account | string | string | query |
index_offset | uint32 | integer | query |
max_transactions | uint32 | integer | query |
lnrpc.TransactionDetails
Source: lightning.proto
Field | gRPC Type | REST Type |
---|---|---|
transactions | Transaction[] | array |
last_index | uint64 | string |
first_index | uint64 | string |
Nested Messages
lnrpc.OutputDetail
Field | gRPC Type | REST Type |
---|---|---|
output_type | OutputScriptType | string |
address | string | string |
pk_script | string | string |
output_index | int64 | string |
amount | int64 | string |
is_our_address | bool | boolean |
lnrpc.PreviousOutPoint
Field | gRPC Type | REST Type |
---|---|---|
outpoint | string | string |
is_our_output | bool | boolean |
lnrpc.Transaction
Field | gRPC Type | REST Type |
---|---|---|
tx_hash | string | string |
amount | int64 | string |
num_confirmations | int32 | integer |
block_hash | string | string |
block_height | int32 | integer |
time_stamp | int64 | string |
total_fees | int64 | string |
dest_addresses deprecated | string[] | array |
output_details | OutputDetail[] | array |
raw_tx_hex | string | string |
label | string | string |
previous_outpoints | PreviousOutPoint[] | array |
Enums
lnrpc.OutputScriptType
Name | Number |
---|---|
SCRIPT_TYPE_PUBKEY_HASH | 0 |
SCRIPT_TYPE_SCRIPT_HASH | 1 |
SCRIPT_TYPE_WITNESS_V0_PUBKEY_HASH | 2 |
SCRIPT_TYPE_WITNESS_V0_SCRIPT_HASH | 3 |
SCRIPT_TYPE_PUBKEY | 4 |
SCRIPT_TYPE_MULTISIG | 5 |
SCRIPT_TYPE_NULLDATA | 6 |
SCRIPT_TYPE_NON_STANDARD | 7 |
SCRIPT_TYPE_WITNESS_UNKNOWN | 8 |
SCRIPT_TYPE_WITNESS_V1_TAPROOT | 9 |