Transcripts

Miniscript

Speaker 0: 00:00:15

Welcome back to the Chaincode Podcast.

Speaker 1: 00:00:17

Hey, this is Murch.

Speaker 0: 00:00:18

And Jonas. Murch, this episode sounds a little bit different when we actually get into the meat of things. So why is it different?

Speaker 1: 00:00:26

I did a little bit of field reporting. So I recorded an episode myself for the first time. We were using different equipment, different environment. I think the sound could have gone a little better, but I recorded a great episode with Sanket.

Speaker 0: 00:00:42

Cool. Yeah, it's really great to have Sanket on, And you really get into the weeds in this Miniscript stuff, huh?

Speaker 1: 00:00:48

Yeah, we explore a little bit the intersection of Miniscript with other developments recently. So PSPTs, output descriptors, Miniscript policy versus Miniscript. I think especially if you're into wallet development or addresses and that sort of stuff, this one will be fun.

Speaker 0: 00:01:07

One of your many nicknames is the wallet whisperer. So I think it'll really be showing your colors here.

Speaker 1: 00:01:14

I guess.

Speaker 0: 00:01:15

All right, hope you enjoy the episode.

Speaker 1: 00:01:24

Hi I'm sitting here with Sanket Kansalkar and I'm gonna talk to him about Minuscript and Minuscript policy and his work that he's doing on making it easier for us to implement more complex contracts on Bitcoin.

Speaker 2: 00:01:49

Hi, I'm Sanket. Nice to be here in New York and excited to discuss more about Miniscript.

What's Miniscript?

Speaker 1: 00:01:57

Miniscript, what is that even actually?

Speaker 2: 00:02:00

Miniscript is Bitcoin script, a subset of Bitcoin script. So to understand what Miniscript is, I'll just go briefly into the problems with current Bitcoin script. As the listeners of this podcast are aware, we have Bitcoin script, which is a stack-based language, which operates on certain opcodes, which manipulate the stack in certain ways to hopefully finally give you a success result. And even though it seems simple at first glance, like you have the stack and you have these opcodes which do some deterministic things on stack. It should be easy to analyze these things, but you could do lots of complex things with Bitcoin, with the current Bitcoin script, which aren't easily analyzable. Like look at the first element, look at its size and based on that, do something else. And what we, our goal with Miniscript was to have something which is more structured. It should enable composition and analysis of script. We also get some other cool features which we will get into but first we get this semantic analysis of script. I give you some script and you want to figure out what it does. It's a mini script you will you can easily figure out what it is doing and right now if you look stare at bunch of like Bitcoin script with this opcodes and weird hexes looking at you, you really have no idea and you hope that it does what it does correctly.

Speaker 1: 00:03:25

Okay, let me try to extract all the things you said here. Miniscript is a subset of the whole Bitcoin script language and you're only using opcodes to understand what they're doing on a...

Speaker 2: 00:03:38

It's best if we not think in terms of opcodes, but we think in terms of fragments of the operations which we are interested in. So Miniscript has three fundamental Bitcoin fragments that we are interested in, like signature checking, hash locks, and time locks. And we have different types of hash locks and time locks, but at a higher level, we have these three constraints, which we would want to use Bitcoin script for and any combination of those you could have ands of time logs or like this time and this key or these three keys spent together so any combination ands or or thresholds of these is a mini script. So we don't have to think in terms of opcodes or what is like check sequence verify or like doing hash or checking the pre-image is equal or not. For thinking about mini scripts It's best if you think about these three basic constraints and combinations of these constraints.

Speaker 1: 00:04:38

So Miniscript is an abstraction layer over Bitcoin script. It takes the concepts out of Bitcoin script and expresses them as a logic composition basically.

Speaker 2: 00:04:49

Yes, It's abstraction, but it's one-to-one mapping. Like, you can go from Bitcoin script to Miniscript and Miniscript to Bitcoin script, like vice versa. Cool. So abstraction, people usually think of it like you lose some information or you gain away but it helps you look at the same subset of Bitcoin script in a more structured way so there is a one-to-one mapping between.

Speaker 1: 00:05:11

Okay that's important yes.

Partially Signed Bitcoin Transactions (PSBTs)

Speaker 1: 00:05:13

How did you come up with needing Miniscript? Why did do we need it and who is it for?

Speaker 2: 00:05:20

