Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(gnovm, tm2): implement event emission with std.Emit #1653

Merged
merged 65 commits into from
Apr 30, 2024
Merged
Show file tree
Hide file tree
Changes from 30 commits
Commits
Show all changes
65 commits
Select commit Hold shift + click to select a range
c67e718
[WIP] feat(gnovm, tm2): Yet Another Emit/Event
notJoon Feb 13, 2024
d7cb7d9
add test for e&e and change file names
notJoon Feb 22, 2024
94ab8ef
Merge branch 'master' into emit-event
notJoon Mar 26, 2024
c06f079
fixup
notJoon Mar 26, 2024
5360fa9
feat: EmitEvent in gno
r3v4s Mar 28, 2024
79f5752
fmt
notJoon Mar 29, 2024
fd84dc5
Merge branch 'master' into emit-event
notJoon Apr 1, 2024
35ef5f8
Event holds more metadata
notJoon Apr 1, 2024
0afd6cd
run go generate
notJoon Apr 1, 2024
6625e7e
fix lint error
notJoon Apr 1, 2024
2a87886
Merge branch 'master' into emit-event
notJoon Apr 2, 2024
d7f1fed
pkgPath in Events
notJoon Apr 2, 2024
2a6084a
re-organize code
notJoon Apr 2, 2024
97e2c07
print attribute
notJoon Apr 2, 2024
860e9bd
print metadata finish
notJoon Apr 2, 2024
63c5829
fix CI failing
notJoon Apr 2, 2024
943ac20
Merge branch 'master' into emit-event
notJoon Apr 3, 2024
866250e
change timestamp to expose the block header data
notJoon Apr 11, 2024
2a99d96
Merge branch 'master' into emit-event
notJoon Apr 11, 2024
3e5636b
fix failing error
notJoon Apr 11, 2024
be033a7
remove height, don't panic
notJoon Apr 12, 2024
52e5412
expose function name
notJoon Apr 12, 2024
1a9a524
save
notJoon Apr 12, 2024
f054d67
event stringfy
notJoon Apr 12, 2024
2adfdd7
fix CI
notJoon Apr 12, 2024
ebb387a
json style event string
notJoon Apr 13, 2024
bb80a2e
Update gnovm/tests/file.go
notJoon Apr 17, 2024
61bc407
fix: apply suggestions
notJoon Apr 17, 2024
e76e231
fix: apply suggestions
notJoon Apr 17, 2024
87d4d9e
Merge branch 'master' into emit-event
notJoon Apr 17, 2024
929eb6d
fix: resolve simple comments
notJoon Apr 18, 2024
49f1d84
moving previous DetailedEvent type into gnovm dir and renamed it
notJoon Apr 18, 2024
9b183fb
valid json
notJoon Apr 18, 2024
d2a0c98
fix: lint, remove leftover
notJoon Apr 18, 2024
59c020f
fix: apply some comments
notJoon Apr 19, 2024
13d7b4f
use EventString
notJoon Apr 19, 2024
9f726ca
remove leftover
notJoon Apr 19, 2024
271651a
Update gnovm/stdlibs/std/emit_event.go
notJoon Apr 22, 2024
b207069
Update gnovm/stdlibs/std/emit_event.go
notJoon Apr 22, 2024
d1c28cc
Update tm2/pkg/bft/abci/types/types.go
notJoon Apr 22, 2024
849ac83
Merge branch 'master' into emit-event
notJoon Apr 22, 2024
2e9d9ed
add very basic test
notJoon Apr 22, 2024
1d83801
add more tests
notJoon Apr 23, 2024
2ab7577
Update gnovm/stdlibs/std/emit_event.go
moul Apr 23, 2024
5a16ac6
explicit regex, remove unnecessary marshaling step.
notJoon Apr 23, 2024
ffb66ae
update comment
notJoon Apr 23, 2024
e49793a
store result to EventString
notJoon Apr 23, 2024
ff0877f
Update tm2/pkg/crypto/keys/client/maketx.go
moul Apr 24, 2024
8ddfd0f
Update gno.land/cmd/gnoland/testdata/event.txtar
notJoon Apr 24, 2024
55b6704
Update gnovm/stdlibs/std/emit_event_test.go
notJoon Apr 24, 2024
a7ae1a7
Update gnovm/stdlibs/std/native.go
notJoon Apr 24, 2024
191c130
Update gnovm/stdlibs/std/emit_event.gno
notJoon Apr 24, 2024
1474c0d
Update gnovm/stdlibs/std/context.go
notJoon Apr 24, 2024
150fe46
no regex
notJoon Apr 24, 2024
ed5f542
fixup (maybe)
notJoon Apr 25, 2024
67a40e2
fixup
notJoon Apr 25, 2024
ae5292a
Merge branch 'emit-event' of https://github.com/notJoon/gno-core into…
notJoon Apr 25, 2024
6cd31f1
fix: CI failing
notJoon Apr 25, 2024
c8219e4
Apply suggestions from code review
moul Apr 26, 2024
7e391a9
change field name and remove EmittedEvents, no global consst in test
notJoon Apr 29, 2024
96f7ca5
panic
notJoon Apr 29, 2024
0358dd6
Merge branch 'master' into emit-event
notJoon Apr 29, 2024
317108a
func name change
notJoon Apr 29, 2024
b0d9b28
Merge branch 'master' into emit-event
moul Apr 29, 2024
7a5fd74
use attrs for field name and change to use loadpkg
notJoon Apr 30, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion gno.land/cmd/gnoland/testdata/addpkg.txtar
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,8 @@ gnokey maketx call -pkgpath gno.land/r/foobar/bar -func Render -gas-fee 1000000u
stdout '("hello from foo" string)'
stdout 'OK!'
stdout 'GAS WANTED: 2000000'
stdout 'GAS USED: [0-9]+'
stdout 'GAS USED: \d+'
stdout 'EVENTS:'
thehowl marked this conversation as resolved.
Show resolved Hide resolved

