Mike Hearn [ARCHIVE] on Nostr: 📅 Original date posted:2012-07-21 📝 Original message:One thing that occurred to ...
📅 Original date posted:2012-07-21
📝 Original message:One thing that occurred to me recently is that it'd be useful if
filters could contain exact matches as well as Bloom filters.
Specifically I'm thinking of things like my bond network proposal
where some outputs may be marked as special using script fragments
like "BOND" <data or hash of data> 2DROP.
This would allow systems that are only interested in data and
transactions relevant to bonds to exact-filter the chain on that
marker, and then when a transaction is discovered, add the hash of
that transaction to a parallel Bloom filter, ensuring you can see any
transactions that connect to it.
The spec as provided by Jeff doesn't specify how filters are matched
against transactions. I propose the following algorithm:
For each TX:
- Check if the hash of the tx itself matches the filter
- For each input:
- For each script data element check if it is found in the filter
- Check if the COutPoint.hash value is in the filter (let's you
select txns that connect to arbitrary txns of interest)
- For each output
- For each script data element check if it is found in the filter
Published at
2023-06-07 10:23:40Event JSON
{
"id": "5c3dfbc2c0e85e5de3982f03c783b134d7222dc661a68f05f07a4311a1438461",
"pubkey": "f2c95df3766562e3b96b79a0254881c59e8639f23987846961cf55412a77f6f2",
"created_at": 1686133420,
"kind": 1,
"tags": [
[
"e",
"23ee79838ca93d0a58849ea33f725a52fc63e55e8c77c38083086666621775b1",
"",
"reply"
],
[
"p",
"a23dbf6c6cc83e14cc3df4e56cc71845f611908084cfe620e83e40c06ccdd3d0"
]
],
"content": "📅 Original date posted:2012-07-21\n📝 Original message:One thing that occurred to me recently is that it'd be useful if\nfilters could contain exact matches as well as Bloom filters.\n\nSpecifically I'm thinking of things like my bond network proposal\nwhere some outputs may be marked as special using script fragments\nlike \"BOND\" \u003cdata or hash of data\u003e 2DROP.\n\nThis would allow systems that are only interested in data and\ntransactions relevant to bonds to exact-filter the chain on that\nmarker, and then when a transaction is discovered, add the hash of\nthat transaction to a parallel Bloom filter, ensuring you can see any\ntransactions that connect to it.\n\nThe spec as provided by Jeff doesn't specify how filters are matched\nagainst transactions. I propose the following algorithm:\n\nFor each TX:\n- Check if the hash of the tx itself matches the filter\n- For each input:\n - For each script data element check if it is found in the filter\n - Check if the COutPoint.hash value is in the filter (let's you\nselect txns that connect to arbitrary txns of interest)\n- For each output\n - For each script data element check if it is found in the filter",
"sig": "625c63b326a7bf4708da901114aca53e18d685b1397dc19676347da24c6e2c6311b64bc32c78949e0573133ecd921cfc41459e075c9bafeadad92f61e94d90a4"
}