class BlkReader extends Reader (View source)

BLK File reader class.

Properties

protected $items from  BaseCollection
protected TKey> $keys

The keys in this collection.

from  BaseCollection
protected int $position

The current position of the iterator.

from  BaseCollection
protected callable|null $offsetGetFormatter

A custom function to format the items in the list.

from  Reader
protected string $blkFolder

The full path to the folder that contains the bitcoin blk files.

protected string $magicBytes

The magic bytes that indicate a block start.

Methods

__construct(string $blkFolder, bool $loadFiles = false)

Initialize a new instance of the bitcoin blk reader class.

mixed
jsonSerialize()

No description

from  Reader
all()

No description

add(TValue $item, TKey $key = null)

Add an item.

TValue|null
get(TKey $key)

Get an item by {@param $key}.

bool
isEmpty()

Check if the collection is empty.

int
count()

Count the number of items.

bool
offsetExists(TKey $key)

Check if an offset($key) exists.

mixed
offsetGet(TKey $key)

Get the item at offset($key).

from  Reader
void
offsetSet(TKey|null $key, TValue $value)

Set/Add an item.

void
offsetUnset(TKey $key)

Unset an item from the list.

TValue
current()

Get the current element.

TKey
key()

Get the key of the current element.

void
next()

Move forward to next element.

void
rewind()

Rewind the iterator to the first element.

bool
valid()

Checks if current iterator position is valid.

loadData()

Loads the available blk files.

setOffsetGetFormatter(callable $callable)

Set the item output formatter.

from  Reader
moveTo(int $offset)

Move to {@param $offset}.

from  Reader
blocks()

Gets the blocks from the current blk file.

void
setMagicBytes(string $magicBytes)

Set the magic bytes that indicates a block start.

string|null
fileName()

Gets the file name of the file that we are currently reading from.

Details

__construct(string $blkFolder, bool $loadFiles = false)

Initialize a new instance of the bitcoin blk reader class.

If the intention is to read all or most of the blk files set $loadFiles to true.

Parameters

string $blkFolder

Path to the blk files.

bool $loadFiles

Indicates if the blk files should be loaded doing the construction of the class.

Exceptions

RuntimeException

mixed jsonSerialize()

No description

Return Value

mixed

all()

No description

BaseCollection add(TValue $item, TKey $key = null)

Add an item.

Parameters

TValue $item
TKey $key

Return Value

BaseCollection

TValue|null get(TKey $key)

Get an item by {@param $key}.

Parameters

TKey $key

Return Value

TValue|null

bool isEmpty()

Check if the collection is empty.

Return Value

bool

int count()

Count the number of items.

Return Value

int

bool offsetExists(TKey $key)

Check if an offset($key) exists.

Parameters

TKey $key

Return Value

bool

mixed offsetGet(TKey $key)

Get the item at offset($key).

Parameters

TKey $key

Return Value

mixed

void offsetSet(TKey|null $key, TValue $value)

Set/Add an item.

Parameters

TKey|null $key
TValue $value

Return Value

void

void offsetUnset(TKey $key)

Unset an item from the list.

Parameters

TKey $key

Return Value

void

TValue current()

Get the current element.

Return Value

TValue

TKey key()

Get the key of the current element.

Return Value

TKey

void next()

Move forward to next element.

Return Value

void

void rewind()

Rewind the iterator to the first element.

Return Value

void

bool valid()

Checks if current iterator position is valid.

Return Value

bool

Reader loadData()

Loads the available blk files.

Return Value

Reader

Reader setOffsetGetFormatter(callable $callable)

Set the item output formatter.

$filesPath = "/home/nisse/storeage";

$readerObj = new CustomReader();

$readerObj->setOffsetGetFormatter(function($item) use ($filesPath){
    return $filesPath.DIRECTORY_SEPARATOR.$item;
});

$readerObj->offsetSet(0, 'file0.txt');

$file0 = $readerObj->current();
// echo $file0; // == /home/nisse/storeage/file0.txt

Parameters

callable $callable

Return Value

Reader

Reader moveTo(int $offset)

Move to {@param $offset}.

Parameters

int $offset

Return Value

Reader

Generator blocks()

Gets the blocks from the current blk file.


use Cjpg\Bitcoin\Blk\Readers\BlkReader;

$blkReader = new BlkReader('/raid10/bitcoin/blocks', true);

foreach($blkReader as $reader) {

    // $reader instance of BlkReader
    foreach($blkFile->blocks() as $idx => $block) {

        // $idx is the block number in the blk file.
        // INDEX STARTS FROM 0!
        // The first blk file 00000.dat contains 119995 blocks.

        // $block is an instance of \Cjpg\Bitcoin\Blk\BlockParser
        $block;
    }
}

Return Value

Generator

Exceptions

RuntimeException

void setMagicBytes(string $magicBytes)

Set the magic bytes that indicates a block start.

Note that this must be bytes not a hexadecimal string!

eg. for main net (default) "\xf9\xbe\xb4\xd9".

Known magic values:
Network Magic value setMagicBytes(...)
main 0xD9B4BEF9 "\xf9\xbe\xb4\xd9"
testnet/regtest 0xDAB5BFFA "\xFA\xBF\xB5\xDA"
testnet3 0x0709110B "\x0B\x11\x09\x07"
signet 0x40CF030A "\x0A\x03\xCF\x40"

Parameters

string $magicBytes

Return Value

void

string|null fileName()

Gets the file name of the file that we are currently reading from.

Return Value

string|null

Filename without path