-- bar.gno --
package bar
Expand Down
42 changes: 42 additions & 0 deletions gno.land/cmd/gnoland/testdata/event.txtar
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
# start a new node
gnoland start

gnokey maketx addpkg -pkgdir $WORK -pkgpath gno.land/r/demo/ee -gas-fee 1000000ugnot -gas-wanted 2000000 -broadcast -chainid=tendermint_test test1
stdout OK!

gnokey maketx call -pkgpath gno.land/r/demo/ee -func Hello -gas-fee 1000000ugnot -gas-wanted 2000000 -broadcast -chainid=tendermint_test test1
notJoon marked this conversation as resolved.
Show resolved Hide resolved
stdout OK!
stdout 'GAS WANTED: 2000000'
stdout 'GAS USED: [0-9]+'
stdout 'EVENTS:'

-- ee.gno --
package ee

import (
"std"
)

const (
EventAttrKeySender = "sender"
EventAttrKeyReceiver = "receiver"
)

func Hello() {
std.Emit(
EventAttrKeySender,
[]string{
"key1", "value1",
"key2", "value2",
"key3", "value3",
"not-a-pair", // ignore the key-value not in pairs
notJoon marked this conversation as resolved.
Show resolved Hide resolved
},
)

std.Emit(
EventAttrKeyReceiver,
[]string{
"foo", "bar",
},
)
}
5 changes: 5 additions & 0 deletions gno.land/pkg/sdk/vm/keeper.go
Original file line number Diff line number Diff line change
Expand Up @@ -186,6 +186,7 @@
OrigSendSpent: new(std.Coins),
OrigPkgAddr: pkgAddr.Bech32(),
Banker: NewSDKBanker(vm, ctx),
EventLogger: ctx.EventLogger(),
}
// Parse and run the files, construct *PV.
m2 := gno.NewMachineWithOptions(
Expand Down Expand Up @@ -263,6 +264,7 @@
OrigSendSpent: new(std.Coins),
OrigPkgAddr: pkgAddr.Bech32(),
Banker: NewSDKBanker(vm, ctx),
EventLogger: ctx.EventLogger(),
}
// Construct machine and evaluate.
m := gno.NewMachineWithOptions(
Expand Down Expand Up @@ -334,6 +336,7 @@
OrigSendSpent: new(std.Coins),
OrigPkgAddr: pkgAddr.Bech32(),
Banker: NewSDKBanker(vm, ctx),
EventLogger: ctx.EventLogger(),
}
// Parse and run the files, construct *PV.
buf := new(bytes.Buffer)
Expand Down Expand Up @@ -463,6 +466,7 @@
// OrigSendSpent: nil,
OrigPkgAddr: pkgAddr.Bech32(),
Banker: NewSDKBanker(vm, ctx), // safe as long as ctx is a fork to be discarded.
EventLogger: ctx.EventLogger(),

Check warning on line 469 in gno.land/pkg/sdk/vm/keeper.go

View check run for this annotation

Codecov / codecov/patch

gno.land/pkg/sdk/vm/keeper.go#L469