Okay, so this is before my involvement in Miniscript. How did people come up with Miniscript? It started with PSBTs. So with PSBTs you have, in the PSBT workflow, we have these different roles where- PSBT of course stands for Partially Signed Bitcoin Transactions and describes a protocol for creating multi-user transactions. Yeah, so with this PSBTs, we have like this partially signed Bitcoin transactions. We have all these different roles. We have a, in a PSBT workflow, we have say a creator role which creates a basic transaction skeleton and we, I'm ignoring the PSPT v2 parts for now, but let's just stick with the original PSPT. The rules are pretty much the same. We have a transaction creator. We have some transaction updater role, which would update the transaction with some necessary signing information. We have the signers, which could be your hardware wallets, which would sign that transaction. And we have this role finally called finalizer, which is different from signer. And the job of finalizer, so the job of signer is to get, like take this PSBT, this bunch of key value pairs and for a particular input, put its signature in some certain, in a key value pair onto this PSBT data structure. And you would pass on this PSBT to different hardware wallets, software wallets, and we even have extended PSBT spec with hash, like hash free images. And people would feed in all this information into your PSBT key value store. And you still somehow have to create this script SIG or witness. And the job of this finalizer is to create this, like look at all this information, which has already used, like has all the signatures and everything and finally create this final witness or final script fields Which those are called in PSV.

Analyzing PSBTs with Miniscript

Speaker 1: 00:07:23

Right. So how does mini script?

Speaker 2: 00:07:25

Yeah, this is where mini script comes into play so let's say you have a complex like some script now you have some complex script like a three or five and one of them in like you're trying to spend a three or five output and one of the three or five is say another some complex policy which has you implement a time lock and maybe it has it can also be spent by some like lightning HDLCs. So when you your hardware wallet just gives you a signature for the corresponding like corresponding input and the signature message and now you have to still satisfy this given all these signatures you still have to create a final witness now this is where many script comes in it looks at all these possible like so it looks at the script the script which you are spending the witness script or the redeem script, and figures out what, like based on this public key, this satisfaction, I have satisfaction for these keys, I know the pre-images for these time locks, and it is currently it is this sequence number for this transaction and it is this time log so can I use this path? It will figure out all it will take all this information and create this final like this final witness or final script so it's kind of like a smart finalizer you could have any mini script and you just your wallets just given their signatures and like hash images and the mini script finalizer would just automatically fill in the witness for you.

Speaker 1: 00:08:55

So the mini script in PSPT is basically used as a recipe on how to reconstruct all the ingredients, all the signatures that people have provided, given the public key information and so forth, into the actual Bitcoin transaction that then can be sent to the network.

Speaker 2: 00:09:14

Yes, exactly. And that's how it was motivated. Now you have all these signatures. Now, how do you actually create this?

Speaker 1: 00:09:20

Right,

Speaker 2: 00:09:21

and that is what led to like then we should have so you cannot obviously do this for all Scripts like you could have complex scripts where it cannot even if you have signatures or something, you just can't reason about these scripts, how to satisfy those. But then I think Peter and you were primary Andrew Postron and Peter, whatever they were involved before I started working on this project. And they decided, okay, if we look at a subset of this, which is analyzable, we can satisfy those scripts generically. And that is where Miniscript was like, that's how Miniscript was started.

Speaker 1: 00:09:56

Okay, so basically, it was that just describes how we got a subset of script in the first place. We only took the ones that we could analyze and could generically express. And the motivation was to be able to craft these recipes for PSPT.

How do Output Descriptors relate to Miniscript

Speaker 1: 00:10:15

I think that's also related to output descriptors, right?

Speaker 2: 00:10:19

Yes, so yeah, that is also related to output descriptors. So, output descriptors essentially are like encodings of your witness script or script pub key, or sorry, reading script. So when I say, I just try to distinguish those witness script is like segwit thing and reading script is like the P2SH version of.

Speaker 1: 00:10:41

Right,

Speaker 2: 00:10:42

yes. Ideally, we would want to extend these output descriptors with mini script descriptors. So you would have, right now our descriptors are like fairly limited. You have like multi and multi is I think probably the most complex one which we have. So... You mean uptake multi-sig? Yeah, no, multi-descriptor. Like, you know, multi-descriptor. So with Miniscript, we would have a Miniscript descriptor, which would be something like a WSH of, inside of that you would actually write your mini script descriptor. And since there is a one-to-one, so this is how it like fits in with PSBTs, where you have this redeem script or witness script, And from this, I mentioned previously that we have this one-to-one mapping between all of these mini scripts and the scripts. So you look at all these witness scripts, you create a mini script from it. So one-to-one mapping, we can do that. And by looking at that, and like the structured mini script and the witnesses, you can create this.

