2014-07-08 08:45:37 -05:00
|
|
|
// Copyright (c) 2013-2014 Conformal Systems LLC.
|
|
|
|
// Use of this source code is governed by an ISC
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
2015-01-27 11:45:10 -06:00
|
|
|
package database_test
|
2014-07-08 08:45:37 -05:00
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2014-12-22 20:05:11 -06:00
|
|
|
|
2015-01-27 11:45:10 -06:00
|
|
|
"github.com/btcsuite/btcd/database"
|
|
|
|
_ "github.com/btcsuite/btcd/database/memdb"
|
2015-01-16 17:27:16 -06:00
|
|
|
"github.com/btcsuite/btcnet"
|
2015-01-15 10:33:06 -06:00
|
|
|
"github.com/btcsuite/btcutil"
|
2014-07-08 08:45:37 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
// This example demonstrates creating a new database and inserting the genesis
|
|
|
|
// block into it.
|
|
|
|
func ExampleCreateDB() {
|
2014-07-08 08:50:12 -05:00
|
|
|
// Notice in these example imports that the memdb driver is loaded.
|
|
|
|
// Ordinarily this would be whatever driver(s) your application
|
|
|
|
// requires.
|
|
|
|
// import (
|
2015-01-27 11:45:10 -06:00
|
|
|
// "github.com/btcsuite/btcd/database"
|
|
|
|
// _ "github.com/btcsuite/btcd/database/memdb"
|
2014-07-08 08:50:12 -05:00
|
|
|
// )
|
|
|
|
|
2014-07-08 08:45:37 -05:00
|
|
|
// Create a database and schedule it to be closed on exit. This example
|
|
|
|
// uses a memory-only database to avoid needing to write anything to
|
|
|
|
// the disk. Typically, you would specify a persistent database driver
|
|
|
|
// such as "leveldb" and give it a database name as the second
|
|
|
|
// parameter.
|
2015-01-27 11:45:10 -06:00
|
|
|
db, err := database.CreateDB("memdb")
|
2014-07-08 08:45:37 -05:00
|
|
|
if err != nil {
|
|
|
|
fmt.Println(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
defer db.Close()
|
|
|
|
|
|
|
|
// Insert the main network genesis block.
|
|
|
|
genesis := btcutil.NewBlock(btcnet.MainNetParams.GenesisBlock)
|
|
|
|
newHeight, err := db.InsertBlock(genesis)
|
|
|
|
if err != nil {
|
|
|
|
fmt.Println(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
fmt.Println("New height:", newHeight)
|
|
|
|
|
|
|
|
// Output:
|
|
|
|
// New height: 0
|
|
|
|
}
|
2014-07-08 09:10:14 -05:00
|
|
|
|
2014-07-08 09:25:47 -05:00
|
|
|
// exampleLoadDB is used in the example to elide the setup code.
|
2015-01-27 11:45:10 -06:00
|
|
|
func exampleLoadDB() (database.Db, error) {
|
|
|
|
db, err := database.CreateDB("memdb")
|
2014-07-08 09:10:14 -05:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Insert the main network genesis block.
|
|
|
|
genesis := btcutil.NewBlock(btcnet.MainNetParams.GenesisBlock)
|
|
|
|
_, err = db.InsertBlock(genesis)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return db, err
|
|
|
|
}
|
|
|
|
|
|
|
|
// This example demonstrates querying the database for the most recent best
|
|
|
|
// block height and hash.
|
2014-07-08 10:04:03 -05:00
|
|
|
func ExampleDb_newestSha() {
|
2014-07-08 09:10:14 -05:00
|
|
|
// Load a database for the purposes of this example and schedule it to
|
|
|
|
// be closed on exit. See the CreateDB example for more details on what
|
|
|
|
// this step is doing.
|
2014-07-08 09:25:47 -05:00
|
|
|
db, err := exampleLoadDB()
|
2014-07-08 09:10:14 -05:00
|
|
|
if err != nil {
|
|
|
|
fmt.Println(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
defer db.Close()
|
|
|
|
|
|
|
|
latestHash, latestHeight, err := db.NewestSha()
|
|
|
|
if err != nil {
|
|
|
|
fmt.Println(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
fmt.Println("Latest hash:", latestHash)
|
|
|
|
fmt.Println("Latest height:", latestHeight)
|
|
|
|
|
|
|
|
// Output:
|
|
|
|
// Latest hash: 000000000019d6689c085ae165831e934ff763ae46a2a6c172b3f1b60a8ce26f
|
|
|
|
// Latest height: 0
|
|
|
|
}
|