NextScriptKey
NextScriptKey derives the next script key (and its corresponding internal key) and stores them both in the database to make sure they are identified as local keys later on when importing proofs.
Source: assetwalletrpc/assetwallet.proto
gRPC
rpc NextScriptKey (NextScriptKeyRequest) returns (NextScriptKeyResponse);
REST
| HTTP Method | Path |
|---|---|
| POST | /v1/taproot-assets/wallet/script-key/next |
Code Samples
- gRPC
- REST
- Javascript
- Python
- grpcurl
const fs = require('fs');
const grpc = require('@grpc/grpc-js');
const protoLoader = require('@grpc/proto-loader');
const GRPC_HOST = 'localhost:10029'
const MACAROON_PATH = 'TAPD_DIR/data/regtest/admin.macaroon'
const TLS_PATH = 'TAPD_DIR/tls.cert'
const loaderOptions = {
keepCase: true,
longs: String,
enums: String,
defaults: true,
oneofs: true,
};
const packageDefinition = protoLoader.loadSync('assetwalletrpc/assetwallet.proto', loaderOptions);
const assetwalletrpc = grpc.loadPackageDefinition(packageDefinition).assetwalletrpc;
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 assetwalletrpc.AssetWallet(GRPC_HOST, creds);
let request = {
key_family: <uint32>,
};
client.nextScriptKey(request, function(err, response) {
console.log(response);
});
// Console output:
// {
// "script_key": <ScriptKey>,
// }
import codecs, grpc, os
# Generate the following 2 modules by compiling the assetwalletrpc/assetwallet.proto with the grpcio-tools.
# See https://github.com/lightningnetwork/lnd/blob/master/docs/grpc/python.md for instructions.
import assetwallet_pb2 as assetwalletrpc, assetwallet_pb2_grpc as assetwalletstub
GRPC_HOST = 'localhost:10029'
MACAROON_PATH = 'TAPD_DIR/data/regtest/admin.macaroon'
TLS_PATH = 'TAPD_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 = assetwalletstub.AssetWalletStub(channel)
request = assetwalletrpc.NextScriptKeyRequest(
key_family=<uint32>,
)
response = stub.NextScriptKey(request)
print(response)
# {
# "script_key": <ScriptKey>,
# }
# grpcurl docs: https://github.com/fullstorydev/grpcurl
# Proto source: https://github.com/lightninglabs/taproot-assets
GRPC_HOST=localhost:10029
TAPD_DIR=~/.tapd
TAPD_SOURCE=path/to/taproot-assets
NETWORK=mainnet
MACAROON_PATH="$TAPD_DIR/data/$NETWORK/admin.macaroon"
TLS_PATH="$TAPD_DIR/tls.cert"
grpcurl \
-import-path $TAPD_SOURCE/taprpc/ \
-proto assetwalletrpc/assetwallet.proto \
-cacert $TLS_PATH \
-H "macaroon: $(xxd -ps -u -c 1000 $MACAROON_PATH)" \
-d '{ "key_family": <uint32> }' \
$GRPC_HOST \
assetwalletrpc.AssetWallet/NextScriptKey
- Javascript
- Python
- curl
const fs = require('fs');
const request = require('request');
const REST_HOST = 'localhost:8089'
const MACAROON_PATH = 'TAPD_DIR/data/regtest/admin.macaroon'
let requestBody = {
key_family: <integer>, // <uint32>
};
let options = {
url: `https://${REST_HOST}/v1/taproot-assets/wallet/script-key/next`,
// Work-around for self-signed certificates.
rejectUnauthorized: false,
json: true,
headers: {
'Grpc-Metadata-macaroon': fs.readFileSync(MACAROON_PATH).toString('hex'),
},
form: JSON.stringify(requestBody),
}
request.post(options, function(error, response, body) {
console.log(body);
});
// Console output:
// {
// "script_key": <object>, // <ScriptKey>
// }
import base64, codecs, json, requests
REST_HOST = 'localhost:8089'
MACAROON_PATH = 'TAPD_DIR/data/regtest/admin.macaroon'
TLS_PATH = 'TAPD_DIR/tls.cert'
url = f'https://{REST_HOST}/v1/taproot-assets/wallet/script-key/next'
macaroon = codecs.encode(open(MACAROON_PATH, 'rb').read(), 'hex')
headers = {'Grpc-Metadata-macaroon': macaroon}
data = {
'key_family': <uint32>,
}
r = requests.post(url, headers=headers, data=json.dumps(data), verify=TLS_PATH)
print(r.json())
# {
# "script_key": <ScriptKey>,
# }
REST_HOST=localhost:8089
TAPD_DIR=~/.tapd
NETWORK=mainnet
MACAROON_PATH="$TAPD_DIR/data/$NETWORK/admin.macaroon"
TLS_PATH="$TAPD_DIR/tls.cert"
curl -X POST \
--cacert $TLS_PATH \
-H "Grpc-Metadata-macaroon: $(xxd -ps -u -c 1000 $MACAROON_PATH)" \
-d '{ "key_family": <uint32> }' \
https://$REST_HOST/v1/taproot-assets/wallet/script-key/next
Messages
assetwalletrpc.NextScriptKeyRequest
Source: assetwalletrpc/assetwallet.proto
| Field | gRPC Type | REST Type | REST Placement |
|---|---|---|---|
key_family | uint32 | integer | body |
assetwalletrpc.NextScriptKeyResponse
Source: assetwalletrpc/assetwallet.proto
| Field | gRPC Type | REST Type |
|---|---|---|
script_key | ScriptKey | object |
Nested Messages
taprpc.KeyDescriptor
| Field | gRPC Type | REST Type |
|---|---|---|
raw_key_bytes | bytes | string |
key_loc | KeyLocator | object |
taprpc.KeyLocator
| Field | gRPC Type | REST Type |
|---|---|---|
key_family | int32 | integer |
key_index | int32 | integer |
taprpc.ScriptKey
| Field | gRPC Type | REST Type |
|---|---|---|
pub_key | bytes | string |
key_desc | KeyDescriptor | object |
tap_tweak | bytes | string |
type | ScriptKeyType | string |
Enums
taprpc.ScriptKeyType
| Name | Number |
|---|---|
SCRIPT_KEY_UNKNOWN | 0 |
SCRIPT_KEY_BIP86 | 1 |
SCRIPT_KEY_SCRIPT_PATH_EXTERNAL | 2 |
SCRIPT_KEY_BURN | 3 |
SCRIPT_KEY_TOMBSTONE | 4 |
SCRIPT_KEY_CHANNEL | 5 |
SCRIPT_KEY_UNIQUE_PEDERSEN | 6 |