diff options
Diffstat (limited to 'teleirc/matterbridge/vendor/github.com/keybase/go-keybase-chat-bot/kbchat/wallet.go')
| -rw-r--r-- | teleirc/matterbridge/vendor/github.com/keybase/go-keybase-chat-bot/kbchat/wallet.go | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/teleirc/matterbridge/vendor/github.com/keybase/go-keybase-chat-bot/kbchat/wallet.go b/teleirc/matterbridge/vendor/github.com/keybase/go-keybase-chat-bot/kbchat/wallet.go new file mode 100644 index 0000000..1ced65e --- /dev/null +++ b/teleirc/matterbridge/vendor/github.com/keybase/go-keybase-chat-bot/kbchat/wallet.go @@ -0,0 +1,39 @@ +package kbchat + +import ( + "bytes" + "encoding/json" + "fmt" + "strings" + + "github.com/keybase/go-keybase-chat-bot/kbchat/types/stellar1" +) + +type WalletOutput struct { + Result stellar1.PaymentCLILocal `json:"result"` +} + +func (a *API) GetWalletTxDetails(txID string) (wOut WalletOutput, err error) { + a.Lock() + defer a.Unlock() + + txIDEscaped, err := json.Marshal(txID) + if err != nil { + return wOut, err + } + apiInput := fmt.Sprintf(`{"method": "details", "params": {"options": {"txid": %s}}}`, txIDEscaped) + cmd := a.runOpts.Command("wallet", "api") + cmd.Stdin = strings.NewReader(apiInput) + var out bytes.Buffer + cmd.Stdout = &out + err = cmd.Run() + if err != nil { + return wOut, err + } + + if err := json.Unmarshal(out.Bytes(), &wOut); err != nil { + return wOut, fmt.Errorf("unable to decode wallet output: %s", err.Error()) + } + + return wOut, nil +} |