Speaker 1: 00:11:52

On the one hand, mini script can be used by somebody that looks at Bitcoin script to convert it to something more generic and the mini script representation, and then to forward it to the others? So I think you lost me a little bit, sorry.

Speaker 2: 00:12:11

So I think the question was like output descriptors and how do, like How does Miniscript fit into, like I'm interpreting the question as how does Miniscript relate to output descriptors and where does Miniscript fit in this descriptor world? So this would be a, Miniscript descriptors would be like an extension to the current descriptors where right now we have like say WSH of multi is a descriptor. Inside of that, you would have WSH and a miniscript string representation, which would describe a miniscript output. Right. Okay. And that is how, like, you, and then you get all the cool properties of like descriptors. You can figure out the script of keys and with Miniscript you get like figure out.

Speaker 1: 00:12:55

So, so currently output descriptors do not use Miniscript yet, but it would be cool to do so.

Speaker 2: 00:13:01

Yes. Okay. Yeah, it would be like as an output descriptors, we use those as in like in Rust Miniscript and like there is a full like Miniscript is fully specified and we have a good idea and we know that we are going to use how we are going to use output descriptors, but they are not specified in Bitcoin core output descriptors.md Right, right, okay. So we have a very good idea and probably a final idea of how manuscript descriptors are going to look like.

Speaker 1: 00:13:30

Cool. You mentioned that there is a difference of course between or that there is more than one implementation of Miniscript.

Implementations of Miniscript

Speaker 1: 00:13:39

There's Rust Miniscript. I think you've been working a lot on that. Yeah. And there's another Miniscript implementation. Is that in Bitcoin Core?

Speaker 2: 00:13:49

I mean that's a C++ implementation which is designed to be implemented, like easy to be merged with Bitcoin Core. So it's not in Bitcoin Core, it's a separate repository. You can go to like C++ implementation of Miniscript.

Speaker 1: 00:14:06

I see. So Miniscript is not in Bitcoin Core at all yet?

Speaker 2: 00:14:09

No, it is not in Bitcoin Core at all yet.

Speaker 1: 00:14:13

So how's that going to happen?

Speaker 2: 00:14:15

Hopefully through some part through me and Yeah community review. So it is one of the things which I have taken up on myself and like Hopefully plan to do in the near future is to take Peters were like Peters currently implemented version of many script and make a PR to Core to have Miniscript descriptors and output wallet support for Miniscript.

Speaker 1: 00:14:42

Okay, cool.

Speaker 2: 00:14:43

Yeah, and that will bring a bunch of cool things.

Speaker 1: 00:14:46

My understanding is that you and Repulstra, SIPA of course, have been looking at Minuscript for a while.

Semantic analysis of Scripts

Speaker 1: 00:14:56

You mentioned that you use it as a tool for analysis of what script does. Can you tell us a little bit about cool improvements that you found or astonishing discoveries you made while doing that?

Speaker 2: 00:15:09

Yeah. I'll split this answer into two parts. So first is the analysis part, which is, given a mini script, you can look at the mini script, like you can just, it's a tree structure. You can look at the mini script and you can understand what it does, which is something you cannot do with script. You can see it's an add.

Speaker 1: 00:15:29

Yes, I can attest to that. Yes.

Speaker 2: 00:15:33

But not only that, it is a, since we have this structured format, you can answer questions like can this mini script ever be spent? If I don't have access to my cold wallet, can anyone ever spend the script? And you can answer these type of questions which you might want for your security audits.

Speaker 1: 00:15:52

That sounds really important in the context of PSPT and some of the vulnerabilities we found with hardware wallets in the last year or so where hardware wallets could be tricked into participating in transactions where the outputs were actually not spendable by them and things like that.

Speaker 2: 00:16:07

So this allows you, this is more for your software wallet analysis type of things, but hardware wallet, like it does not help you. Hardware wallet probably do not even need to understand Miniscript which is slightly digressing but I think I should highlight this point. So Miniscript like hardware wallet should just understand that given this This is your key and this is the PSPD. Just create a signature for it. And in the PSPD workflow, they don't need to understand anything. They just need to know, I know this private key and I'm asked to give the signature. I'll give the signature. Now, Miniscript does not deal with like vulnerabilities of those sort, but your software wallet on the other hand can make these claims that if I trust this hardware wallet or if I trust this key and as long as that is not hacked, I have all these different components of my script or spending different spending paths. As long as those are compromised or whatever happened with them, I can be sure that I have this thing with me and without that you cannot steal it.

