/
saltpack_ui.go
93 lines (82 loc) · 2.85 KB
/
saltpack_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
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
// Copy of keybase client.SaltpackUI.
//
// Had to copy because SaltpackUI uses private variables
// that I could not initialize. Only changes are calls to
// keybase client and libkb functions.
package libsecrets
import (
"fmt"
"golang.org/x/net/context"
"github.com/keybase/client/go/client"
"github.com/keybase/client/go/libkb"
"github.com/keybase/client/go/protocol/keybase1"
)
type SaltpackUI struct {
libkb.Contextified
terminal libkb.TerminalUI
interactive bool
force bool
}
func (s *SaltpackUI) doNonInteractive(arg keybase1.SaltpackPromptForDecryptArg) error {
switch arg.Sender.SenderType {
case keybase1.SaltpackSenderType_TRACKING_BROKE:
if s.force {
s.G().Log.Warning("Tracking statement is broken for sender, but forcing through.")
return nil
}
return libkb.IdentifyFailedError{Assertion: arg.Sender.Username, Reason: "tracking broke"}
default:
return nil
}
}
func (s *SaltpackUI) doInteractive(arg keybase1.SaltpackPromptForDecryptArg) error {
var why string
def := libkb.PromptDefaultYes
switch arg.Sender.SenderType {
case keybase1.SaltpackSenderType_TRACKING_OK, keybase1.SaltpackSenderType_SELF:
return nil
case keybase1.SaltpackSenderType_NOT_TRACKED:
why = "The sender of this message is a Keybase user you don't track"
case keybase1.SaltpackSenderType_UNKNOWN:
why = "The sender of this message is unknown to Keybase"
case keybase1.SaltpackSenderType_ANONYMOUS:
why = "The sender of this message has chosen to remain anonymous"
case keybase1.SaltpackSenderType_TRACKING_BROKE:
why = "You track the sender of this message, but their tracking statement is broken"
def = libkb.PromptDefaultNo
}
why += ". Go ahead and decrypt?"
ok, err := s.terminal.PromptYesNo(client.PromptDescriptorDecryptInteractive, why, def)
if err != nil {
return err
}
if !ok {
return libkb.CanceledError{M: "decryption canceled"}
}
return nil
}
func (s *SaltpackUI) SaltpackPromptForDecrypt(_ context.Context, arg keybase1.SaltpackPromptForDecryptArg) (err error) {
if !s.interactive {
return s.doNonInteractive(arg)
}
return s.doInteractive(arg)
}
func (s *SaltpackUI) SaltpackVerifySuccess(_ context.Context, arg keybase1.SaltpackVerifySuccessArg) error {
// write messages to stderr
w := s.terminal.ErrorWriter()
var un string
if arg.Sender.SenderType == keybase1.SaltpackSenderType_UNKNOWN {
un = "The signer of this message is unknown to Keybase"
} else {
var you string
if arg.Sender.SenderType == keybase1.SaltpackSenderType_SELF {
you = " (you)"
}
un = fmt.Sprintf("Signed by %s%s", client.ColorString("bold", arg.Sender.Username), you)
}
fmt.Fprintf(w, client.ColorString("green", fmt.Sprintf("Signature verified. %s.\n", un)))
if arg.Sender.SenderType == keybase1.SaltpackSenderType_UNKNOWN {
fmt.Fprintf(w, client.ColorString("green", fmt.Sprintf("Signing key ID: %s.\n", arg.SigningKID)))
}
return nil
}