forked from keybase/client
/
secretkeys.go
43 lines (37 loc) · 1.16 KB
/
secretkeys.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
// Copyright 2015 Keybase, Inc. All rights reserved. Use of
// this source code is governed by the included BSD license.
package service
import (
"errors"
"github.com/keybase/client/go/engine"
"github.com/keybase/client/go/libkb"
keybase1 "github.com/keybase/client/go/protocol/keybase1"
"github.com/keybase/go-framed-msgpack-rpc/rpc"
"golang.org/x/net/context"
)
type SecretKeysHandler struct {
*BaseHandler
libkb.Contextified
}
func NewSecretKeysHandler(xp rpc.Transporter, g *libkb.GlobalContext) *SecretKeysHandler {
return &SecretKeysHandler{
BaseHandler: NewBaseHandler(g, xp),
Contextified: libkb.NewContextified(g),
}
}
func (h *SecretKeysHandler) GetSecretKeys(_ context.Context, sessionID int) (keybase1.SecretKeys, error) {
if h.G().Env.GetRunMode() == libkb.ProductionRunMode {
return keybase1.SecretKeys{}, errors.New("GetSecretKeys is a devel-only RPC")
}
ctx := engine.Context{
LogUI: h.getLogUI(sessionID),
SecretUI: h.getSecretUI(sessionID, h.G()),
SessionID: sessionID,
}
eng := engine.NewSecretKeysEngine(h.G())
err := engine.RunEngine(eng, &ctx)
if err != nil {
return keybase1.SecretKeys{}, err
}
return eng.Result(), nil
}