Speaker 1: 00:17:09

So being able to more clearly analyze how the script works allows us to test our security assumptions more easily.

Speaker 0: 00:17:16

Yes. Mm-hmm.

Speaker 2: 00:17:17

So when I'll correct myself slightly, I mentioned software wallet. I should just mention software. Like, it does not have to be wallet.

Speaker 1: 00:17:24

Like, you could have a mini script analyzer, which will analyze your script and tell you statically, this cannot be spent before this time and this cannot be and you do this generically Yeah We've had lately a bit of a push by some people to distinguish wallets from signers Like actually a hardware wallet might be better called just a hardware signing tool or module. Because a lot of what we think of as the wallet is really the software that keeps track of your funds and provides UX to the user. So maybe that's a little related here, the hardware signer and the software wallet.

Speaker 2: 00:18:07

The software analyzer. It does not even have to keep track of your friends or anything. It's just for analyzing your script. And so that is the analysis. That's how Miniscript relates to semantic analysis. And you can, we are open for more PRs or anything if you find more cool things to analyze with this. And for example, I just have access to these mini keys, how does my script look like? I never want to use my cold wallet. What do my spend conditions look like? I want to spend it two years from future. You can answer these type of questions. So going to the other part, which is like While analyzing these things and while working on many scripts, we discovered a bunch of interesting things, limitations of scripts. As long as you, whenever you try to do something slightly complicated, you run into the script resource limits, which are the 201 opcode limit, some standardness and policy, such standardness and consensus rules about the script, like about the script size, rules about how many witness elements you can have initially in your stack as a standardness rule. Yeah, I think those are like, those are the important ones. So if you try to write complex if you just run into a case where you are certainly like exceeding 201 opcodes and per transaction or per input, that is per like per script per output, sorry, but yeah, per input to any which you are executing the Previous output. But if I give you a, let's say you are trying to, so Miniscript has to deal with all of these things because if I am spending, if I give you a like a mini script and you look at it, you look at the tree and you say oh it looks great like I can spend it with this key and you analyze your own policy maybe for your company you implement some complex policy And let's say there's one path which requires more than 201 opcodes to spend it. So the mini script has to detect all of these things and one, or just not have those as valid mini scripts where you say that user, maybe if you try to spend these funds, the network won't accept it.

Speaker 1: 00:20:17

Right. So you could have a very complex script where parts of it are actually unspendable due to the complexity that it takes to create the input script for them. Yeah that would be a pretty rude thing to do to a transaction partner.

Speaker 2: 00:20:34

Yeah, and if you're in a multi-party setting, maybe you just trick them. You're saying, oh, this part looks good? Yeah, why don't you accept it? And then they try to spend it, and boom, you cannot spend it.

Speaker 1: 00:20:43

Oh, do you want to give me 50% of your money in order to spend your money. Yeah, I see where that might be going.

Speaker 2: 00:20:50

Yeah, so that is one. So you could also, for example, have like your script size, like maybe some of your satisfactions require more than 100 elements, then certainly it becomes non-standard. So Miniscript, when we tried to look at, when we looked at these things, we thought, okay, this is a problem, because when you're dealing with small scripts, everything is good. But when you are like certainly touching these resource limitations, you exceed one of these paths. And then some Miniscript detects all of those things. And like in SegWit context, you have these different rules. So Miniscript would tell you, it would warn you that this script has spent paths which would possibly, which cannot be spent. One of the examples is like Russell O'Connor recently discovered that, it was known to people, but recently highlighted that you cannot spend a time lock and height lock in the same thing because your n, your number for n lock time in a transaction it is either greater than 5 million in which case it is interpreted as a timestamp or it is less than million where it is interpreted as a block height and say you were given this thing where your satisfaction suddenly requires you to have a Time block and a height lock and you just cannot do both of them together.

Speaker 1: 00:22:09

Right, obviously.

Speaker 2: 00:22:10

So we run into these issues and The job for manuscript is to do this once and for all like check and the library would warn the users that okay you are participating in a transaction where like you should not be participating in this transaction with a in this contract with someone else because it has unspendable paths.

Speaker 1: 00:22:29

That sounds really hard to to delimit like this small section of possible scripts that are actually spendable, well-formed, don't exceed any limits, are standard, and not malleable. So that's what you guys did, right?

Speaker 2: 00:22:44

And not malleable.

Non-malleability of miniscript

Speaker 2: 00:22:47

That was an important part, which I should have mentioned at the start. Yeah, miniscripts are designed to be non-malleable. Like with segregated witness, or segwit, we destroy one form of malleability, but we also have other forms of malleability. We have as in like your poorly constructed contracts could have, could be malleable in other ways. And with design, if manuscript policy, like library says that this is safe, you know that if you're satisfied using that, it would be safe, non-malleable. So where this comes into play is you could, for example, have a weird contract and change your witness so that it is still satisfied. The funds are still sent, but you increase the size of transaction and that sort of vectors would like decrease that's that is an attack vector because it decreases the fee per byte of the transaction and suddenly it's not confirmed and Then you have this right you could Maybe make a pinning transaction pinning attack that way or or just delay the confirmation of your transaction Yeah, and that affects security of off-chain protocols right because that's certainly security assumption for them and Right. It is important to have these things and that you know that these things are non-malleable and having...

Speaker 1: 00:24:10

So we covered a little ground here. We found that Miniscript is always not malleable, that it is a smaller subset of all of scripts expressiveness, which in some allows you to make more final analysis of whether you can actually spend what you're participating in and things like that. But my understanding is that you have a converter that takes a script and produces a mini script and then vice versa you can map it back. When you fed in some of the scripts that are currently used on the network, say in Lightning. What did you find out about them?

Speaker 2: 00:24:53

Yeah, so a mini script, as we said, is a subset of scripts. So current Lightning script, first of all, is not a mini script, unfortunately, because it does weird things where it looks at the first element, sees its size and determines whether that's a public key or a pre-image. And that is something which is not friendly to the Miniscript, like the type system.

Miniscript Policy

Speaker 2: 00:25:15

So with Miniscript, we have this additional tool, which we call the policy, Miniscript policy, that is designed as a way for developers to approach Miniscript, because if we look at Miniscript, It has ands and ors of like these things, but we also have this wrappers around those things, which are, which manipulate each fragment. Wrapping means, wrappers mean when you transform many script from one type to some other type, or you change some of the type properties. Each fragment is either like does something, it either puts something on top of stack or puts nothing on top of stack or evaluates the second expression. So, Miniscript has these two, broadly speaking, two type, two attributes. Like one of them are correctness attributes and one of them are non-malleability attributes and these correctness attributes like show how we want to combine or compose this mini script so many script is like also did not highlight this it's also composable which is like you have a mini script with which outputs which is for certain set and we have another mini script and you can compose using this it and and ours and so on so but you cannot like just naively compose them there are we have different ways of like composing things and just directly composing them does not work at the Miniscript level. So when we modify each fragment, we change the type of each fragment, we call those as wrappers. Wrappers are transformation from one type to other type. So we go from, as a simplest example, if we have something which pushes a non-zero element onto the stack, which is we call type B on Miniscript, and we add a verify wrapper. So if we just put up verify after it, then we'll just put nothing on stack. So it's a transformation from many script type B, which puts something on stack, to a verify wrapper, which just checks, like it just, if there is in, it aborts if the top is not zero and it will not push anything on stack. So we have all these different mini script types which hold these different invariants across. So this is bit into a technical design, but this are, these are like the mini script wrappers. So why I was getting into those is these wrappers are required to make the mini script composition work. Like you cannot just write and PK and PKB. You would have to write something like and pk and w of some, it's like a, you would, if you read the manuscript documentation, you would understand like what all these wrappers do, but it essentially help in composing these manuscript fragments.

Speaker 1: 00:27:58

So basically you're saying that there is not just an AND operator, but there's different operators depending on which types you want to combine.

Speaker 2: 00:28:08

Yes, there's different operators. And you can also change what types you want to combine using these different things. So that is somewhat tricky to understand at first. So we have this thing called manuscript policy, which is another abstraction layer out of manuscript where you remove all these wrappers, where you remove all the different types of ands and ors, and you just have simple, like the one which you want to look at and of this, this, this, and all of this, which is what you would conceptually visualize your manuscript as.

Speaker 1: 00:28:37

And so that's basically a human readable, writable thing that then later gets transformed into a manuscript.

Speaker 2: 00:28:46

Yeah.

Speaker 1: 00:28:46

And from the manuscript is, of course, exchangeable to bitcoin script.

Speaker 2: 00:28:51

