Commit 41c3ed99 authored by suyanlong's avatar suyanlong

Add local

parent 96ef8012
Pipeline #7943 failed with stages
...@@ -3,6 +3,7 @@ package peermgr ...@@ -3,6 +3,7 @@ package peermgr
import ( import (
"github.com/libp2p/go-libp2p-core/peer" "github.com/libp2p/go-libp2p-core/peer"
"github.com/link33/sidecar/internal/port" "github.com/link33/sidecar/internal/port"
"github.com/link33/sidecar/internal/router"
"github.com/link33/sidecar/model/pb" "github.com/link33/sidecar/model/pb"
"github.com/meshplus/bitxhub-kit/crypto" "github.com/meshplus/bitxhub-kit/crypto"
) )
...@@ -12,6 +13,7 @@ type local struct { ...@@ -12,6 +13,7 @@ type local struct {
privKey crypto.PrivateKey privKey crypto.PrivateKey
tag string tag string
rev chan *pb.IBTPX rev chan *pb.IBTPX
rout router.Router
} }
func (l *local) ID() string { func (l *local) ID() string {
...@@ -31,6 +33,18 @@ func (l *local) Tag() string { ...@@ -31,6 +33,18 @@ func (l *local) Tag() string {
} }
func (l *local) Send(msg port.Message) (*pb.Message, error) { func (l *local) Send(msg port.Message) (*pb.Message, error) {
// 目标to == id 本机,获取信息
// 转发给路由器的。
// 判断数据类型
var to = ""
if to == l.id.String() {
//获取本机信息,以及本机做的工作。
} else {
//转发给路由模块
//l.rout.Route()
}
panic("implement me") panic("implement me")
} }
......
...@@ -28,16 +28,19 @@ func (s *sidecar) Tag() string { ...@@ -28,16 +28,19 @@ func (s *sidecar) Tag() string {
return s.tag return s.tag
} }
//TODO 如何区别IBTPX与Message // Send TODO 如何区别IBTPX与Message
// Send 同步发送给绑定的对应的port dev
func (s *sidecar) Send(msg port.Message) (*pb.Message, error) { func (s *sidecar) Send(msg port.Message) (*pb.Message, error) {
return s.swarm.Send(s.ID(), msg) return s.swarm.Send(s.ID(), msg)
} }
// AsyncSend 异步发送给绑定的对应的port dev
func (s *sidecar) AsyncSend(msg port.Message) error { func (s *sidecar) AsyncSend(msg port.Message) error {
return s.swarm.AsyncSend(s.ID(), msg) return s.swarm.AsyncSend(s.ID(), msg)
} }
// ListenIBTPX 从绑定的对应的port dev接收数据
func (s *sidecar) ListenIBTPX() <-chan *pb.IBTPX { func (s *sidecar) ListenIBTPX() <-chan *pb.IBTPX {
return s.rev return s.rev
} }
...@@ -97,6 +97,7 @@ func (swarm *Swarm) Start() error { ...@@ -97,6 +97,7 @@ func (swarm *Swarm) Start() error {
privKey: swarm.privKey, privKey: swarm.privKey,
tag: "", tag: "",
rev: make(chan *pb.IBTPX), rev: make(chan *pb.IBTPX),
rout: swarm.router,
} }
swarm.router.Add(l) swarm.router.Add(l)
...@@ -183,7 +184,7 @@ func (swarm *Swarm) handleMessage(s network.Stream, data []byte) { ...@@ -183,7 +184,7 @@ func (swarm *Swarm) handleMessage(s network.Stream, data []byte) {
pack := m.Payload.Data pack := m.Payload.Data
t := m.Type t := m.Type
switch { switch {
// 接收其它sidecar节点发过来的交易、请求等 // 接收其它sidecar节点发过来的交易、请求等。主要是IBTP结构相关数据。
case t == pb.Message_IBTP_SEND || t == pb.Message_IBTP_GET || t == pb.Message_IBTP_RECEIPT_SEND || t == pb.Message_IBTP_RECEIPT_GET: case t == pb.Message_IBTP_SEND || t == pb.Message_IBTP_GET || t == pb.Message_IBTP_RECEIPT_SEND || t == pb.Message_IBTP_RECEIPT_GET:
ibtpx := &pb.IBTPX{} ibtpx := &pb.IBTPX{}
if err := m.Unmarshal(pack); err != nil { if err := m.Unmarshal(pack); err != nil {
...@@ -208,7 +209,7 @@ func (swarm *Swarm) handleMessage(s network.Stream, data []byte) { ...@@ -208,7 +209,7 @@ func (swarm *Swarm) handleMessage(s network.Stream, data []byte) {
} }
swarm.router.Add(newPort) swarm.router.Add(newPort)
rec <- ibtpx rec <- ibtpx
default: default: //非IBTP结构相关数据
//TODO //TODO
} }
......
...@@ -38,8 +38,13 @@ type Port interface { ...@@ -38,8 +38,13 @@ type Port interface {
Name() string Name() string
Tag() string Tag() string
Send(msg Message) (*pb.Message, error) // Send 同步发送给绑定的对应的port dev
Send(msg Message) (*pb.Message, error) //TODO 如何区别IBTPX与Message
// AsyncSend 异步发送给绑定的对应的port dev
AsyncSend(msg Message) error AsyncSend(msg Message) error
// ListenIBTPX 从绑定的对应的port dev接收数据
ListenIBTPX() <-chan *pb.IBTPX ListenIBTPX() <-chan *pb.IBTPX
} }
......
...@@ -3,3 +3,9 @@ package pb ...@@ -3,3 +3,9 @@ package pb
const ( const (
V1 = "1.0" V1 = "1.0"
) )
//type Message interface {
// Marshal() ([]byte, error)
// Unmarshal([]byte) error
// IsMsg()bool
//}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment