Documentation ¶
Overview ¶
ZooBC Copyright (C) 2020 Quasisoft Limited - Hong Kong This file is part of ZooBC <https://github.com/zoobc/zoobc-core>
ZooBC is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
ZooBC is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with ZooBC. If not, see <http://www.gnu.org/licenses/>.
Additional Permission Under GNU GPL Version 3 section 7. As the special exception permitted under Section 7b, c and e, in respect with the Author’s copyright, please refer to this section:
- You are free to convey this Program according to GNU GPL Version 3, as long as you respect and comply with the Author’s copyright by showing in its user interface an Appropriate Notice that the derivate program and its source code are “powered by ZooBC”. This is an acknowledgement for the copyright holder, ZooBC, as the implementation of appreciation of the exclusive right of the creator and to avoid any circumvention on the rights under trademark law for use of some trade names, trademarks, or service marks.
- Complying to the GNU GPL Version 3, you may distribute the program without any permission from the Author. However a prior notification to the authors will be appreciated.
ZooBC is architected by Roberto Capodieci & Barton Johnston
contact us at roberto.capodieci[at]blockchainzoo.com and barton.johnston[at]blockchainzoo.com
Core developers that contributed to the current implementation of the software are:
Ahmad Ali Abdilah ahmad.abdilah[at]blockchainzoo.com Allan Bintoro allan.bintoro[at]blockchainzoo.com Andy Herman Gede Sukra Ketut Ariasa Nawi Kartini nawi.kartini[at]blockchainzoo.com Stefano Galassi stefano.galassi[at]blockchainzoo.com
IMPORTANT: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
Index ¶
- type P2PServerHandler
- func (ss *P2PServerHandler) GetCommonMilestoneBlockIDs(ctx context.Context, req *model.GetCommonMilestoneBlockIdsRequest) (*model.GetCommonMilestoneBlockIdsResponse, error)
- func (ss *P2PServerHandler) GetCumulativeDifficulty(ctx context.Context, req *model.GetCumulativeDifficultyRequest) (*model.GetCumulativeDifficultyResponse, error)
- func (ss *P2PServerHandler) GetMorePeers(ctx context.Context, req *model.Empty) (*model.GetMorePeersResponse, error)
- func (ss *P2PServerHandler) GetNextBlockIDs(ctx context.Context, req *model.GetNextBlockIdsRequest) (*model.BlockIdsResponse, error)
- func (ss *P2PServerHandler) GetNextBlocks(ctx context.Context, req *model.GetNextBlocksRequest) (*model.BlocksData, error)
- func (ss *P2PServerHandler) GetNodeAddressesInfo(ctx context.Context, req *model.GetNodeAddressesInfoRequest) (..., error)
- func (ss *P2PServerHandler) GetNodeProofOfOrigin(ctx context.Context, req *model.GetNodeProofOfOriginRequest) (*model.ProofOfOrigin, error)
- func (ss *P2PServerHandler) GetPeerInfo(ctx context.Context, req *model.GetPeerInfoRequest) (*model.GetPeerInfoResponse, error)
- func (ss *P2PServerHandler) RequestBlockTransactions(ctx context.Context, req *model.RequestBlockTransactionsRequest) (*model.Empty, error)
- func (ss *P2PServerHandler) RequestFileDownload(ctx context.Context, req *model.FileDownloadRequest) (*model.FileDownloadResponse, error)
- func (ss *P2PServerHandler) SendBlock(ctx context.Context, req *model.SendBlockRequest) (*model.SendBlockResponse, error)
- func (ss *P2PServerHandler) SendBlockTransactions(ctx context.Context, req *model.SendBlockTransactionsRequest) (*model.SendBlockTransactionsResponse, error)
- func (ss *P2PServerHandler) SendNodeAddressInfo(ctx context.Context, req *model.SendNodeAddressInfoRequest) (*model.Empty, error)
- func (ss *P2PServerHandler) SendPeers(ctx context.Context, req *model.SendPeersRequest) (*model.Empty, error)
- func (ss *P2PServerHandler) SendTransaction(ctx context.Context, req *model.SendTransactionRequest) (*model.SendTransactionResponse, error)
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type P2PServerHandler ¶
type P2PServerHandler struct { Service service2.P2PServerServiceInterface FeedbackStrategy feedbacksystem.FeedbackStrategyInterface }
P2PServerHandler represent data service node as server
func NewP2PServerHandler ¶
func NewP2PServerHandler( p2pServerService service2.P2PServerServiceInterface, feedbackStrategy feedbacksystem.FeedbackStrategyInterface, ) *P2PServerHandler
func (*P2PServerHandler) GetCommonMilestoneBlockIDs ¶
func (ss *P2PServerHandler) GetCommonMilestoneBlockIDs(ctx context.Context, req *model.GetCommonMilestoneBlockIdsRequest) (*model.GetCommonMilestoneBlockIdsResponse, error)
func (*P2PServerHandler) GetCumulativeDifficulty ¶
func (ss *P2PServerHandler) GetCumulativeDifficulty(ctx context.Context, req *model.GetCumulativeDifficultyRequest, ) (*model.GetCumulativeDifficultyResponse, error)
GetCumulativeDifficulty responds to the request of the cumulative difficulty status of a node
func (*P2PServerHandler) GetMorePeers ¶
func (ss *P2PServerHandler) GetMorePeers(ctx context.Context, req *model.Empty) (*model.GetMorePeersResponse, error)
GetMorePeers contains info other peers
func (*P2PServerHandler) GetNextBlockIDs ¶
func (ss *P2PServerHandler) GetNextBlockIDs(ctx context.Context, req *model.GetNextBlockIdsRequest) (*model.BlockIdsResponse, error)
func (*P2PServerHandler) GetNextBlocks ¶
func (ss *P2PServerHandler) GetNextBlocks(ctx context.Context, req *model.GetNextBlocksRequest) (*model.BlocksData, error)
func (*P2PServerHandler) GetNodeAddressesInfo ¶
func (ss *P2PServerHandler) GetNodeAddressesInfo(ctx context.Context, req *model.GetNodeAddressesInfoRequest) (*model. GetNodeAddressesInfoResponse, error)
GetNodeAddressesInfo return content of node_address_info table to requesting peer
func (*P2PServerHandler) GetNodeProofOfOrigin ¶
func (ss *P2PServerHandler) GetNodeProofOfOrigin(ctx context.Context, req *model.GetNodeProofOfOriginRequest) (*model.ProofOfOrigin, error)
func (*P2PServerHandler) GetPeerInfo ¶
func (ss *P2PServerHandler) GetPeerInfo(ctx context.Context, req *model.GetPeerInfoRequest) (*model.GetPeerInfoResponse, error)
GetPeerInfo to return info of this host
func (*P2PServerHandler) RequestBlockTransactions ¶
func (ss *P2PServerHandler) RequestBlockTransactions( ctx context.Context, req *model.RequestBlockTransactionsRequest, ) (*model.Empty, error)
RequestBlockTransactions receive requested transaction from another node
func (*P2PServerHandler) RequestFileDownload ¶
func (ss *P2PServerHandler) RequestFileDownload( ctx context.Context, req *model.FileDownloadRequest, ) (*model.FileDownloadResponse, error)
RequestFileDownload receives an array of file names and return corresponding files.
func (*P2PServerHandler) SendBlock ¶
func (ss *P2PServerHandler) SendBlock(ctx context.Context, req *model.SendBlockRequest) (*model.SendBlockResponse, error)
SendBlock receive block from other node and calling BlockReceived Event
func (*P2PServerHandler) SendBlockTransactions ¶
func (ss *P2PServerHandler) SendBlockTransactions( ctx context.Context, req *model.SendBlockTransactionsRequest, ) (*model.SendBlockTransactionsResponse, error)
SendBlockTransactions receive transaction from other node and calling TransactionReceived Event
func (*P2PServerHandler) SendNodeAddressInfo ¶
func (ss *P2PServerHandler) SendNodeAddressInfo(ctx context.Context, req *model.SendNodeAddressInfoRequest) (*model.Empty, error)
SendNodeAddressInfo receive a NodeAddressInfo sent by a peer
func (*P2PServerHandler) SendPeers ¶
func (ss *P2PServerHandler) SendPeers(ctx context.Context, req *model.SendPeersRequest) (*model.Empty, error)
SendPeers receives set of peers info from other node and put them into the unresolved peers
func (*P2PServerHandler) SendTransaction ¶
func (ss *P2PServerHandler) SendTransaction( ctx context.Context, req *model.SendTransactionRequest, ) (*model.SendTransactionResponse, error)
SendTransaction receive transaction from other node and calling TransactionReceived Event