Skip to content

Instantly share code, notes, and snippets.

@pool2win
pool2win / miniscript-as-lisp-demo.rkt
Created August 25, 2023 08:04
Demo lisp for bitcoin miniscrpit
#lang racket
;; define place holder functions for demo
(define (pk key) (eq? key #t))
(define (older num) (> num 1000))
(define (hash160 val) (val))
(let ([key_revocation 'abc]
[key_local 'def]
[key_remote 'xyz]
Each bead commits to:
| Bitcoin Block header | Slots Merkle Root |
| Coinbase | timestamp | nonce | TX Merkle Root | prev block |
Where the block header is a standard bitcoin block header as expanded in the second line
and each bead commits to <Slots Merkle Root> which should be added to the <metadata>
field as described in:
https://github.com/mcelrath/braidcoin/blob/master/braidpool_spec.md
The Slots data structure is a key-value table containing:
@pool2win
pool2win / braidpool_uhpo_payout_mechanism.adoc
Last active April 30, 2024 17:19
Braidpool - UHPO Payout Mechanism

Braidpool Payout

@pool2win
pool2win / Silent_Payments.md
Created May 1, 2024 06:08 — forked from RubenSomsen/Silent_Payments.md
Silent Payments – Receive private payments from anyone on a single static address without requiring any interaction or extra on-chain overhead

Silent Payments

Receive private payments from anyone on a single static address without requiring any interaction or extra on-chain overhead.

Update: This now has a BIP and WIP implementation

Overview

The recipient generates a so-called silent payment address and makes it publicly known. The sender then takes a public key from one of their chosen inputs for the payment, and uses it to derive a shared secret that is then used to tweak the silent payment address. The recipient detects the payment by scanning every transaction in the blockchain.

use tokio::sync::{mpsc, oneshot};
use tokio::time;
struct MyActor {
receiver: mpsc::Receiver<ActorMessage>,
next_id: u32,
subscribers: Vec<ClientActorHandle>,
reader: mpsc::Receiver<u32>,
}
enum ActorMessage {