Yes. So I would like to highlight that this is one, like this policy, yeah this representation is what we call the policy and we have a one way for going from Miniscript policy which we call compiling. So it's not a one-to-one mapping anymore because you're losing information when you try to lift up. So this invariant is, it's not necessary that it will hold. You can go to policy to use Miniscript and Miniscript to policy, it might not. The compiler might do different things and it might change things. But policy is like the most natural way for any developer person who is interacting with script to write something. You think about things that are like and of this, or of this. You don't necessarily think about, you never think about many script fragments. Those are like our constructions. Right.

Rediscovering HTLCs

Speaker 2: 00:29:40

So we have, so for lightning policies, we looked at like, we made a compiler, which just looks at all the different possibilities and proof forces things and we found something which was better in average satisfaction cost than what the yeah than what the lightning developers had initially yeah had initially constructed and not only that we get something which has less satisfaction rates for HTLCs. Now, this is technically, I like to highlight this, these are never meant to be broadcasted on-chain, like HTLCs should never be, but still they can be in case a spear goes offline.

Speaker 1: 00:30:14

You want to avoid it, but they're totally meant to be broadcast.

Speaker 0: 00:30:17

Yeah, they're totally meant to be broadcast.

Speaker 1: 00:30:19

Yeah, that's a good point. They're basically cached on the second layer and only when necessary are executed on-chain to decide a conflict.

Speaker 2: 00:30:31

Yes, So we found something which is cheaper to that. But not only that, that is Miniscript. So with that, you get all these bunch of cool things which we discovered. Like you could have REST Miniscript, like any wallet which can satisfy it. You could do analysis on it.

Speaker 1: 00:30:47

You could do smart fee estimation on it you could basically have a lightning signer use any existing hardware signer as a lightning signer done right you could you could use any signer you would just need a mini script finalizer to finalize all these things so yeah you could use any hardware signer or any signer which you want.

Speaker 2: 00:31:06

And you don't need to have all these like hard coded logic for, I have not looked at Lightning Core, but I would assume that they have this logic which would be like hard coded for this particular Lightning script we need to feed in. Like the first element should be this, the second element should be this, and third. And if you looked at any all the smart contracts which people have deployed, they have this hard-coded things. And this really screws up inter-operation between wallets, which is a very slick, a good point where if you have Miniscript compatible wallets, you have green two of three and something like you cannot just go to some other wallet, right?

Speaker 1: 00:31:40

So basically that brings us back to the question, who is Miniscript for? And it is, It could be used by wallet developers to ensure interoperability with hardware wallets or second layer protocols.

Speaker 2: 00:31:54

Yeah, second any wallets basically like if you're supporting many script scripts and other wallets support many script scripts then you can they can satisfy your thing you can satisfy everything. It is just the finalizer which I would like to highlight. Your signer does not need to do anything. Like it's just only the final, the part, the one which puts in the witnesses into place, that one needs to understand Miniscript. So it can just be a software thing. Nice. So you don't have to go through all the hardware wallets to see a ad mini script.

Speaker 1: 00:32:24

You found a way to better express the currently prevalent Lightning transaction types. And how did that go? Did everybody adopt that already?

Speaker 2: 00:32:36

No, no. I mean, my understanding is that in Lightning implementations you already have that deployed everywhere and to change the way in which you negotiate HTLCs and is not only like just a script problem but a network layer problem probably requires much more of an engineering effort to get it through and I think they're like with the new implementations they were discussing it on the mailing list thread about whether they can adopt many script, like many script supported, or many script descriptors, or many script scripts, and that would be really great if they adopted.

Miniscript uses

Speaker 2: 00:33:11

And so it's who should use many script. If you are a wallet, like if you're a wallet, you should make sure that you're not doing... Most of the things can be done by Miniscript. It's like hash locks, time locks, and signatures, and that is most what you use Bitcoin for. So you should have Miniscript. And for users, if you're doing any complex multi-party contract, You can just analyze your thing that you're participating is correct.

Speaker 1: 00:33:34

And so would it be fair to say that Miniscript makes the job of a wallet developer easier?

Speaker 2: 00:33:40

Yeah, it allows you more functionality, which you could just be a simple thing like I only support free to book key and just have this one thing but if you want to step anywhere more than that you yeah this would make your life much easier like you don't have to deal with fee estimate as in like you don't currently yeah you cannot estimate your with if you have any complex contract it is hard for you to know what is the maximum possible satisfaction Witness size which you can have maybe you look at this and it's a complex contract. You don't know how much Fees it how many we whites it would take you cannot guess its fees So you still have to have the fee output.

Speaker 1: 00:34:18

