2018-07-04 13:51:47 +03:00
|
|
|
package config
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
2022-11-04 09:57:20 -04:00
|
|
|
"github.com/libp2p/go-libp2p/core/host"
|
|
|
|
"github.com/libp2p/go-libp2p/core/network"
|
2022-08-19 12:34:07 -04:00
|
|
|
msmux "github.com/libp2p/go-libp2p/p2p/muxer/muxer-multistream"
|
2018-07-04 13:51:47 +03:00
|
|
|
)
|
|
|
|
|
2021-06-16 16:19:45 -04:00
|
|
|
// MuxC is a stream multiplex transport constructor.
|
2022-04-01 12:16:46 -04:00
|
|
|
type MuxC func(h host.Host) (network.Multiplexer, error)
|
2018-07-04 13:51:47 +03:00
|
|
|
|
|
|
|
// MsMuxC is a tuple containing a multiplex transport constructor and a protocol
|
|
|
|
// ID.
|
|
|
|
type MsMuxC struct {
|
|
|
|
MuxC
|
|
|
|
ID string
|
|
|
|
}
|
|
|
|
|
|
|
|
var muxArgTypes = newArgTypeSet(hostType, networkType, peerIDType, pstoreType)
|
|
|
|
|
|
|
|
// MuxerConstructor creates a multiplex constructor from the passed parameter
|
|
|
|
// using reflection.
|
|
|
|
func MuxerConstructor(m interface{}) (MuxC, error) {
|
|
|
|
// Already constructed?
|
2022-04-01 12:16:46 -04:00
|
|
|
if t, ok := m.(network.Multiplexer); ok {
|
|
|
|
return func(_ host.Host) (network.Multiplexer, error) {
|
2018-07-04 13:51:47 +03:00
|
|
|
return t, nil
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
ctor, err := makeConstructor(m, muxType, muxArgTypes)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2022-04-01 12:16:46 -04:00
|
|
|
return func(h host.Host) (network.Multiplexer, error) {
|
2022-11-04 09:57:20 -04:00
|
|
|
t, err := ctor(h, nil, nil, nil, nil, nil)
|
2018-07-04 13:51:47 +03:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2022-04-01 12:16:46 -04:00
|
|
|
return t.(network.Multiplexer), nil
|
2018-07-04 13:51:47 +03:00
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
2022-04-01 12:16:46 -04:00
|
|
|
func makeMuxer(h host.Host, tpts []MsMuxC) (network.Multiplexer, error) {
|
2018-07-04 13:51:47 +03:00
|
|
|
muxMuxer := msmux.NewBlankTransport()
|
|
|
|
transportSet := make(map[string]struct{}, len(tpts))
|
|
|
|
for _, tptC := range tpts {
|
|
|
|
if _, ok := transportSet[tptC.ID]; ok {
|
|
|
|
return nil, fmt.Errorf("duplicate muxer transport: %s", tptC.ID)
|
|
|
|
}
|
2019-06-09 09:24:20 +02:00
|
|
|
transportSet[tptC.ID] = struct{}{}
|
2018-07-04 13:51:47 +03:00
|
|
|
}
|
|
|
|
for _, tptC := range tpts {
|
|
|
|
tpt, err := tptC.MuxC(h)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
muxMuxer.AddTransport(tptC.ID, tpt)
|
|
|
|
}
|
|
|
|
return muxMuxer, nil
|
|
|
|
}
|