kaspad/infrastructure/network/rpc/handle_get_subnetwork.go
stasatdaglabs d14809694f
[NOD-1223] Reorganize directory structure (#874)
* [NOD-1223] Delete unused files/packages.

* [NOD-1223] Move signal and limits to the os package.

* [NOD-1223] Put database and dbaccess into the db package.

* [NOD-1223] Fold the logs package into the logger package.

* [NOD-1223] Rename domainmessage to appmessage.

* [NOD-1223] Rename to/from DomainMessage to AppMessage.

* [NOD-1223] Move appmessage to the app packge.

* [NOD-1223] Move protocol to the app packge.

* [NOD-1223] Move the network package to the infrastructure packge.

* [NOD-1223] Rename cmd to executables.

* [NOD-1223] Fix go.doc in the logger package.
2020-08-18 10:26:39 +03:00

34 lines
842 B
Go

package rpc
import (
"github.com/kaspanet/kaspad/infrastructure/network/rpc/model"
"github.com/kaspanet/kaspad/util/subnetworkid"
)
// handleGetSubnetwork handles the getSubnetwork command.
func handleGetSubnetwork(s *Server, cmd interface{}, closeChan <-chan struct{}) (interface{}, error) {
c := cmd.(*model.GetSubnetworkCmd)
subnetworkID, err := subnetworkid.NewFromStr(c.SubnetworkID)
if err != nil {
return nil, rpcDecodeHexError(c.SubnetworkID)
}
var gasLimit *uint64
if !subnetworkID.IsBuiltInOrNative() {
limit, err := s.dag.GasLimit(subnetworkID)
if err != nil {
return nil, &model.RPCError{
Code: model.ErrRPCSubnetworkNotFound,
Message: "Subnetwork not found.",
}
}
gasLimit = &limit
}
subnetworkReply := &model.GetSubnetworkResult{
GasLimit: gasLimit,
}
return subnetworkReply, nil
}