So when you build a transaction and it is a complex contract that has multiple ways of being executed, Miniscript allows you to directly calculate how big the transaction might end up being on the chain, which you need to know in order to estimate the fees in advance.

Speaker 2: 00:34:34

Yes, exactly.

Speaker 1: 00:34:35

And you need to pick the fees while building the transaction before signing.

Speaker 2: 00:34:38

Yes. Right.

Removing script limitations with Taproot

Speaker 2: 00:34:39

Yeah, that's one of the, one small thing which we did not highlight is all these script limitations which we discussed, they made their way into TAPscript. So although we did a bunch of work for many scripts trying to deal with all these resource things, but in BIP 342, we realized that it's like not a, these things are Satoshi-age things, which we, like many other things, don't know. The reason why, as in, they were there for denial of service reasons but now we better understand Bitcoin so you have removed those limits and those are only like block level limits now also the complex check multi sig of code which did like weird counting for 201 opcodes that has also been replaced by a much more thing, which actually checksig add friends, which would more represent the cost that actually the CPU incurs when trying to validate the transaction.

Speaker 1: 00:35:32

So Taproot removes UpCheck, MultiSig, ChecksigAdd instead and a few other of the script limitations have been thrown out in order to make scripts easier to analyze and all of that came out of your, you and your colleagues' manuscript research.

Speaker 2: 00:35:51

Yeah.

Speaker 1: 00:35:52

Cool.

Generic signing

Speaker 1: 00:35:53

What's the coolest thing in manuscript altogether, would you say?

Speaker 2: 00:35:58

So I would say like the coolest thing is like this generic signing or generic finalizing where you have your wallet, everyone has their own wallet in a fancy future, we have these different policies that everyone has. You have your own policy, you are engaging in a multi-party contract with me, I have my own policy, you have your hardware wallet somewhere else, I have my signer somewhere else and in a PSBT workflow we would just transfer this PSBT around, all the wallets would just put in their signatures at their respective places And we have this complex contract, the wallets don't even need to know what the contract is, like where is the 3 of 5 or something, they just need to know I give you this public key, this is the message you need to sign for, they would put the signature there, and you just have one final miniscript software which would create this thing. And this is really cool because previously you have all this, like, there's no interoperation between wallets. Now you have different wallets, which do not even need to understand many script and this like just a final piece together, you can.

Speaker 1: 00:37:03

So this will make it a lot easier for various different wallet software to interact and basically establish a industry standard on how to think about scripts.

Speaker 2: 00:37:17

Yeah, Miniscript is a standard, like you would, it is Bitcoin script, but it is one of the, so it's not necessary that you have to, you don't need any soft fork or any like any consensus implementation. You just have Miniscript and you just need one final software and that's cool.

Future work

Speaker 1: 00:37:34

What's the general status of Miniscript? We talked a little bit earlier about how you're still working on getting it implemented in Bitcoin Core, how there's prototypes for it, but where are we at with Miniscript right now?

Speaker 2: 00:37:48

We have, my primary role has been on the Rust implementation, like the Rust Miniscript side of things. And one of my projects there is to extend Miniscript to TabScript, like TabRoot Miniscript. Now that we don't have all these complex these weird constraints some things become easy but now we have this new upcodes so we need new terminals for expressing the checksig add friends multi and we also have a different this is still an R&D so one side is R&D for tap script where we show different tap leaf versions and Merkle we are not sure that we're still thinking about how to extend that to taproot which will make things easy And on the other side where we have segwit and support for that so just miniscript version is like almost finalized You'll see there are we are going to add new features, which would be more like how do you analyze things? But the base level miniscript design and specification is fixed like there's nothing to be changed over there and you might add more smarter compilations but for the C++ side of things I am I will be working as you say I am working so it's more correct as like I am working for the past few days I will be working towards getting Peter's his repository miniscript updated with Rust manuscript and getting some reviewer there and then transferring and that would be like a multi-step thing because we'll discuss more with the community how that goes because it has a bunch of features, as we discussed. One of them is just like script to mini script. Then we will have like, I don't know if analyzing capabilities belong in Bitcoin Core or you want different software for it. We definitely want support for generic finalizing, that would be another task and all the tests and test framework and all those things. So that's...

Speaker 1: 00:39:34

And then of course it has to map one to one to each other and be exactly, behave exactly the same way between the different implementations. So probably it has a very strong testing core set, huge amount of test cases.

Speaker 2: 00:39:46

