package net import ( "errors" msg "github.com/jbenet/go-ipfs/net/message" mux "github.com/jbenet/go-ipfs/net/mux" swarm "github.com/jbenet/go-ipfs/net/swarm" peer "github.com/jbenet/go-ipfs/peer" context "github.com/jbenet/go-ipfs/Godeps/_workspace/src/code.google.com/p/go.net/context" ) // IpfsNetwork implements the Network interface, type IpfsNetwork struct { // local peer local *peer.Peer // protocol multiplexing muxer *mux.Muxer // peer connection multiplexing swarm *swarm.Swarm // network context ctx context.Context cancel context.CancelFunc } // NewIpfsNetwork is the structure that implements the network interface func NewIpfsNetwork(ctx context.Context, local *peer.Peer, pmap *mux.ProtocolMap) (*IpfsNetwork, error) { ctx, cancel := context.WithCancel(ctx) in := &IpfsNetwork{ local: local, muxer: mux.NewMuxer(*pmap), ctx: ctx, cancel: cancel, } err := in.muxer.Start(ctx) if err != nil { cancel() return nil, err } in.swarm, err = swarm.NewSwarm(ctx, local) if err != nil { cancel() return nil, err } // remember to wire components together. in.muxer.Pipe.ConnectTo(in.swarm.Pipe) return in, nil } // Listen handles incoming connections on given Multiaddr. // func (n *IpfsNetwork) Listen(*ma.Muliaddr) error {} // DialPeer attempts to establish a connection to a given peer func (n *IpfsNetwork) DialPeer(p *peer.Peer) error { _, err := n.swarm.Dial(p) return err } // ClosePeer connection to peer func (n *IpfsNetwork) ClosePeer(p *peer.Peer) error { return n.swarm.CloseConnection(p) } // IsConnected returns whether a connection to given peer exists. func (n *IpfsNetwork) IsConnected(p *peer.Peer) (bool, error) { return n.swarm.GetConnection(p.ID) != nil, nil } // GetProtocols returns the protocols registered in the network. func (n *IpfsNetwork) GetProtocols() *mux.ProtocolMap { // copy over because this map should be read only. pmap := mux.ProtocolMap{} for id, proto := range n.muxer.Protocols { pmap[id] = proto } return &pmap } // SendMessage sends given Message out func (n *IpfsNetwork) SendMessage(m msg.NetMessage) error { n.swarm.Outgoing <- m return nil } // Close terminates all network operation func (n *IpfsNetwork) Close() error { if n.cancel == nil { return errors.New("Network already closed.") } n.swarm.Close() n.muxer.Stop() n.cancel() n.cancel = nil return nil }