lotus/node/modules/core.go

126 lines
2.9 KiB
Go
Raw Normal View History

package modules
import (
2019-10-11 00:31:06 +00:00
"context"
2019-07-23 20:37:06 +00:00
"crypto/rand"
2019-10-11 00:31:06 +00:00
"github.com/filecoin-project/go-lotus/build"
"github.com/filecoin-project/go-lotus/lib/addrutil"
2019-10-11 00:31:06 +00:00
"github.com/filecoin-project/go-lotus/node/modules/helpers"
2019-07-24 01:16:17 +00:00
"github.com/gbrlsnchs/jwt/v3"
2019-07-03 17:39:07 +00:00
logging "github.com/ipfs/go-log"
2019-10-11 00:31:06 +00:00
"github.com/libp2p/go-libp2p-core/host"
"github.com/libp2p/go-libp2p-core/peerstore"
record "github.com/libp2p/go-libp2p-record"
2019-10-11 00:31:06 +00:00
"go.uber.org/fx"
2019-07-24 01:16:17 +00:00
"golang.org/x/xerrors"
2019-10-11 00:31:06 +00:00
"io"
"io/ioutil"
"time"
2019-07-24 01:16:17 +00:00
"github.com/filecoin-project/go-lotus/api"
"github.com/filecoin-project/go-lotus/chain/types"
"github.com/filecoin-project/go-lotus/node/modules/dtypes"
2019-07-10 15:38:35 +00:00
"github.com/filecoin-project/go-lotus/node/repo"
)
2019-07-03 17:39:07 +00:00
var log = logging.Logger("modules")
type Genesis func() (*types.BlockHeader, error)
2019-07-08 13:36:43 +00:00
// RecordValidator provides namesys compatible routing record validator
func RecordValidator(ps peerstore.Peerstore) record.Validator {
return record.NamespacedValidator{
"pk": record.PublicKeyValidator{},
}
}
2019-07-08 13:36:43 +00:00
2019-07-23 20:23:44 +00:00
const JWTSecretName = "auth-jwt-private"
2019-07-23 20:37:06 +00:00
type jwtPayload struct {
Allow []string
}
func APISecret(keystore types.KeyStore, lr repo.LockedRepo) (*dtypes.APIAlg, error) {
2019-07-23 20:23:44 +00:00
key, err := keystore.Get(JWTSecretName)
if err != nil {
2019-07-23 20:37:06 +00:00
log.Warn("Generating new API secret")
sk, err := ioutil.ReadAll(io.LimitReader(rand.Reader, 32))
if err != nil {
return nil, err
}
key = types.KeyInfo{
Type: "jwt-hmac-secret",
PrivateKey: sk,
}
if err := keystore.Put(JWTSecretName, key); err != nil {
return nil, xerrors.Errorf("writing API secret: %w", err)
}
// TODO: make this configurable
p := jwtPayload{
Allow: api.AllPermissions,
}
cliToken, err := jwt.Sign(&p, jwt.NewHS256(key.PrivateKey))
if err != nil {
return nil, err
}
if err := lr.SetAPIToken(cliToken); err != nil {
return nil, err
}
2019-07-23 20:23:44 +00:00
}
2019-07-23 20:37:06 +00:00
return (*dtypes.APIAlg)(jwt.NewHS256(key.PrivateKey)), nil
2019-07-23 20:23:44 +00:00
}
2019-10-11 00:31:06 +00:00
func ConfigBootstrap(peers []string) func() (dtypes.BootstrapPeers, error) {
return func() (dtypes.BootstrapPeers, error) {
return addrutil.ParseAddresses(context.TODO(), peers)
}
}
func BuiltinBootstrap() (dtypes.BootstrapPeers, error) {
return build.BuiltinBootstrap()
}
func Bootstrap(mctx helpers.MetricsCtx, lc fx.Lifecycle, host host.Host, pinfos dtypes.BootstrapPeers) {
2019-10-11 00:31:06 +00:00
ctx, cancel := context.WithCancel(mctx)
lc.Append(fx.Hook{
OnStart: func(_ context.Context) error {
go func() {
for {
2019-10-17 01:24:45 +00:00
sctx, cancel := context.WithTimeout(ctx, 2*time.Second)
2019-10-11 00:31:06 +00:00
<-sctx.Done()
cancel()
if ctx.Err() != nil {
return
}
if len(host.Network().Conns()) > 0 {
continue
}
log.Warn("No peers connected, performing automatic bootstrap")
for _, pi := range pinfos {
2019-10-11 00:31:06 +00:00
if err := host.Connect(ctx, pi); err != nil {
log.Warn("bootstrap connect failed: ", err)
}
}
}
}()
return nil
},
OnStop: func(_ context.Context) error {
cancel()
return nil
},
})
}