Yes, we have tested like, I don't know million, but we have tested a lot, like all the different possible combinations of many say Peter has one more cool tool called gram trophy if it's not one of his popularly known projects when if you give it some grammar rules, it would generate different possible combinations for those. And we have tested that extensively with Miniscript.

Speaker 1: 00:40:12

Is that how you found the Better Lightning constructions?

Speaker 2: 00:40:15

So the Better Lightning construction is a compiler part. So that is when you go from a policy which you expect to do the mini script.

The role of policy

Speaker 2: 00:40:23

And this is where people get confused and I would like to highlight is one of the most common confusions in many script across developers is policy to mini script is not stable. It is something which is just designed for you to approach miniscript. You should just use policy once, get your miniscript and use that miniscript. So the C++ version would give possibly different outputs. The rest of the script would give possibly different outputs. In future, you might have new ways to compile things to a mini script. You might rearrange things. So policy is just one way to approach a mini script. You should not treat policy as your mini script. Those are different things.

Speaker 1: 00:41:04

So the actual interchangeable part is the mini script mini script policy is the human writable part that once gets compiled to mini script and then you should stay there yeah cool So the next step is to make Bitcoin Core or the Bitcoin Core compatible implementation plain as with Rust Miniscript and then hopefully to roll it out. And my understanding is that the tap script functionality is in rest mini script already.

Speaker 2: 00:41:36

No, it is. So app script functionality is in, like, it's in works, like we're still in our end, like there's no code yet. We are discussing, Because there are a bunch of things which we can do now with taproot. Like you could have a private test. Let's say you have two, one of the benefits of taproot is you only show what you're executing. If you have an OR of two things, you don't show what your second OR is. And so then we can have this as a different hidden node and just show the script to share execution which is not true for segwit so there is still some like design things to be done over there we still have a good idea of how we want to do it There's one way where you go like completely private where let's say you have your leaves all of the leaves just represent ors of different things and you only show one of them and there's a trade-off like maybe that blows up too high let's say you're doing 11 or 15 multi-sig or something then you clearly cannot have all the different ORs in the leave. That would be too much. So there is still some trade-offs and design to be figured out there, but it's...

Speaker 1: 00:42:40

So you would want to, for example, make your Miniscript compiler take into account how many leaves that would require to express a construction like that?

Speaker 2: 00:42:51

So yeah, tap script compiler is still in work but the tap script to miniscript that thing should still just that is almost done. You just have new fragments for checks multi-sig and we remove the resource limit checks and so on. So that is, that is REST Miniscript. That's not, as far as I understand, like Bitcoin Core wallet support for Taproot is still like right now under review. So I think we'll just go slowly over there with SegWit and test framework and just make developers familiar in general with Miniscript, make them comfortable so we have more informed review and go forward with that. Right.

Speaker 1: 00:43:25

That sounds all really cool. Are we still missing something? Did I forget to ask you something?

Speaker 2: 00:43:31

I think that Miniscript covers pretty much it. Miniscript is just part of descriptors like at a high level to summarize everything. Miniscript is part of descriptors which fit into all of this PSPT workflow and Miniscript would help you compose scripts, analyze them, find smart fees, generically sign for them.

Speaker 1: 00:43:49

Right. How do we keep abreast of the updates regarding Miniscript?

Speaker 2: 00:43:55

There is a pound pound Miniscript IRC channel which is fairly active. So we discussed a lot of things over there and Rust Miniscript and C++ Miniscript are the two repositories. And if you want to play around with Miniscript, Peter has this great website which is like a go-to resource for Miniscript which is bitcoin.cpa.be slash miniscript. So that is the place where you can start. And if you have any questions, approach at pound pound miniscript.

Speaker 1: 00:44:25

Those will, of course, be in the show notes then. Ha, ha, yeah. Ha, ha, yeah. I hope you liked that. We're going to probably record a few more episodes soon because more people are going to be in the office again, and we might be going to more conferences as well.

Speaker 0: 00:44:44

The Chaincode Podcast is back. Again. Full force. We've said this before, but this time is different. We mean it. All right. Thanks, Murch. Thanks for putting that together. There'll be show notes and we'll see you next time.

Speaker 1: 00:44:58

Yeah. See ya.

Transcripts

Community-maintained archive to unlocking knowledge from technical bitcoin transcripts

TranscriptsAbout

Explore all Products

ChatBTC imageBitcoin searchBitcoin TLDRSaving SatoshiBitcoin Transcripts Review
Built with 🧡 by the Bitcoin Dev Project
View our public visitor count
We'd love to hear your feedback on this project?Give Feedback