/
log_ui.go
52 lines (45 loc) · 1.27 KB
/
log_ui.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
// Auto-generated to Go types and interfaces using avdl-compiler v1.4.10 (https://github.com/keybase/node-avdl-compiler)
// Input file: avdl/keybase1/log_ui.avdl
package keybase1
import (
"github.com/keybase/go-framed-msgpack-rpc/rpc"
context "golang.org/x/net/context"
"time"
)
type LogArg struct {
SessionID int `codec:"sessionID" json:"sessionID"`
Level LogLevel `codec:"level" json:"level"`
Text Text `codec:"text" json:"text"`
}
type LogUiInterface interface {
Log(context.Context, LogArg) error
}
func LogUiProtocol(i LogUiInterface) rpc.Protocol {
return rpc.Protocol{
Name: "keybase.1.logUi",
Methods: map[string]rpc.ServeHandlerDescription{
"log": {
MakeArg: func() interface{} {
var ret [1]LogArg
return &ret
},
Handler: func(ctx context.Context, args interface{}) (ret interface{}, err error) {
typedArgs, ok := args.(*[1]LogArg)
if !ok {
err = rpc.NewTypeError((*[1]LogArg)(nil), args)
return
}
err = i.Log(ctx, typedArgs[0])
return
},
},
},
}
}
type LogUiClient struct {
Cli rpc.GenericClient
}
func (c LogUiClient) Log(ctx context.Context, __arg LogArg) (err error) {
err = c.Cli.Call(ctx, "keybase.1.logUi.log", []interface{}{__arg}, nil, 0*time.Millisecond)
return
}