With none safety trade-off vs. working validating nodes, there is no such thing as a technique to create a wallet-service with out downloading and validating the blockchain.
If SPV node safety trade-offs are acceptable, chances are you’ll contemplate working the pockets service with these.
SPV nodes don’t fully-validate the blockchain, and solely obtain the longest header-chain. Nevertheless, since they solely validate POW within the header-chain, and don’t index all transactions (solely these associated to the pockets service addresses), they should acquire a proof {that a} tx of curiosity is confirmed through. one other full-node peer. This proof might be delivered a merkle-proof, which represents a particular department of the merlke-tree starting with the txid of curiosity, of which the foundation is dedicated to every block header.
The safety trade-off for SPV nodes is two-fold:
- Privateness: Because the pockets service is focused on tx’s pertaining to particular addresses, some details about addresses will essentially leak to the queried full-nodes.
- Potential for omission: Friends can all the time stay silent about particular confirmed transactions with out the SPV consumer having the ability to show this, doubtlessly requiring cross-comparison heuristic throughout validating friends.
- A SPV consumer doesn’t validate any consensus guidelines, thereby not understanding whether or not the chain/department it’s following appropriately validates in accordance with the validation rule set the consumer helps.