本文整理汇总了Golang中github.com/FactomProject/FactomCode/common.Hash类的典型用法代码示例。如果您正苦于以下问题:Golang Hash类的具体用法?Golang Hash怎么用?Golang Hash使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了Hash类的20个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Golang代码示例。
示例1: sanityCheck
func sanityCheck(hash *common.Hash) (*common.DirBlockInfo, error) {
dirBlockInfo := dirBlockInfoMap[hash.String()]
if dirBlockInfo == nil {
s := fmt.Sprintf("Anchor Error: hash %s does not exist in dirBlockInfoMap.\n", hash.String())
anchorLog.Error(s)
return nil, errors.New(s)
}
if dirBlockInfo.BTCConfirmed {
s := fmt.Sprintf("Anchor Warning: hash %s has already been confirmed in btc block chain.\n", hash.String())
anchorLog.Error(s)
return nil, errors.New(s)
}
//The re-anchoring is allowed now.
//if !common.NewHash().IsSameAs(dirBlockInfo.BTCTxHash) {
//s := fmt.Sprintf("Anchor Warning: hash %s has already been anchored but not confirmed. btc tx hash is %s\n", hash.String(), dirBlockInfo.BTCTxHash.String())
//anchorLog.Error(s)
//return nil, errors.New(s)
//}
if dclient == nil || wclient == nil {
s := fmt.Sprintf("\n\n$$$ WARNING: rpc clients and/or wallet are not initiated successfully. No anchoring for now.\n")
anchorLog.Warning(s)
return nil, errors.New(s)
}
if len(balances) == 0 {
anchorLog.Warning("len(balances) == 0, start rescan UTXO *** ")
updateUTXO()
}
if len(balances) == 0 {
s := fmt.Sprintf("\n\n$$$ WARNING: No balance in your wallet. No anchoring for now.\n")
anchorLog.Warning(s)
return nil, errors.New(s)
}
return dirBlockInfo, nil
}
开发者ID:FactomProject,项目名称:FactomCode,代码行数:34,代码来源:anchor.go
示例2: HaveBlockInDB
// HaveBlockInDB returns whether or not the chain instance has the block represented
// by the passed hash. This includes checking the various places a block can
// be like part of the main chain, on a side chain, or in the orphan pool.
//
// This function is NOT safe for concurrent access.
func HaveBlockInDB(hash *common.Hash) (bool, error) {
//util.Trace(spew.Sdump(hash))
blk, _ := db.FetchDBlockByHash(hash)
if blk != nil {
fmt.Println("HaveBlockInDB. true. ", hash.BTCString())
return true, nil
}
return false, nil
/*
if hash == nil || dchain.Blocks == nil || len(dchain.Blocks) == 0 {
return false, nil
}
// double check the block ids
for i := 0; i < len(dchain.Blocks); i = i + 1 {
if dchain.Blocks[i] == nil {
continue
}
if dchain.Blocks[i].DBHash == nil {
dchain.Blocks[i].DBHash, _ = common.CreateHash(dchain.Blocks[i])
}
if dchain.Blocks[i].DBHash.IsSameAs(hash) {
return true, nil
}
}
return false, nil */
}
开发者ID:FactomProject,项目名称:FactomCode,代码行数:34,代码来源:util.go
示例3: SendRawTransactionToBTC
// SendRawTransactionToBTC is the main function used to anchor factom
// dir block hash to bitcoin blockchain
func SendRawTransactionToBTC(hash *common.Hash, blockHeight uint32) (*wire.ShaHash, error) {
anchorLog.Debug("SendRawTransactionToBTC: hash=", hash.String(), ", dir block height=", blockHeight) //strconv.FormatUint(blockHeight, 10))
dirBlockInfo, err := sanityCheck(hash)
if err != nil {
return nil, err
}
return doTransaction(hash, blockHeight, dirBlockInfo)
}
开发者ID:FactomProject,项目名称:FactomCode,代码行数:10,代码来源:anchor.go
示例4: UpdateBlockHeightCache
// UpdateBlockHeightCache updates the dir block height cache in db
func (db *LevelDb) UpdateBlockHeightCache(dirBlkHeigh uint32, dirBlkHash *common.Hash) error {
// Update DirBlock Height cache
db.lastDirBlkHeight = int64(dirBlkHeigh)
db.lastDirBlkSha, _ = wire.NewShaHash(dirBlkHash.Bytes())
db.lastDirBlkShaCached = true
return nil
}
开发者ID:6londe,项目名称:FactomCode,代码行数:9,代码来源:dblock.go
示例5: validateABlockByMR
// Validate Admin Block by merkle root
func validateABlockByMR(mr *common.Hash) error {
b, _ := db.FetchABlockByHash(mr)
if b == nil {
return errors.New("Admin block not found in db for merkle root: " + mr.String())
}
return nil
}
开发者ID:FactomProject,项目名称:FactomCode,代码行数:10,代码来源:init.go
示例6: validateCBlockByMR
// Validate Entry Credit Block by merkle root
func validateCBlockByMR(mr *common.Hash) error {
cb, _ := db.FetchECBlockByHash(mr)
if cb == nil {
return errors.New("Entry Credit block not found in db for merkle root: " + mr.String())
}
return nil
}
开发者ID:FactomProject,项目名称:FactomCode,代码行数:10,代码来源:init.go
示例7: FetchEntryByHash
// FetchEntry gets an entry by hash from the database.
func (db *LevelDb) FetchEntryByHash(entrySha *common.Hash) (entry *common.Entry, err error) {
var key []byte = []byte{byte(TBL_ENTRY)}
key = append(key, entrySha.Bytes()...)
db.dbLock.RLock()
data, err := db.lDb.Get(key, db.ro)
db.dbLock.RUnlock()
if data != nil {
entry = new(common.Entry)
_, err := entry.UnmarshalBinaryData(data)
if err != nil {
return nil, err
}
}
return entry, nil
}
开发者ID:FactomProject,项目名称:FactomCode,代码行数:17,代码来源:entry.go
示例8: FetchECBlockByHash
// FetchECBlockByHash gets an Entry Credit block by hash from the database.
func (db *LevelDb) FetchECBlockByHash(ecBlockHash *common.Hash) (ecBlock *common.ECBlock, err error) {
db.dbLock.Lock()
defer db.dbLock.Unlock()
var key []byte = []byte{byte(TBL_CB)}
key = append(key, ecBlockHash.Bytes()...)
data, err := db.lDb.Get(key, db.ro)
if data != nil {
ecBlock = common.NewECBlock()
_, err := ecBlock.UnmarshalBinaryData(data)
if err != nil {
return nil, err
}
}
return ecBlock, nil
}
开发者ID:6londe,项目名称:FactomCode,代码行数:18,代码来源:ecblock.go
示例9: FetchFBlockByHash
// FetchFBlockByHash gets an factoid block by hash from the database.
func (db *LevelDb) FetchFBlockByHash(hash *common.Hash) (FBlock block.IFBlock, err error) {
db.dbLock.Lock()
defer db.dbLock.Unlock()
var key []byte = []byte{byte(TBL_SC)}
key = append(key, hash.Bytes()...)
data, err := db.lDb.Get(key, db.ro)
if data != nil {
FBlock = new(block.FBlock)
_, err := FBlock.UnmarshalBinaryData(data)
if err != nil {
return nil, err
}
}
return FBlock, nil
}
开发者ID:brianharness,项目名称:FactomCode,代码行数:18,代码来源:scblock.go
示例10: FetchABlockByHash
// FetchABlockByHash gets an admin block by hash from the database.
func (db *LevelDb) FetchABlockByHash(aBlockHash *common.Hash) (aBlock *common.AdminBlock, err error) {
var key = []byte{byte(TBL_AB)}
key = append(key, aBlockHash.Bytes()...)
var data []byte
db.dbLock.RLock()
data, err = db.lDb.Get(key, db.ro)
db.dbLock.RUnlock()
if data != nil {
aBlock = new(common.AdminBlock)
_, err := aBlock.UnmarshalBinaryData(data)
if err != nil {
return nil, err
}
}
return aBlock, nil
}
开发者ID:FactomProject,项目名称:FactomCode,代码行数:18,代码来源:ablock.go
示例11: FetchDirBlockInfoByHash
// FetchDirBlockInfoByHash gets an DirBlockInfo obj
func (db *LevelDb) FetchDirBlockInfoByHash(dbHash *common.Hash) (dirBlockInfo *common.DirBlockInfo, err error) {
db.dbLock.Lock()
defer db.dbLock.Unlock()
var key []byte = []byte{byte(TBL_DB_INFO)}
key = append(key, dbHash.Bytes()...)
data, err := db.lDb.Get(key, db.ro)
if data != nil {
dirBlockInfo = new(common.DirBlockInfo)
_, err := dirBlockInfo.UnmarshalBinaryData(data)
if err != nil {
return nil, err
}
}
return dirBlockInfo, nil
}
开发者ID:6londe,项目名称:FactomCode,代码行数:19,代码来源:dblock.go
示例12: FetchEBHashByMR
// FetchEBHashByMR gets an entry by hash from the database.
func (db *LevelDb) FetchEBHashByMR(eBMR *common.Hash) (*common.Hash, error) {
var key []byte = []byte{byte(TBL_EB_MR)}
key = append(key, eBMR.Bytes()...)
db.dbLock.RLock()
data, err := db.lDb.Get(key, db.ro)
db.dbLock.RUnlock()
if err != nil {
return nil, err
}
eBlockHash := common.NewHash()
_, err = eBlockHash.UnmarshalBinaryData(data)
if err != nil {
return nil, err
}
return eBlockHash, nil
}
开发者ID:FactomProject,项目名称:FactomCode,代码行数:19,代码来源:eblock.go
示例13: FetchDBHashByMR
// FetchDBHashByMR gets a DBHash by MR from the database.
func (db *LevelDb) FetchDBHashByMR(dBMR *common.Hash) (*common.Hash, error) {
db.dbLock.Lock()
defer db.dbLock.Unlock()
var key []byte = []byte{byte(TBL_DB_MR)}
key = append(key, dBMR.Bytes()...)
data, err := db.lDb.Get(key, db.ro)
if err != nil {
return nil, err
}
dBlockHash := common.NewHash()
_, err = dBlockHash.UnmarshalBinaryData(data)
if err != nil {
return nil, err
}
return dBlockHash, nil
}
开发者ID:6londe,项目名称:FactomCode,代码行数:20,代码来源:dblock.go
示例14: FetchEBlockByHash
// FetchEntryBlock gets an entry by hash from the database.
func (db *LevelDb) FetchEBlockByHash(eBlockHash *common.Hash) (*common.EBlock, error) {
var key []byte = []byte{byte(TBL_EB)}
key = append(key, eBlockHash.Bytes()...)
db.dbLock.RLock()
data, err := db.lDb.Get(key, db.ro)
db.dbLock.RUnlock()
if err != nil {
return nil, err
}
eBlock := common.NewEBlock()
if data != nil {
_, err := eBlock.UnmarshalBinaryData(data)
if err != nil {
return nil, err
}
}
return eBlock, nil
}
开发者ID:FactomProject,项目名称:FactomCode,代码行数:20,代码来源:eblock.go
示例15: FetchDBlockByHash
// FetchDBlockByHash gets an entry by hash from the database.
func (db *LevelDb) FetchDBlockByHash(dBlockHash *common.Hash) (*common.DirectoryBlock, error) {
var key = []byte{byte(TBL_DB)}
key = append(key, dBlockHash.Bytes()...)
db.dbLock.RLock()
data, _ := db.lDb.Get(key, db.ro)
db.dbLock.RUnlock()
dBlock := common.NewDBlock()
if data == nil {
return nil, errors.New("DBlock not found for Hash: " + dBlockHash.String())
}
_, err := dBlock.UnmarshalBinaryData(data)
if err != nil {
return nil, err
}
dBlock.DBHash = dBlockHash
return dBlock, nil
}
开发者ID:FactomProject,项目名称:FactomCode,代码行数:20,代码来源:dblock.go
示例16: FetchChainByHash
// FetchChainByHash gets a chain by chainID
func (db *LevelDb) FetchChainByHash(chainID *common.Hash) (*common.EChain, error) {
var key []byte = []byte{byte(TBL_CHAIN_HASH)}
key = append(key, chainID.Bytes()...)
db.dbLock.RLock()
data, err := db.lDb.Get(key, db.ro)
db.dbLock.RUnlock()
if err != nil {
return nil, err
}
chain := common.NewEChain()
if data != nil {
_, err := chain.UnmarshalBinaryData(data)
if err != nil {
return nil, err
}
}
return chain, nil
}
开发者ID:FactomProject,项目名称:FactomCode,代码行数:20,代码来源:eblock.go
示例17: doTransaction
func doTransaction(hash *common.Hash, blockHeight uint64, dirBlockInfo *common.DirBlockInfo) (*wire.ShaHash, error) {
b := balances[0]
i := copy(balances, balances[1:])
balances[i] = b
msgtx, err := createRawTransaction(b, hash.Bytes(), blockHeight)
if err != nil {
return nil, fmt.Errorf("cannot create Raw Transaction: %s", err)
}
shaHash, err := sendRawTransaction(msgtx)
if err != nil {
return nil, fmt.Errorf("cannot send Raw Transaction: %s", err)
}
// for test purpose
if dirBlockInfo != nil {
dirBlockInfo.BTCTxHash = toHash(shaHash)
}
return shaHash, nil
}
开发者ID:jakeporter,项目名称:FactomCode,代码行数:20,代码来源:anchor.go
示例18: doTransaction
func doTransaction(hash *common.Hash, blockHeight uint32, dirBlockInfo *common.DirBlockInfo) (*wire.ShaHash, error) {
b := balances[0]
balances = balances[1:]
anchorLog.Info("new balances.len=", len(balances))
msgtx, err := createRawTransaction(b, hash.Bytes(), blockHeight)
if err != nil {
return nil, fmt.Errorf("cannot create Raw Transaction: %s", err)
}
shaHash, err := sendRawTransaction(msgtx)
if err != nil {
return nil, fmt.Errorf("cannot send Raw Transaction: %s", err)
}
if dirBlockInfo != nil {
dirBlockInfo.BTCTxHash = toHash(shaHash)
}
return shaHash, nil
}
开发者ID:FactomProject,项目名称:FactomCode,代码行数:21,代码来源:anchor.go
示例19: FetchAllEBlocksByChain
// FetchAllEBlocksByChain gets all of the blocks by chain id
func (db *LevelDb) FetchAllEBlocksByChain(chainID *common.Hash) (eBlocks *[]common.EBlock, err error) {
db.dbLock.RLock()
defer db.dbLock.RUnlock()
var fromkey []byte = []byte{byte(TBL_EB_CHAIN_NUM)} // Table Name (1 bytes)
fromkey = append(fromkey, chainID.Bytes()...) // Chain Type (32 bytes)
var tokey []byte = addOneToByteArray(fromkey)
eBlockSlice := make([]common.EBlock, 0, 10)
iter := db.lDb.NewIterator(&util.Range{Start: fromkey, Limit: tokey}, db.ro)
for iter.Next() {
eBlockHash := common.NewHash()
_, err := eBlockHash.UnmarshalBinaryData(iter.Value())
if err != nil {
return nil, err
}
var key []byte = []byte{byte(TBL_EB)}
key = append(key, eBlockHash.Bytes()...)
data, err := db.lDb.Get(key, db.ro)
if err != nil {
return nil, err
}
eBlock := common.NewEBlock()
if data != nil {
_, err := eBlock.UnmarshalBinaryData(data)
if err != nil {
return nil, err
}
eBlockSlice = append(eBlockSlice, *eBlock)
}
}
iter.Release()
err = iter.Error()
return &eBlockSlice, nil
}
开发者ID:FactomProject,项目名称:FactomCode,代码行数:41,代码来源:eblock.go
示例20: validateEBlockByMR
// Validate Entry Block by merkle root
func validateEBlockByMR(cid *common.Hash, mr *common.Hash) error {
eb, err := db.FetchEBlockByMR(mr)
if err != nil {
return err
}
if eb == nil {
return errors.New("Entry block not found in db for merkle root: " + mr.String())
}
keyMR, err := eb.KeyMR()
if err != nil {
return err
}
if !mr.IsSameAs(keyMR) {
return errors.New("Entry block's merkle root does not match with: " + mr.String())
}
for _, ebEntry := range eb.Body.EBEntries {
if !bytes.Equal(ebEntry.Bytes()[:31], common.ZERO_HASH[:31]) {
entry, _ := db.FetchEntryByHash(ebEntry)
if entry == nil {
return errors.New("Entry not found in db for entry hash: " + ebEntry.String())
}
} // Else ... we could do a bit more validation of the minute markers.
}
return nil
}
开发者ID:FactomProject,项目名称:FactomCode,代码行数:30,代码来源:init.go
注:本文中的github.com/FactomProject/FactomCode/common.Hash类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。 |
请发表评论