mirror of
https://github.com/kaspanet/kaspad.git
synced 2025-09-13 13:00:10 +00:00

* [NOD-1319] Create the protorpc package. * [NOD-1319] Use a general ClientStream in closeSend. * [NOD-1319] Decouple p2pServer from gRPCServer. * [NOD-1319] Begin implementing rpcServer. * [NOD-1319] Move grpcStream to grpc_connection.go. * [NOD-1319] Fold the rpc messages.proto into a common message.proto. * [NOD-1319] Remove code duplication in MessageStream. * [NOD-1319] Rename methods in netadapter. * [NOD-1319] Rename message_xxx to p2p_xxx. * [NOD-1319] Section off p2p messages from rpc messages in messages.proto. * [NOD-1319] Split toPayload to a p2p part and and rpc part. * [NOD-1319] Rename msgxxx.go to p2p_msgxx.go in the appmessage package. * [NOD-1319] Implement GetCurrentVersionRequestMessage and GetCurrentVersionResponseMessage. * [NOD-1319] Implement toAppMessage and fromAppMessage for getCurrentNetwork * [NOD-1319] Make a temporary workaround so that tests pass. * [NOD-1319] Begin implementing the rpc manager. * [NOD-1319] Implement an initial routerInitializer for rpc. * [NOD-1319] Rename the spawn in routerInitializer. * [NOD-1319] Implement an RPC context. * [NOD-1319] Move the actual handlers to a separate package. * [NOD-1319] Use the correct value for the GetCurrentNetwork response. * [NOD-1319] Fix some names. * [NOD-1319] Begin implementing a cli rpc client. * [NOD-1319] Implement connecting to the RPC server. * [NOD-1319] Make sure that connecting to the server and sending/receiving messages works. * [NOD-1319] Make kaspactl2 speak in json strings. * [NOD-1319] Finish implementing kaspactl2. * [NOD-1319] Remove debug messages. * [NOD-1319] Properly handle errors in rpc.go. * [NOD-1319] Move the grpc client to a separate package. * [NOD-1319] Extract Post out of PostString. * [NOD-1319] Implement PostAppMessage. * [NOD-1319] Stub out submitBlock. * [NOD-1319] Stub out getBlockTemplate. * [NOD-1319] Combine request and reponse files. * [NOD-1319] Implement submitBlock. * [NOD-1319] Implement returning errors from RPC. * [NOD-1319] Begin implementing getBlockTemplate. * [NOD-1319] Add missing field in GetBlockTemplateRequestMessage. * [NOD-1319] Implement a minimal getBlockTemplate. * [NOD-1319] Add getBlockTemplate stuff to grpc. * [NOD-1319] Implement the rest of getBlockTemplate. * [NOD-1319] Add block/transaction added handlers to the protocol manager. * [NOD-1319] Implement NotifyTransactionAddedToMempool. * [NOD-1319] Implement NotifyBlockAddedToDAG. * [NOD-1319] Connect block/transaction added handlers. * [NOD-1319] Add notifyBlockAdded. * [NOD-1319] Add a notification system. * [NOD-1319] Improve the notification system. * [NOD-1319] Add a block added listener stub. * [NOD-1319] Add BlockAddedNotificationMessage. * [NOD-1319] Finish implementing HandleNotifyBlockAdded. * [NOD-1319] Println instead of Print in kaspactl2. * [NOD-1319] Remove unused flags in kaspactl2. * [NOD-1319] Make kaspaminer work with the new RPC. * [NOD-1319] Fix a bad log. * [NOD-1319] Make kaspaminer work. * [NOD-1319] Disconnect the old RPC. * [NOD-1319] Move grpcclient.go. * [NOD-1319] Begin generalizing the rpcClient. * [NOD-1319] Move errors to the side of the payload. * [NOD-1319] Add errors to appmessage. * [NOD-1319] Move AttachRouter to grpcclient. * [NOD-1319] Fix kaspaminer not handling responses. * [NOD-1319] Properly handle blockAddedNotifications. * [NOD-1319] Move errors into individual response objects. * [NOD-1319] Begin replacing the RPC client in the integration tests. * [NOD-1319] Implement GetPeerAddresses. * [NOD-1319] Implement GetPeerAddresses. * [NOD-1319] Fix setOnBlockAddedHandler. * [NOD-1319] Remove the old kaspactl. * [NOD-1319] Move ConvertGetBlockTemplateResultToBlock to the mining package. * [NOD-1319] Implement getSelectedTipHash. * [NOD-1319] Simplify testRPCRouter. * [NOD-1319] Write stubs for the required test RPC commands. * [NOD-1319] Implement a minimal getMempoolEntry. * [NOD-1319] Implement a minimal getMempoolEntry. * [NOD-1319] Implement getConnectedPeerInfo. * [NOD-1319] Delete the old RPC. * [NOD-1319] Fix a fromAppMessage. * [NOD-1319] Implement connectToPeer. * [NOD-1319] Fix a bug in registerForBlockAddedNotifications. * [NOD-1319] Fix a deadlock in closing notification listeners. * [NOD-1319] Fix merge errors. * [NOD-1319] Fix an import. * [NOD-1319] Properly handle errors in grpcclient. * [NOD-1319] Fix TestIBD. * [NOD-1319] Prevent kaspaminer from running when not connected. * [NOD-1319] Implement sendRawTransaction. * [NOD-1319] Implement sendRawTransaction in the client. * [NOD-1319] Extract a general RPC client from the integration test RPC client. * [NOD-1319] Use the general RPC client for the miner. * [NOD-1319] Move the rpcclient package out of netadapter. * [NOD-1319] Normalize onBlockAdded. * [NOD-1319] Begin implementing notifyChainChanged. * [NOD-1319] Implement the model for notifyChainChanged. * [NOD-1319] Implement conversions for notifyChainChanged. * [NOD-1319] Implement HandleNotifyChainChanged. * [NOD-1319] Normalize notifications. * [NOD-1319] Implement RegisterForChainChangedNotifications. * [NOD-1319] Begin connecting blockdag's chain-changed notification with the RPC. * [NOD-1319] Finish implementing notifyChainChanged. * [NOD-1319] Implement getBlockHex. * [NOD-1319] Rename getBlockHex to getBlock. * [NOD-1319] Implement the verbose model for getBlock. * [NOD-1319] Implement buildBlockVerboseData. * [NOD-1319] Implement buildTransactionVerboseData. * [NOD-1319] Move verboseData stuff to verbosedata.go. * [NOD-1319] Add includeTransactionVerboseData. * [NOD-1319] Begin implementing getSubnetwork. * [NOD-1319] Finish implementing getSubnetwork. * [NOD-1319] Begin implementing getChainFromBlock. * [NOD-1319] Finish implementing getChainFromBlock. * [NOD-1319] Begin implementing getBlocks. * [NOD-1319] Finish implementing getBlocks. * [NOD-1319] Fix bad responses in HandleNotifyChainChanged. * [NOD-1319] Fix bugs in verbosedata.go. * [NOD-1319] Fix more bugs in verbosedata.go. * [NOD-1319] Make go vet happy. * [NOD-1319] Extract handleBlockDAGNotifications to a method. * [NOD-1319] Add a newline. * [NOD-1319] Use peers instead of connections to check if connected. * [NOD-1319] Add a comment. * [NOD-1319] Lock the dag lock in getBlock. * [NOD-1319] Rename netAdapter.connections to p2pConnections. * [NOD-1319] In protowire, rename wireXXX to protoXXX. * [NOD-1319] Rename PostString to PostJSON. * [NOD-1319] Disallow empty transactions in SendRawTransaction. * [NOD-1319] Disallow empty blocks in SubmitBlocks. * [NOD-1319] Add SetLogger. * [NOD-1319] Fix an error message. * [NOD-1319] Fix an error message. * [NOD-1319] Rename testTimeout to rpcTimeout. * [NOD-1319] Rename SendRawTransaction to SubmitTransaction. * [NOD-1319] Rename ConnectToPeer to AddPeer. * [NOD-1319] Add missing longPollID to request. * [NOD-1319] Rename ChainChangedChainBlock to ChainBlock. * [NOD-1319] Rename Vin and Vout. * [NOD-1319] Implement RPCErrorf. * [NOD-1319] Fix RPCErrorf's comment. * [NOD-1319] Remove unused flags in kaspaminer.
310 lines
8.0 KiB
Go
310 lines
8.0 KiB
Go
// Copyright (c) 2013-2017 The btcsuite developers
|
|
// Copyright (c) 2017 The Decred developers
|
|
// Use of this source code is governed by an ISC
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package logger
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
"sort"
|
|
"strings"
|
|
|
|
"github.com/pkg/errors"
|
|
)
|
|
|
|
// Loggers per subsystem. A single backend logger is created and all subsytem
|
|
// loggers created from it will write to the backend. When adding new
|
|
// subsystems, add the subsystem logger variable here and to the
|
|
// subsystemLoggers map.
|
|
//
|
|
// Loggers can not be used before the log rotator has been initialized with a
|
|
// log file. This must be performed early during application startup by calling
|
|
// InitLog.
|
|
var (
|
|
// BackendLog is the logging backend used to create all subsystem loggers.
|
|
BackendLog = NewBackend()
|
|
|
|
adxrLog = BackendLog.Logger("ADXR")
|
|
amgrLog = BackendLog.Logger("AMGR")
|
|
cmgrLog = BackendLog.Logger("CMGR")
|
|
ksdbLog = BackendLog.Logger("KSDB")
|
|
kasdLog = BackendLog.Logger("KASD")
|
|
bdagLog = BackendLog.Logger("BDAG")
|
|
cnfgLog = BackendLog.Logger("CNFG")
|
|
discLog = BackendLog.Logger("DISC")
|
|
indxLog = BackendLog.Logger("INDX")
|
|
minrLog = BackendLog.Logger("MINR")
|
|
peerLog = BackendLog.Logger("PEER")
|
|
rpcsLog = BackendLog.Logger("RPCS")
|
|
rpccLog = BackendLog.Logger("RPCC")
|
|
scrpLog = BackendLog.Logger("SCRP")
|
|
srvrLog = BackendLog.Logger("SRVR")
|
|
syncLog = BackendLog.Logger("SYNC")
|
|
txmpLog = BackendLog.Logger("TXMP")
|
|
utilLog = BackendLog.Logger("UTIL")
|
|
profLog = BackendLog.Logger("PROF")
|
|
protLog = BackendLog.Logger("PROT")
|
|
muxxLog = BackendLog.Logger("MUXX")
|
|
grpcLog = BackendLog.Logger("GRPC")
|
|
p2psLog = BackendLog.Logger("P2PS")
|
|
ntarLog = BackendLog.Logger("NTAR")
|
|
dnssLog = BackendLog.Logger("DNSS")
|
|
snvrLog = BackendLog.Logger("SNVR")
|
|
ibdsLog = BackendLog.Logger("IBDS")
|
|
)
|
|
|
|
// SubsystemTags is an enum of all sub system tags
|
|
var SubsystemTags = struct {
|
|
ADXR,
|
|
AMGR,
|
|
CMGR,
|
|
KSDB,
|
|
KASD,
|
|
BDAG,
|
|
CNFG,
|
|
DISC,
|
|
INDX,
|
|
MINR,
|
|
PEER,
|
|
RPCS,
|
|
RPCC,
|
|
SCRP,
|
|
SRVR,
|
|
SYNC,
|
|
TXMP,
|
|
UTIL,
|
|
PROF,
|
|
PROT,
|
|
MUXX,
|
|
GRPC,
|
|
P2PS,
|
|
NTAR,
|
|
DNSS,
|
|
SNVR,
|
|
IBDS string
|
|
}{
|
|
ADXR: "ADXR",
|
|
AMGR: "AMGR",
|
|
CMGR: "CMGR",
|
|
KSDB: "KSDB",
|
|
KASD: "KASD",
|
|
BDAG: "BDAG",
|
|
CNFG: "CNFG",
|
|
DISC: "DISC",
|
|
INDX: "INDX",
|
|
MINR: "MINR",
|
|
PEER: "PEER",
|
|
RPCS: "RPCS",
|
|
RPCC: "RPCC",
|
|
SCRP: "SCRP",
|
|
SRVR: "SRVR",
|
|
SYNC: "SYNC",
|
|
TXMP: "TXMP",
|
|
UTIL: "UTIL",
|
|
PROF: "PROF",
|
|
PROT: "PROT",
|
|
MUXX: "MUXX",
|
|
GRPC: "GRPC",
|
|
P2PS: "P2PS",
|
|
NTAR: "NTAR",
|
|
DNSS: "DNSS",
|
|
SNVR: "SNVR",
|
|
IBDS: "IBDS",
|
|
}
|
|
|
|
// subsystemLoggers maps each subsystem identifier to its associated logger.
|
|
var subsystemLoggers = map[string]*Logger{
|
|
SubsystemTags.ADXR: adxrLog,
|
|
SubsystemTags.AMGR: amgrLog,
|
|
SubsystemTags.CMGR: cmgrLog,
|
|
SubsystemTags.KSDB: ksdbLog,
|
|
SubsystemTags.KASD: kasdLog,
|
|
SubsystemTags.BDAG: bdagLog,
|
|
SubsystemTags.CNFG: cnfgLog,
|
|
SubsystemTags.DISC: discLog,
|
|
SubsystemTags.INDX: indxLog,
|
|
SubsystemTags.MINR: minrLog,
|
|
SubsystemTags.PEER: peerLog,
|
|
SubsystemTags.RPCS: rpcsLog,
|
|
SubsystemTags.RPCC: rpccLog,
|
|
SubsystemTags.SCRP: scrpLog,
|
|
SubsystemTags.SRVR: srvrLog,
|
|
SubsystemTags.SYNC: syncLog,
|
|
SubsystemTags.TXMP: txmpLog,
|
|
SubsystemTags.UTIL: utilLog,
|
|
SubsystemTags.PROF: profLog,
|
|
SubsystemTags.PROT: protLog,
|
|
SubsystemTags.MUXX: muxxLog,
|
|
SubsystemTags.GRPC: grpcLog,
|
|
SubsystemTags.P2PS: p2psLog,
|
|
SubsystemTags.NTAR: ntarLog,
|
|
SubsystemTags.DNSS: dnssLog,
|
|
SubsystemTags.SNVR: snvrLog,
|
|
SubsystemTags.IBDS: ibdsLog,
|
|
}
|
|
|
|
// InitLog attaches log file and error log file to the backend log.
|
|
func InitLog(logFile, errLogFile string) {
|
|
err := BackendLog.AddLogFileWithCustomRotator(logFile, LevelTrace, 100*1024, 4)
|
|
if err != nil {
|
|
fmt.Fprintf(os.Stderr, "Error adding log file %s as log rotator for level %s: %s", logFile, LevelTrace, err)
|
|
os.Exit(1)
|
|
}
|
|
err = BackendLog.AddLogFile(errLogFile, LevelWarn)
|
|
if err != nil {
|
|
fmt.Fprintf(os.Stderr, "Error adding log file %s as log rotator for level %s: %s", errLogFile, LevelWarn, err)
|
|
os.Exit(1)
|
|
}
|
|
}
|
|
|
|
// SetLogLevel sets the logging level for provided subsystem. Invalid
|
|
// subsystems are ignored. Uninitialized subsystems are dynamically created as
|
|
// needed.
|
|
func SetLogLevel(subsystemID string, logLevel string) {
|
|
// Ignore invalid subsystems.
|
|
logger, ok := subsystemLoggers[subsystemID]
|
|
if !ok {
|
|
return
|
|
}
|
|
|
|
// Defaults to info if the log level is invalid.
|
|
level, _ := LevelFromString(logLevel)
|
|
logger.SetLevel(level)
|
|
}
|
|
|
|
// SetLogLevels sets the log level for all subsystem loggers to the passed
|
|
// level. It also dynamically creates the subsystem loggers as needed, so it
|
|
// can be used to initialize the logging system.
|
|
func SetLogLevels(logLevel string) {
|
|
// Configure all sub-systems with the new logging level. Dynamically
|
|
// create loggers as needed.
|
|
for subsystemID := range subsystemLoggers {
|
|
SetLogLevel(subsystemID, logLevel)
|
|
}
|
|
}
|
|
|
|
// DirectionString is a helper function that returns a string that represents
|
|
// the direction of a connection (inbound or outbound).
|
|
func DirectionString(inbound bool) string {
|
|
if inbound {
|
|
return "inbound"
|
|
}
|
|
return "outbound"
|
|
}
|
|
|
|
// PickNoun returns the singular or plural form of a noun depending
|
|
// on the count n.
|
|
func PickNoun(n uint64, singular, plural string) string {
|
|
if n == 1 {
|
|
return singular
|
|
}
|
|
return plural
|
|
}
|
|
|
|
// SupportedSubsystems returns a sorted slice of the supported subsystems for
|
|
// logging purposes.
|
|
func SupportedSubsystems() []string {
|
|
// Convert the subsystemLoggers map keys to a slice.
|
|
subsystems := make([]string, 0, len(subsystemLoggers))
|
|
for subsysID := range subsystemLoggers {
|
|
subsystems = append(subsystems, subsysID)
|
|
}
|
|
|
|
// Sort the subsystems for stable display.
|
|
sort.Strings(subsystems)
|
|
return subsystems
|
|
}
|
|
|
|
// Get returns a logger of a specific sub system
|
|
func Get(tag string) (logger *Logger, ok bool) {
|
|
logger, ok = subsystemLoggers[tag]
|
|
return
|
|
}
|
|
|
|
// ParseAndSetDebugLevels attempts to parse the specified debug level and set
|
|
// the levels accordingly. An appropriate error is returned if anything is
|
|
// invalid.
|
|
func ParseAndSetDebugLevels(debugLevel string) error {
|
|
// When the specified string doesn't have any delimters, treat it as
|
|
// the log level for all subsystems.
|
|
if !strings.Contains(debugLevel, ",") && !strings.Contains(debugLevel, "=") {
|
|
// Validate debug log level.
|
|
if !validLogLevel(debugLevel) {
|
|
str := "The specified debug level [%s] is invalid"
|
|
return errors.Errorf(str, debugLevel)
|
|
}
|
|
|
|
// Change the logging level for all subsystems.
|
|
SetLogLevels(debugLevel)
|
|
|
|
return nil
|
|
}
|
|
|
|
// Split the specified string into subsystem/level pairs while detecting
|
|
// issues and update the log levels accordingly.
|
|
for _, logLevelPair := range strings.Split(debugLevel, ",") {
|
|
if !strings.Contains(logLevelPair, "=") {
|
|
str := "The specified debug level contains an invalid " +
|
|
"subsystem/level pair [%s]"
|
|
return errors.Errorf(str, logLevelPair)
|
|
}
|
|
|
|
// Extract the specified subsystem and log level.
|
|
fields := strings.Split(logLevelPair, "=")
|
|
subsysID, logLevel := fields[0], fields[1]
|
|
|
|
// Validate subsystem.
|
|
if _, exists := Get(subsysID); !exists {
|
|
str := "The specified subsystem [%s] is invalid -- " +
|
|
"supported subsytems %s"
|
|
return errors.Errorf(str, subsysID, strings.Join(SupportedSubsystems(), ", "))
|
|
}
|
|
|
|
// Validate log level.
|
|
if !validLogLevel(logLevel) {
|
|
str := "The specified debug level [%s] is invalid"
|
|
return errors.Errorf(str, logLevel)
|
|
}
|
|
|
|
SetLogLevel(subsysID, logLevel)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// validLogLevel returns whether or not logLevel is a valid debug log level.
|
|
func validLogLevel(logLevel string) bool {
|
|
switch logLevel {
|
|
case "trace":
|
|
fallthrough
|
|
case "debug":
|
|
fallthrough
|
|
case "info":
|
|
fallthrough
|
|
case "warn":
|
|
fallthrough
|
|
case "error":
|
|
fallthrough
|
|
case "critical":
|
|
return true
|
|
}
|
|
return false
|
|
}
|
|
|
|
// LogClosure is a closure that can be printed with %s to be used to
|
|
// generate expensive-to-create data for a detailed log level and avoid doing
|
|
// the work if the data isn't printed.
|
|
type LogClosure func() string
|
|
|
|
func (c LogClosure) String() string {
|
|
return c()
|
|
}
|
|
|
|
// NewLogClosure casts a function to a LogClosure.
|
|
// See LogClosure for details.
|
|
func NewLogClosure(c func() string) LogClosure {
|
|
return c
|
|
}
|