forked from TrueCloudLab/neoneo-go
cli: make gas parameter to deployment add gas to the base price
That's how it was intended to behave originally. One thing questionable here is contract price (policy thing, basically) being moved to smartcontract package, but it's probably fine for NEO 2.0 (as it won't change) and we'll make something better for NEO 3.0.
This commit is contained in:
parent
695c4dd6ae
commit
bbd802681e
4 changed files with 46 additions and 26 deletions
|
@ -44,7 +44,7 @@ var (
|
||||||
}
|
}
|
||||||
gasFlag = cli.Float64Flag{
|
gasFlag = cli.Float64Flag{
|
||||||
Name: "gas, g",
|
Name: "gas, g",
|
||||||
Usage: "gas to pay for transaction",
|
Usage: "gas to add to the transaction",
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -88,6 +88,12 @@ func NewCommands() []cli.Command {
|
||||||
{
|
{
|
||||||
Name: "deploy",
|
Name: "deploy",
|
||||||
Usage: "deploy a smart contract (.avm with description)",
|
Usage: "deploy a smart contract (.avm with description)",
|
||||||
|
Description: `Deploys given contract into the chain. The gas parameter is for additional
|
||||||
|
gas to be added as a network fee to prioritize the transaction. It may also
|
||||||
|
be required to add that to satisfy chain's policy regarding transaction size
|
||||||
|
and the minimum size fee (so if transaction send fails, try adding 0.001 GAS
|
||||||
|
to it).
|
||||||
|
`,
|
||||||
Action: contractDeploy,
|
Action: contractDeploy,
|
||||||
Flags: []cli.Flag{
|
Flags: []cli.Flag{
|
||||||
cli.StringFlag{
|
cli.StringFlag{
|
||||||
|
@ -583,6 +589,8 @@ func contractDeploy(ctx *cli.Context) error {
|
||||||
return cli.NewExitError(fmt.Errorf("failed to create deployment script: %v", err), 1)
|
return cli.NewExitError(fmt.Errorf("failed to create deployment script: %v", err), 1)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gas += smartcontract.GetDeploymentPrice(request.DetailsToSCProperties(&conf.Contract))
|
||||||
|
|
||||||
txHash, err := c.SignAndPushInvocationTx(txScript, wif, gas)
|
txHash, err := c.SignAndPushInvocationTx(txScript, wif, gas)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return cli.NewExitError(fmt.Errorf("failed to push invocation tx: %v", err), 1)
|
return cli.NewExitError(fmt.Errorf("failed to push invocation tx: %v", err), 1)
|
||||||
|
|
|
@ -93,18 +93,7 @@ func getSyscallPrice(v *vm.VM, id uint32) util.Fixed8 {
|
||||||
arg := estack.Peek(1).BigInt().Int64()
|
arg := estack.Peek(1).BigInt().Int64()
|
||||||
return util.Fixed8FromInt64(arg * 5000)
|
return util.Fixed8FromInt64(arg * 5000)
|
||||||
case neoContractCreate, neoContractMigrate, antSharesContractCreate, antSharesContractMigrate:
|
case neoContractCreate, neoContractMigrate, antSharesContractCreate, antSharesContractMigrate:
|
||||||
fee := int64(100)
|
return smartcontract.GetDeploymentPrice(smartcontract.PropertyState(estack.Peek(3).BigInt().Int64()))
|
||||||
props := smartcontract.PropertyState(estack.Peek(3).BigInt().Int64())
|
|
||||||
|
|
||||||
if props&smartcontract.HasStorage != 0 {
|
|
||||||
fee += 400
|
|
||||||
}
|
|
||||||
|
|
||||||
if props&smartcontract.HasDynamicInvoke != 0 {
|
|
||||||
fee += 500
|
|
||||||
}
|
|
||||||
|
|
||||||
return util.Fixed8FromInt64(fee)
|
|
||||||
case systemStoragePut, systemStoragePutEx, neoStoragePut, antSharesStoragePut:
|
case systemStoragePut, systemStoragePutEx, neoStoragePut, antSharesStoragePut:
|
||||||
// price for storage PUT is 1 GAS per 1 KiB
|
// price for storage PUT is 1 GAS per 1 KiB
|
||||||
keySize := len(estack.Peek(1).Bytes())
|
keySize := len(estack.Peek(1).Bytes())
|
||||||
|
|
|
@ -80,17 +80,10 @@ func AddInputsAndUnspentsToTx(tx *transaction.Transaction, addr string, assetID
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// CreateDeploymentScript returns a script that deploys given smart contract
|
// DetailsToSCProperties extract the fields needed from ContractDetails
|
||||||
// with its metadata.
|
// and converts them to smartcontract.PropertyState.
|
||||||
func CreateDeploymentScript(avm []byte, contract *ContractDetails) ([]byte, error) {
|
func DetailsToSCProperties(contract *ContractDetails) smartcontract.PropertyState {
|
||||||
var props smartcontract.PropertyState
|
var props smartcontract.PropertyState
|
||||||
|
|
||||||
script := io.NewBufBinWriter()
|
|
||||||
emit.Bytes(script.BinWriter, []byte(contract.Description))
|
|
||||||
emit.Bytes(script.BinWriter, []byte(contract.Email))
|
|
||||||
emit.Bytes(script.BinWriter, []byte(contract.Author))
|
|
||||||
emit.Bytes(script.BinWriter, []byte(contract.Version))
|
|
||||||
emit.Bytes(script.BinWriter, []byte(contract.ProjectName))
|
|
||||||
if contract.HasStorage {
|
if contract.HasStorage {
|
||||||
props |= smartcontract.HasStorage
|
props |= smartcontract.HasStorage
|
||||||
}
|
}
|
||||||
|
@ -100,7 +93,19 @@ func CreateDeploymentScript(avm []byte, contract *ContractDetails) ([]byte, erro
|
||||||
if contract.IsPayable {
|
if contract.IsPayable {
|
||||||
props |= smartcontract.IsPayable
|
props |= smartcontract.IsPayable
|
||||||
}
|
}
|
||||||
emit.Int(script.BinWriter, int64(props))
|
return props
|
||||||
|
}
|
||||||
|
|
||||||
|
// CreateDeploymentScript returns a script that deploys given smart contract
|
||||||
|
// with its metadata.
|
||||||
|
func CreateDeploymentScript(avm []byte, contract *ContractDetails) ([]byte, error) {
|
||||||
|
script := io.NewBufBinWriter()
|
||||||
|
emit.Bytes(script.BinWriter, []byte(contract.Description))
|
||||||
|
emit.Bytes(script.BinWriter, []byte(contract.Email))
|
||||||
|
emit.Bytes(script.BinWriter, []byte(contract.Author))
|
||||||
|
emit.Bytes(script.BinWriter, []byte(contract.Version))
|
||||||
|
emit.Bytes(script.BinWriter, []byte(contract.ProjectName))
|
||||||
|
emit.Int(script.BinWriter, int64(DetailsToSCProperties(contract)))
|
||||||
emit.Int(script.BinWriter, int64(contract.ReturnType))
|
emit.Int(script.BinWriter, int64(contract.ReturnType))
|
||||||
params := make([]byte, len(contract.Parameters))
|
params := make([]byte, len(contract.Parameters))
|
||||||
for k := range contract.Parameters {
|
for k := range contract.Parameters {
|
||||||
|
|
18
pkg/smartcontract/deployment_price.go
Normal file
18
pkg/smartcontract/deployment_price.go
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
package smartcontract
|
||||||
|
|
||||||
|
import "github.com/nspcc-dev/neo-go/pkg/util"
|
||||||
|
|
||||||
|
// GetDeploymentPrice returns contract deployment price based on its properties.
|
||||||
|
func GetDeploymentPrice(props PropertyState) util.Fixed8 {
|
||||||
|
fee := int64(100)
|
||||||
|
|
||||||
|
if props&HasStorage != 0 {
|
||||||
|
fee += 400
|
||||||
|
}
|
||||||
|
|
||||||
|
if props&HasDynamicInvoke != 0 {
|
||||||
|
fee += 500
|
||||||
|
}
|
||||||
|
|
||||||
|
return util.Fixed8FromInt64(fee)
|
||||||
|
}
|
Loading…
Reference in a new issue