2013-05-29 02:07:21 +02:00
|
|
|
// Copyright (c) 2013 Conformal Systems LLC.
|
|
|
|
// Use of this source code is governed by an ISC
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
/*
|
2013-06-01 00:09:26 +02:00
|
|
|
Package btcdb provides a database interface for the Bitcoin block chain.
|
2013-05-29 02:07:21 +02:00
|
|
|
|
2013-06-01 00:09:26 +02:00
|
|
|
As of May 2013, there are over 235,000 blocks in the Bitcoin block chain and
|
|
|
|
and over 17 million transactions (which turns out to be over 11GB of data).
|
2013-05-29 02:07:21 +02:00
|
|
|
btcdb provides a database layer to store and retrieve this data in a fairly
|
|
|
|
simple and efficient manner. The use of this should not require specific
|
|
|
|
knowledge of the database backend used although currently only db_sqlite is
|
|
|
|
provided.
|
|
|
|
|
|
|
|
Basic Design
|
|
|
|
|
|
|
|
The basic design of btcdb is to provide two classes of items in a
|
|
|
|
database; blocks and transactions (tx) where the block number
|
|
|
|
increases monotonically. Each transaction belongs to a single block
|
|
|
|
although a block can have a variable number of transactions. Along
|
|
|
|
with these two items, several convenience functions for dealing with
|
|
|
|
the database are provided as well as functions to query specific items
|
|
|
|
that may be present in a block or tx (although many of these are in
|
2013-07-25 23:44:18 +02:00
|
|
|
the sqlite3 subpackage).
|
2013-05-29 02:07:21 +02:00
|
|
|
|
|
|
|
Usage
|
|
|
|
|
|
|
|
At the highest level, the use of this packages just requires that you
|
|
|
|
import it, setup a database, insert some data into it, and optionally,
|
2013-07-25 23:44:18 +02:00
|
|
|
query the data back. The first block inserted into the database will be
|
|
|
|
treated as the genesis block. Every subsequent block insert requires the
|
|
|
|
referenced parent block to already exist. In a more concrete example:
|
|
|
|
|
|
|
|
// Import packages.
|
|
|
|
import (
|
|
|
|
"github.com/conformal/btcdb"
|
|
|
|
_ "github.com/conformal/btcdb/sqlite3"
|
|
|
|
"github.com/conformal/btcutil"
|
|
|
|
"github.com/conformal/btcwire"
|
|
|
|
)
|
2013-05-29 02:07:21 +02:00
|
|
|
|
2013-05-31 20:50:23 +02:00
|
|
|
// Create a database and schedule it to be closed on exit.
|
2013-07-25 23:44:18 +02:00
|
|
|
dbName := "example.db"
|
|
|
|
db, err := btcdb.CreateDB("sqlite", dbName)
|
2013-05-29 02:07:21 +02:00
|
|
|
if err != nil {
|
2013-05-31 20:50:23 +02:00
|
|
|
// Log and handle the error
|
2013-05-29 02:07:21 +02:00
|
|
|
}
|
2013-05-31 20:50:23 +02:00
|
|
|
defer db.Close()
|
2013-05-29 02:07:21 +02:00
|
|
|
|
2013-07-25 23:44:18 +02:00
|
|
|
|
|
|
|
// Insert the main network genesis block.
|
|
|
|
pver := btcwire.ProtocolVersion
|
|
|
|
genesis := btcutil.NewBlock(&btcwire.GenesisBlock, pver)
|
|
|
|
newHeight, err := db.InsertBlock(block)
|
2013-05-29 02:07:21 +02:00
|
|
|
if err != nil {
|
2013-05-31 20:50:23 +02:00
|
|
|
// Log and handle the error
|
2013-05-29 02:07:21 +02:00
|
|
|
}
|
|
|
|
*/
|
|
|
|
package btcdb
|