forked from ava-labs/hypersdk
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgenesis.go
136 lines (112 loc) · 4.09 KB
/
genesis.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
// Copyright (C) 2023, Ava Labs, Inc. All rights reserved.
// See the file LICENSE for licensing terms.
package genesis
import (
"context"
"encoding/json"
"fmt"
"github.com/ava-labs/avalanchego/trace"
"github.com/ava-labs/avalanchego/x/merkledb"
"github.com/ava-labs/hypersdk/codec"
"github.com/ava-labs/hypersdk/examples/morpheusvm/consts"
"github.com/ava-labs/hypersdk/examples/morpheusvm/storage"
"github.com/ava-labs/hypersdk/fees"
"github.com/ava-labs/hypersdk/state"
"github.com/ava-labs/hypersdk/vm"
smath "github.com/ava-labs/avalanchego/utils/math"
hconsts "github.com/ava-labs/hypersdk/consts"
)
var _ vm.Genesis = (*Genesis)(nil)
type CustomAllocation struct {
Address string `json:"address"` // bech32 address
Balance uint64 `json:"balance"`
}
type Genesis struct {
// State Parameters
StateBranchFactor merkledb.BranchFactor `json:"stateBranchFactor"`
// Chain Parameters
MinBlockGap int64 `json:"minBlockGap"` // ms
MinEmptyBlockGap int64 `json:"minEmptyBlockGap"` // ms
// Chain Fee Parameters
MinUnitPrice fees.Dimensions `json:"minUnitPrice"`
UnitPriceChangeDenominator fees.Dimensions `json:"unitPriceChangeDenominator"`
WindowTargetUnits fees.Dimensions `json:"windowTargetUnits"` // 10s
MaxBlockUnits fees.Dimensions `json:"maxBlockUnits"` // must be possible to reach before block too large
// Tx Parameters
ValidityWindow int64 `json:"validityWindow"` // ms
MaxActionsPerTx uint8 `json:"maxActionsPerTx"`
MaxOutputsPerAction uint8 `json:"maxOutputsPerAction"`
// Tx Fee Parameters
BaseComputeUnits uint64 `json:"baseUnits"`
StorageKeyReadUnits uint64 `json:"storageKeyReadUnits"`
StorageValueReadUnits uint64 `json:"storageValueReadUnits"` // per chunk
StorageKeyAllocateUnits uint64 `json:"storageKeyAllocateUnits"`
StorageValueAllocateUnits uint64 `json:"storageValueAllocateUnits"` // per chunk
StorageKeyWriteUnits uint64 `json:"storageKeyWriteUnits"`
StorageValueWriteUnits uint64 `json:"storageValueWriteUnits"` // per chunk
// Allocates
CustomAllocation []*CustomAllocation `json:"customAllocation"`
}
func Default() *Genesis {
return &Genesis{
// State Parameters
StateBranchFactor: merkledb.BranchFactor16,
// Chain Parameters
MinBlockGap: 100,
MinEmptyBlockGap: 750,
// Chain Fee Parameters
MinUnitPrice: fees.Dimensions{100, 100, 100, 100, 100},
UnitPriceChangeDenominator: fees.Dimensions{48, 48, 48, 48, 48},
WindowTargetUnits: fees.Dimensions{20_000_000, 1_000, 1_000, 1_000, 1_000},
MaxBlockUnits: fees.Dimensions{1_800_000, 2_000, 2_000, 2_000, 2_000},
// Tx Parameters
ValidityWindow: 60 * hconsts.MillisecondsPerSecond, // ms
MaxActionsPerTx: 16,
MaxOutputsPerAction: 1,
// Tx Fee Compute Parameters
BaseComputeUnits: 1,
// Tx Fee Storage Parameters
//
// TODO: tune this
StorageKeyReadUnits: 5,
StorageValueReadUnits: 2,
StorageKeyAllocateUnits: 20,
StorageValueAllocateUnits: 5,
StorageKeyWriteUnits: 10,
StorageValueWriteUnits: 3,
}
}
func New(b []byte, _ []byte /* upgradeBytes */) (*Genesis, error) {
g := Default()
if len(b) > 0 {
if err := json.Unmarshal(b, g); err != nil {
return nil, fmt.Errorf("failed to unmarshal config %s: %w", string(b), err)
}
}
return g, nil
}
func (g *Genesis) Load(ctx context.Context, tracer trace.Tracer, mu state.Mutable) error {
ctx, span := tracer.Start(ctx, "Genesis.Load")
defer span.End()
if err := g.StateBranchFactor.Valid(); err != nil {
return err
}
supply := uint64(0)
for _, alloc := range g.CustomAllocation {
addr, err := codec.ParseAddressBech32(consts.HRP, alloc.Address)
if err != nil {
return fmt.Errorf("%w: %s", err, alloc.Address)
}
supply, err = smath.Add64(supply, alloc.Balance)
if err != nil {
return err
}
if err := storage.SetBalance(ctx, mu, addr, alloc.Balance); err != nil {
return fmt.Errorf("%w: addr=%s, bal=%d", err, alloc.Address, alloc.Balance)
}
}
return nil
}
func (g *Genesis) GetStateBranchFactor() merkledb.BranchFactor {
return g.StateBranchFactor
}