mirror of
				https://github.com/kaspanet/kaspad.git
				synced 2025-10-14 00:59:33 +00:00 
			
		
		
		
	 40342eb45a
			
		
	
	
		40342eb45a
		
	
	
	
	
		
			
			* [NOD-275] Moved getBlockTemplate and related functionality to a separate file. * [NOD-275] Started moving handlers to separate files. * [NOD-275] Fixed merge errors. * [NOD-275] Moved all handlers out of rpcserver.go. * [NOD-275] Moved non-shared functions out of rpcserver.go. * [NOD-275] Moved handleGetAllManualNodesInfo to a separate file. * [NOD-275] Moved handlers out of rpcwebsocket.go to separate files. * [NOD-275] Fixed import error. * [NOD-275] Renamed all handler files to include underscores. * [NOD-275] Moved common rpc helper functions to common.go.
		
			
				
	
	
		
			115 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			115 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package rpc
 | |
| 
 | |
| import (
 | |
| 	"github.com/daglabs/btcd/btcjson"
 | |
| 	"github.com/daglabs/btcd/util/network"
 | |
| 	"net"
 | |
| 	"strconv"
 | |
| )
 | |
| 
 | |
| // handleNode handles node commands.
 | |
| func handleNode(s *Server, cmd interface{}, closeChan <-chan struct{}) (interface{}, error) {
 | |
| 	c := cmd.(*btcjson.NodeCmd)
 | |
| 
 | |
| 	var addr string
 | |
| 	var nodeID uint64
 | |
| 	var errN, err error
 | |
| 	params := s.cfg.DAGParams
 | |
| 	switch c.SubCmd {
 | |
| 	case "disconnect":
 | |
| 		// If we have a valid uint disconnect by node id. Otherwise,
 | |
| 		// attempt to disconnect by address, returning an error if a
 | |
| 		// valid IP address is not supplied.
 | |
| 		if nodeID, errN = strconv.ParseUint(c.Target, 10, 32); errN == nil {
 | |
| 			err = s.cfg.ConnMgr.DisconnectByID(int32(nodeID))
 | |
| 		} else {
 | |
| 			if _, _, errP := net.SplitHostPort(c.Target); errP == nil || net.ParseIP(c.Target) != nil {
 | |
| 				addr = network.NormalizeAddress(c.Target, params.DefaultPort)
 | |
| 				err = s.cfg.ConnMgr.DisconnectByAddr(addr)
 | |
| 			} else {
 | |
| 				return nil, &btcjson.RPCError{
 | |
| 					Code:    btcjson.ErrRPCInvalidParameter,
 | |
| 					Message: "invalid address or node ID",
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 		if err != nil && peerExists(s.cfg.ConnMgr, addr, int32(nodeID)) {
 | |
| 
 | |
| 			return nil, &btcjson.RPCError{
 | |
| 				Code:    btcjson.ErrRPCMisc,
 | |
| 				Message: "can't disconnect a permanent peer, use remove",
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 	case "remove":
 | |
| 		// If we have a valid uint disconnect by node id. Otherwise,
 | |
| 		// attempt to disconnect by address, returning an error if a
 | |
| 		// valid IP address is not supplied.
 | |
| 		if nodeID, errN = strconv.ParseUint(c.Target, 10, 32); errN == nil {
 | |
| 			err = s.cfg.ConnMgr.RemoveByID(int32(nodeID))
 | |
| 		} else {
 | |
| 			if _, _, errP := net.SplitHostPort(c.Target); errP == nil || net.ParseIP(c.Target) != nil {
 | |
| 				addr = network.NormalizeAddress(c.Target, params.DefaultPort)
 | |
| 				err = s.cfg.ConnMgr.RemoveByAddr(addr)
 | |
| 			} else {
 | |
| 				return nil, &btcjson.RPCError{
 | |
| 					Code:    btcjson.ErrRPCInvalidParameter,
 | |
| 					Message: "invalid address or node ID",
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 		if err != nil && peerExists(s.cfg.ConnMgr, addr, int32(nodeID)) {
 | |
| 			return nil, &btcjson.RPCError{
 | |
| 				Code:    btcjson.ErrRPCMisc,
 | |
| 				Message: "can't remove a temporary peer, use disconnect",
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 	case "connect":
 | |
| 		addr = network.NormalizeAddress(c.Target, params.DefaultPort)
 | |
| 
 | |
| 		// Default to temporary connections.
 | |
| 		subCmd := "temp"
 | |
| 		if c.ConnectSubCmd != nil {
 | |
| 			subCmd = *c.ConnectSubCmd
 | |
| 		}
 | |
| 
 | |
| 		switch subCmd {
 | |
| 		case "perm", "temp":
 | |
| 			err = s.cfg.ConnMgr.Connect(addr, subCmd == "perm")
 | |
| 		default:
 | |
| 			return nil, &btcjson.RPCError{
 | |
| 				Code:    btcjson.ErrRPCInvalidParameter,
 | |
| 				Message: "invalid subcommand for node connect",
 | |
| 			}
 | |
| 		}
 | |
| 	default:
 | |
| 		return nil, &btcjson.RPCError{
 | |
| 			Code:    btcjson.ErrRPCInvalidParameter,
 | |
| 			Message: "invalid subcommand for node",
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if err != nil {
 | |
| 		return nil, &btcjson.RPCError{
 | |
| 			Code:    btcjson.ErrRPCInvalidParameter,
 | |
| 			Message: err.Error(),
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	// no data returned unless an error.
 | |
| 	return nil, nil
 | |
| }
 | |
| 
 | |
| // peerExists determines if a certain peer is currently connected given
 | |
| // information about all currently connected peers. Peer existence is
 | |
| // determined using either a target address or node id.
 | |
| func peerExists(connMgr rpcserverConnManager, addr string, nodeID int32) bool {
 | |
| 	for _, p := range connMgr.ConnectedPeers() {
 | |
| 		if p.ToPeer().ID() == nodeID || p.ToPeer().Addr() == addr {
 | |
| 			return true
 | |
| 		}
 | |
| 	}
 | |
| 	return false
 | |
| }
 |