bae4c820ee
* Initial Webserver Draft for Version Controlling * Rename type to avoid confusion * Move Function Calls into Version Package * Fix Linting and Language Typos * Fix Linting and Spelling Mistakes * Include Copyright * Include Copyright * Adjust Version-Control Server to return list of Versions * Linting * Improve Request Handling and Readability * Add Configuration File Option Add Systemd Service file * Add Logging to File * Smaller Changes * Add Semantic Versioning and refuses outdated Software from Startup (#1612) * implements internal Semantic Version library * adds version logging + reporting to process * Advance SemVer struct for easier handling * Add Accepted Version Store * Fix Function * Restructure * Type Conversion * Handle Version String properly * Add Note about array index * Set temporary Default Version * Add Copyright * Adding Version to Dashboard * Adding Version Info Log * Renaming and adding CheckerProcess * Iteration Sync * Iteration V2 * linting * made LogAndReportVersion a go routine * Refactor to Go Routine * Add Context to Go Routine and allow Operation if Lookup to Control Server fails * Handle Unmarshal properly * Linting * Relocate Version Checks * Relocating Version Check and specified default Version for now * Linting Error Prevention * Refuse Startup on outdated Version * Add Startup Check Function * Straighten Logging * Dont force Shutdown if --dev flag is set * Create full Service/Peer Structure for ControlServer * Linting * Straighting Naming * Finish VersionControl Service Layout * Improve Error Handling * Change Listening Address * Move Checker Function * Remove VersionControl Peer * Linting * Linting * Create VersionClient Service * Renaming * Add Version Client to Peer Definitions * Linting and Renaming * Linting * Remove Transport Checks for now * Move to Client Side Flag * Remove check * Linting * Transport Client Version Intro * Adding Version Client to Transport Client * Add missing parameter * Adding Version Check, to set Allowed = true * Set Default to true, testing * Restructuring Code * Uplink Changes * Add more proper Defaults * Renaming of Version struct * Dont pass Service use Pointer * Set Defaults for Versioning Checks * Put HTTP Server in go routine * Add Versioncontrol to Storj-Sim * Testplanet Fixes * Linting * Add Error Handling and new Server Struct * Move Lock slightly * Reduce Race Potentials * Remove unnecessary files * Linting * Add Proper Transport Handling * small fixes * add fence for allowed check * Add Startup Version Check and Service Naming * make errormessage private * Add Comments about VersionedClient * Linting * Remove Checks that refuse outgoing connections * Remove release cmd * Add Release Script * Linting * Update to use correct Values * Change Timestamp handling * Adding Protobuf changes back in * Adding SatelliteDB Changes and adding Storj Node Version to PB * Add Migration Table * Add Default Stats for Creation * Move to BigInt * Proper SQL Migration * Ensure minimum Version is passed to the node selection * Linting... * Remove VersionedClient and adjust smaller changes from prior merge * Linting * Fix PB Message Handling and Query for Node Selection * some future-proofing type changes Change-Id: I3cb5018dcccdbc9739fe004d859065992720caaf * fix a compiler error Change-Id: If66bb92d8b98e31cd618ecec9c6448ab9b037fa5 * Comment on Constant for Overlay * Remove NOT NULL and add epoch call as function * add versions to bootstrap and satellites Change-Id: I436944589ea5f21600cdd997742a84fe0b16e47b * Change Update Migration * Fix DB Migration * Increase Timeout temporarily, to see whats going on * Remove unnecessary const and vars Cleanup Function calls from deprecated NodeVersion struct * Updated Protopuf, removed depcreated Code from Inspector * Implement NodeVersion into InfoResponse * Regenerated locked.go * Linting * Fix Tests * Remove unnecessary constant * Update Function and Flag Description * Remove Empty Stat Creation * return properly with error * Remove unnecessary struct * simplify migration step * Update Inspector to return Version Info * Update local Endpoint Version Handling * Reset Travis Timeout * Add Default for CommitHash * single quotes
104 lines
3.1 KiB
Go
104 lines
3.1 KiB
Go
// Copyright (C) 2019 Storj Labs, Inc.
|
|
// See LICENSE for copying information.
|
|
|
|
package kademlia
|
|
|
|
import (
|
|
"context"
|
|
"sync/atomic"
|
|
|
|
"github.com/zeebo/errs"
|
|
"go.uber.org/zap"
|
|
|
|
"storj.io/storj/pkg/pb"
|
|
)
|
|
|
|
// EndpointError defines errors class for Endpoint
|
|
var EndpointError = errs.Class("kademlia endpoint error")
|
|
|
|
// Endpoint implements the kademlia Endpoints
|
|
type Endpoint struct {
|
|
log *zap.Logger
|
|
service *Kademlia
|
|
routingTable *RoutingTable
|
|
connected int32
|
|
}
|
|
|
|
// NewEndpoint returns a new kademlia endpoint
|
|
func NewEndpoint(log *zap.Logger, service *Kademlia, routingTable *RoutingTable) *Endpoint {
|
|
return &Endpoint{
|
|
service: service,
|
|
routingTable: routingTable,
|
|
log: log,
|
|
}
|
|
}
|
|
|
|
// Query is a node to node communication query
|
|
func (endpoint *Endpoint) Query(ctx context.Context, req *pb.QueryRequest) (*pb.QueryResponse, error) {
|
|
endpoint.service.Queried()
|
|
|
|
if req.GetPingback() {
|
|
endpoint.pingback(ctx, req.Sender)
|
|
}
|
|
|
|
nodes, err := endpoint.routingTable.FindNear(req.Target.Id, int(req.Limit))
|
|
if err != nil {
|
|
return &pb.QueryResponse{}, EndpointError.New("could not find near endpoint: %v", err)
|
|
}
|
|
|
|
return &pb.QueryResponse{Sender: req.Sender, Response: nodes}, nil
|
|
}
|
|
|
|
// pingback implements pingback for queries
|
|
func (endpoint *Endpoint) pingback(ctx context.Context, target *pb.Node) {
|
|
_, err := endpoint.service.Ping(ctx, *target)
|
|
if err != nil {
|
|
endpoint.log.Debug("connection to node failed", zap.Error(err), zap.String("nodeID", target.Id.String()))
|
|
err = endpoint.routingTable.ConnectionFailed(target)
|
|
if err != nil {
|
|
endpoint.log.Error("could not respond to connection failed", zap.Error(err))
|
|
}
|
|
} else {
|
|
err = endpoint.routingTable.ConnectionSuccess(target)
|
|
if err != nil {
|
|
endpoint.log.Error("could not respond to connection success", zap.Error(err))
|
|
} else {
|
|
count := atomic.AddInt32(&endpoint.connected, 1)
|
|
if count == 1 {
|
|
endpoint.log.Sugar().Debugf("Successfully connected with %s", target.Address.Address)
|
|
} else if count%100 == 0 {
|
|
endpoint.log.Sugar().Debugf("Successfully connected with %s %dx times", target.Address.Address, count)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// Ping provides an easy way to verify a node is online and accepting requests
|
|
func (endpoint *Endpoint) Ping(ctx context.Context, req *pb.PingRequest) (*pb.PingResponse, error) {
|
|
endpoint.service.Pinged()
|
|
return &pb.PingResponse{}, nil
|
|
}
|
|
|
|
// RequestInfo returns the node info
|
|
func (endpoint *Endpoint) RequestInfo(ctx context.Context, req *pb.InfoRequest) (*pb.InfoResponse, error) {
|
|
self := endpoint.service.Local()
|
|
|
|
return &pb.InfoResponse{
|
|
Type: self.GetType(),
|
|
Operator: &pb.NodeOperator{
|
|
Email: self.GetMetadata().GetEmail(),
|
|
Wallet: self.GetMetadata().GetWallet(),
|
|
},
|
|
Capacity: &pb.NodeCapacity{
|
|
FreeBandwidth: self.GetRestrictions().GetFreeBandwidth(),
|
|
FreeDisk: self.GetRestrictions().GetFreeDisk(),
|
|
},
|
|
Version: &pb.NodeVersion{
|
|
Version: self.GetVersion().GetVersion(),
|
|
CommitHash: self.GetVersion().GetCommitHash(),
|
|
Timestamp: self.GetVersion().GetTimestamp(),
|
|
Release: self.GetVersion().GetRelease(),
|
|
},
|
|
}, nil
|
|
}
|