Added line #L469 was not covered by tests
}
m := gno.NewMachineWithOptions(
gno.MachineOptions{
Expand Down Expand Up @@ -523,6 +527,7 @@
// OrigSendSpent: nil,
OrigPkgAddr: pkgAddr.Bech32(),
Banker: NewSDKBanker(vm, ctx), // safe as long as ctx is a fork to be discarded.
EventLogger: ctx.EventLogger(),

Check warning on line 530 in gno.land/pkg/sdk/vm/keeper.go

View check run for this annotation

Codecov / codecov/patch

gno.land/pkg/sdk/vm/keeper.go#L530

Added line #L530 was not covered by tests
}
m := gno.NewMachineWithOptions(
gno.MachineOptions{
Expand Down
25 changes: 25 additions & 0 deletions gnovm/stdlibs/native.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions gnovm/stdlibs/std/context.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,4 +17,5 @@ type ExecContext struct {
OrigSend std.Coins
OrigSendSpent *std.Coins // mutable
Banker BankerInterface
EventLogger *sdk.EventLogger
}
4 changes: 4 additions & 0 deletions gnovm/stdlibs/std/emit_event.gno
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
package std

func Emit(typ string, attrs []string) { emitEvent(typ, attrs) }
notJoon marked this conversation as resolved.
Show resolved Hide resolved
func emitEvent(typ string, attrs []string)
notJoon marked this conversation as resolved.
Show resolved Hide resolved
29 changes: 29 additions & 0 deletions gnovm/stdlibs/std/emit_event.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
package std

// ref: https://github.com/gnolang/gno/pull/853
notJoon marked this conversation as resolved.
Show resolved Hide resolved

import (
gno "github.com/gnolang/gno/gnovm/pkg/gnolang"
"github.com/gnolang/gno/tm2/pkg/sdk"
)

func X_emitEvent(m *gno.Machine, typ string, attrs []string) {
attrLen := len(attrs)
eventAttrs := make([]sdk.EventAttribute, attrLen/2)
pkgPath := CurrentRealmPath(m)
zivkovicmilos marked this conversation as resolved.
Show resolved Hide resolved
fnIdent := GetFuncNameFromCallStack(m)

for i := 0; i < attrLen-1; i += 2 {
eventAttrs[i/2] = sdk.EventAttribute{
Key: attrs[i],
Value: attrs[i+1],
}
}

timestamp := GetTimestamp(m)
notJoon marked this conversation as resolved.
Show resolved Hide resolved

event := sdk.CreateDetailedEvent(typ, pkgPath, fnIdent, timestamp, eventAttrs...)

ctx := m.Context.(ExecContext)
ctx.EventLogger.EmitEvent(event)
}
12 changes: 12 additions & 0 deletions gnovm/stdlibs/std/native.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,18 @@ func GetHeight(m *gno.Machine) int64 {
return m.Context.(ExecContext).Height
}

func GetTimestamp(m *gno.Machine) int64 {
return m.Context.(ExecContext).Timestamp
}

// GetFuncNameFromCallStack returns the last called function name (identifier) from the call stack.
func GetFuncNameFromCallStack(m *gno.Machine) string {
if len(m.Frames) == 0 {
return ""
}
return string(m.Frames[0].Func.Name)
notJoon marked this conversation as resolved.
Show resolved Hide resolved
}

notJoon marked this conversation as resolved.
Show resolved Hide resolved
func X_origSend(m *gno.Machine) (denoms []string, amounts []int64) {
os := m.Context.(ExecContext).OrigSend
return ExpandCoins(os)
Expand Down
2 changes: 2 additions & 0 deletions gnovm/tests/file.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ import (
"github.com/gnolang/gno/gnovm/stdlibs"
"github.com/gnolang/gno/tm2/pkg/crypto"
osm "github.com/gnolang/gno/tm2/pkg/os"
"github.com/gnolang/gno/tm2/pkg/sdk"
"github.com/gnolang/gno/tm2/pkg/std"
"github.com/pmezard/go-difflib/difflib"
)
Expand Down Expand Up @@ -50,6 +51,7 @@ func testMachineCustom(store gno.Store, pkgPath string, stdout io.Writer, maxAll
OrigSend: send,
OrigSendSpent: new(std.Coins),
Banker: banker,
EventLogger: sdk.NewEventLogger(),
}
m := gno.NewMachineWithOptions(gno.MachineOptions{
PkgPath: "", // set later.
Expand Down
2 changes: 1 addition & 1 deletion gnovm/tests/files/zrealm_natbind0.gno
Original file line number Diff line number Diff line change
Expand Up @@ -141,7 +141,7 @@ func main() {
// "Closure": {
// "@type": "/gno.RefValue",
// "Escaped": true,
// "ObjectID": "a7f5397443359ea76c50be82c77f1f893a060925:6"
// "ObjectID": "a7f5397443359ea76c50be82c77f1f893a060925:7"
// },
// "FileName": "native.gno",
// "IsMethod": false,
Expand Down
32 changes: 32 additions & 0 deletions tm2/pkg/bft/abci/types/types.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package abci

import (
"strings"
"time"

"github.com/gnolang/gno/tm2/pkg/crypto"
Expand Down Expand Up @@ -116,6 +117,32 @@ func (r ResponseBase) IsErr() bool {
return r.Error != nil
}

func (r ResponseBase) EventString() string {
notJoon marked this conversation as resolved.
Show resolved Hide resolved
levts := len(r.Events)
if levts == 0 {
return `""`
}

var builder strings.Builder

if levts > 1 {
builder.WriteString("[")
}

for i, event := range r.Events {
if i > 0 {
builder.WriteString(",")
}
builder.WriteString(event.String())
}

if levts > 1 {
builder.WriteString("]")
}
notJoon marked this conversation as resolved.
Show resolved Hide resolved

return builder.String()
}
notJoon marked this conversation as resolved.
Show resolved Hide resolved

// nondeterministic
type ResponseException struct {
ResponseBase
Expand Down Expand Up @@ -193,6 +220,7 @@ type Error interface {
}

type Event interface {
String() string
AssertABCIEvent()
}

Expand Down Expand Up @@ -225,6 +253,10 @@ func (err EventString) Event() string {
return string(err)
}

func (err EventString) String() string {
return string(err)
}

// ----------------------------------------
// Misc

Expand Down
3 changes: 2 additions & 1 deletion tm2/pkg/crypto/keys/client/maketx.go
Original file line number Diff line number Diff line change
Expand Up @@ -180,7 +180,8 @@ func ExecSignAndBroadcast(
io.Println(string(bres.DeliverTx.Data))
io.Println("OK!")
io.Println("GAS WANTED:", bres.DeliverTx.GasWanted)
io.Println("GAS USED: ", bres.DeliverTx.GasUsed)
io.Println("GAS USED:", bres.DeliverTx.GasUsed)
io.Println("EVENTS:", bres.DeliverTx.EventString())

zivkovicmilos marked this conversation as resolved.
Show resolved Hide resolved
return nil
}
1 change: 1 addition & 0 deletions tm2/pkg/sdk/baseapp.go
Original file line number Diff line number Diff line change
Expand Up @@ -653,6 +653,7 @@ func (app *BaseApp) runMsgs(ctx Context, msgs []Msg, mode RunTxMode) (result Res
// each result.
data = append(data, msgResult.Data...)
events = append(events, msgResult.Events...)
events = append(events, ctx.EventLogger().Events()...)
notJoon marked this conversation as resolved.
Show resolved Hide resolved
// TODO append msgevent from ctx. XXX XXX

// stop execution and return on first failed message
Expand Down
43 changes: 43 additions & 0 deletions tm2/pkg/sdk/events.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
package sdk

import (
"encoding/json"
"fmt"

abci "github.com/gnolang/gno/tm2/pkg/bft/abci/types"
)

Expand Down Expand Up @@ -35,3 +38,43 @@ func (em *EventLogger) EmitEvents(events []Event) {
// ----------------------------------------------------------------------------

type Event = abci.Event

type DetailedEvent struct {
notJoon marked this conversation as resolved.
Show resolved Hide resolved
Type string // type of event
PkgPath string // event occurred package path
Identifier string // event occurred function identifier
Timestamp int64
Attributes []EventAttribute // list of event attributes (comma separated key-value pairs)
}

func CreateDetailedEvent(eventType string, pkgPath string, ident string, timestamp int64, attrs ...EventAttribute) Event {
notJoon marked this conversation as resolved.
Show resolved Hide resolved
return DetailedEvent{
Type: eventType,
PkgPath: pkgPath,
Identifier: ident,
Attributes: attrs,
Timestamp: timestamp,
}
}

func (e DetailedEvent) AssertABCIEvent() {}

func (e DetailedEvent) String() string {
result, err := json.Marshal(e)
if err != nil {
return fmt.Sprintf("Error marshalling event: %v", err)
}
return string(result)
}

type EventAttribute struct {
Key string
Value string
}

func NewEventAttribute(key, value string) EventAttribute {
notJoon marked this conversation as resolved.
Show resolved Hide resolved
return EventAttribute{
Key: key,
Value: value,
}
}
2 changes: 2 additions & 0 deletions tm2/pkg/sdk/package.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,4 +15,6 @@ var Package = amino.RegisterPackage(amino.NewPackage(
).
WithTypes(
Result{},
DetailedEvent{},
EventAttribute{},
notJoon marked this conversation as resolved.
Show resolved Hide resolved
))
2 changes: 1 addition & 1 deletion tm2/pkg/sdk/sdk.proto
Original file line number Diff line number Diff line change
Expand Up @@ -12,4 +12,4 @@ message Result {
abci.ResponseBase response_base = 1 [json_name = "ResponseBase"];
sint64 gas_wanted = 2 [json_name = "GasWanted"];
sint64 gas_used = 3 [json_name = "GasUsed"];
}
}
Loading