a2fa5c4c5a
* adds enums to nodetype * updating nodetype todos * ran pb updates * reorder nodetypes * adding checks * wip * wip * wip * bug in test-captplanet * wip * add values to storagenode, satellite, captplanet binaries * Cleanup * more cleanup * wip * lint * lint * wip * fixes bug * regenerate protos Change-Id: Id270212e8c7479e52641058042cf23b5317ab773 * limit node type changes to kademlia Change-Id: I9c1a6cc4a79e05086627f0fdeb5028c62ce754f4 * dpanic Change-Id: Id952a2ad13c807ebaea0ec0a875405e267d81c3e * review comments Change-Id: I7f9b77ef22779dd012fd490375b136014f51f834
121 lines
3.5 KiB
Go
121 lines
3.5 KiB
Go
// Copyright (C) 2018 Storj Labs, Inc.
|
|
// See LICENSE for copying information.
|
|
|
|
package kademlia
|
|
|
|
import (
|
|
"context"
|
|
"flag"
|
|
|
|
"github.com/zeebo/errs"
|
|
"go.uber.org/zap"
|
|
monkit "gopkg.in/spacemonkeygo/monkit.v2"
|
|
|
|
"storj.io/storj/pkg/node"
|
|
"storj.io/storj/pkg/pb"
|
|
"storj.io/storj/pkg/provider"
|
|
"storj.io/storj/pkg/utils"
|
|
)
|
|
|
|
var (
|
|
// Error defines a Kademlia error
|
|
Error = errs.Class("kademlia error")
|
|
mon = monkit.Package()
|
|
)
|
|
|
|
var (
|
|
flagBucketSize = flag.Int("kademlia.bucket-size", 20, "Size of each Kademlia bucket")
|
|
flagReplacementCacheSize = flag.Int("kademlia.replacement-cache-size", 5, "Size of Kademlia replacement cache")
|
|
)
|
|
|
|
//CtxKey Used as kademlia key
|
|
type CtxKey int
|
|
|
|
const (
|
|
ctxKeyKad CtxKey = iota
|
|
)
|
|
|
|
// OperatorConfig defines properties related to storage node operator metadata
|
|
type OperatorConfig struct {
|
|
Email string `help:"Operator email address" default:""`
|
|
Wallet string `help:"Operator wallet adress" default:""`
|
|
}
|
|
|
|
// Config defines all of the things that are needed to start up Kademlia
|
|
// server endpoints (and not necessarily client code).
|
|
type Config struct {
|
|
BootstrapAddr string `help:"the kademlia node to bootstrap against" default:"bootstrap-dev.storj.io:8080"`
|
|
DBPath string `help:"the path for our db services to be created on" default:"$CONFDIR/kademlia"`
|
|
Alpha int `help:"alpha is a system wide concurrency parameter." default:"5"`
|
|
ExternalAddress string `help:"the public address of the kademlia node; defaults to the gRPC server address." default:""`
|
|
Operator OperatorConfig
|
|
}
|
|
|
|
// StorageNodeConfig is a Config that implements provider.Responsibility as
|
|
// a storage node
|
|
type StorageNodeConfig Config
|
|
|
|
// Run implements provider.Responsibility
|
|
func (c StorageNodeConfig) Run(ctx context.Context, server *provider.Provider) error {
|
|
return Config(c).Run(ctx, server, pb.NodeType_STORAGE)
|
|
}
|
|
|
|
// SatelliteConfig is a Config that implements provider.Responsibility as
|
|
// a satellite
|
|
type SatelliteConfig Config
|
|
|
|
// Run implements provider.Responsibility
|
|
func (c SatelliteConfig) Run(ctx context.Context, server *provider.Provider) error {
|
|
return Config(c).Run(ctx, server, pb.NodeType_SATELLITE)
|
|
}
|
|
|
|
// Run does not implement provider.Responsibility. Please use a specific
|
|
// SatelliteConfig or StorageNodeConfig
|
|
func (c Config) Run(ctx context.Context, server *provider.Provider,
|
|
nodeType pb.NodeType) (err error) {
|
|
defer mon.Task()(&ctx)(&err)
|
|
|
|
// TODO(coyle): I'm thinking we just remove this function and grab from the config.
|
|
in, err := GetIntroNode(c.BootstrapAddr)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
metadata := &pb.NodeMetadata{
|
|
Email: c.Operator.Email,
|
|
Wallet: c.Operator.Wallet,
|
|
}
|
|
|
|
addr := server.Addr().String()
|
|
if c.ExternalAddress != "" {
|
|
addr = c.ExternalAddress
|
|
}
|
|
|
|
logger := zap.L()
|
|
kad, err := NewKademlia(logger, nodeType, []pb.Node{*in}, addr, metadata, server.Identity(), c.DBPath, c.Alpha)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
kad.StartRefresh(ctx)
|
|
defer func() { err = utils.CombineErrors(err, kad.Disconnect()) }()
|
|
|
|
pb.RegisterNodesServer(server.GRPC(), node.NewServer(logger, kad))
|
|
|
|
go func() {
|
|
if err = kad.Bootstrap(ctx); err != nil {
|
|
logger.Error("Failed to bootstrap Kademlia", zap.Any("ID", server.Identity().ID))
|
|
}
|
|
}()
|
|
|
|
return server.Run(context.WithValue(ctx, ctxKeyKad, kad))
|
|
}
|
|
|
|
// LoadFromContext loads an existing Kademlia from the Provider context
|
|
// stack if one exists.
|
|
func LoadFromContext(ctx context.Context) *Kademlia {
|
|
if v, ok := ctx.Value(ctxKeyKad).(*Kademlia); ok {
|
|
return v
|
|
}
|
|
return nil
|
|
}
|