summaryrefslogtreecommitdiffstats
path: root/vendor/github.com/keybase/go-keybase-chat-bot/kbchat/wallet.go
diff options
context:
space:
mode:
authorcori hudson <54032873+hyperobject@users.noreply.github.com>2019-08-26 15:00:31 -0400
committerWim <wim@42.be>2019-08-26 21:00:31 +0200
commit921f2dfcdf1a6263220b55eb55716e497373dfcf (patch)
tree436478bd7b61ea598d75af0d27520b512dad1683 /vendor/github.com/keybase/go-keybase-chat-bot/kbchat/wallet.go
parent79a006c8de311a7bbab540e62bd3fac998d415d5 (diff)
downloadmatterbridge-msglm-921f2dfcdf1a6263220b55eb55716e497373dfcf.tar.gz
matterbridge-msglm-921f2dfcdf1a6263220b55eb55716e497373dfcf.tar.bz2
matterbridge-msglm-921f2dfcdf1a6263220b55eb55716e497373dfcf.zip
Add initial Keybase Chat support (#877)
* initial work on native keybase bridging * Hopefully make a functional keybase bridge * add keybase to bridgemap * send to right channel, try to figure out received msgs * add account and userid * i am a Dam Fool * Fix formatting for messages, handle /me * update vendors, ran golint and goimports * move handlers to handlers.go, clean up unused config options * add sample config, fix inconsistent remote nick handling * Update readme with keybase links * Resolve fixmie errors * Error -> Errorf * fix linting errors in go.mod and go.sum * explicitly join channels, ignore messages from non-specified channels * check that team names match before bridging message
Diffstat (limited to 'vendor/github.com/keybase/go-keybase-chat-bot/kbchat/wallet.go')
-rw-r--r--vendor/github.com/keybase/go-keybase-chat-bot/kbchat/wallet.go48
1 files changed, 48 insertions, 0 deletions
diff --git a/vendor/github.com/keybase/go-keybase-chat-bot/kbchat/wallet.go b/vendor/github.com/keybase/go-keybase-chat-bot/kbchat/wallet.go
new file mode 100644
index 00000000..7dfdab68
--- /dev/null
+++ b/vendor/github.com/keybase/go-keybase-chat-bot/kbchat/wallet.go
@@ -0,0 +1,48 @@
+package kbchat
+
+import (
+ "bytes"
+ "encoding/json"
+ "fmt"
+ "strings"
+)
+
+type WalletOutput struct {
+ Result WalletResult `json:"result"`
+}
+
+type WalletResult struct {
+ TxID string `json:"txID"`
+ Status string `json:"status"`
+ Amount string `json:"amount"`
+ Asset WalletAsset `json:"asset"`
+ FromUsername string `json:"fromUsername"`
+ ToUsername string `json:"toUsername"`
+}
+
+type WalletAsset struct {
+ Type string `json:"type"`
+ Code string `json:"code"`
+ Issuer string `json:"issuer"`
+}
+
+func (a *API) GetWalletTxDetails(txID string) (wOut WalletOutput, err error) {
+ a.Lock()
+ defer a.Unlock()
+
+ apiInput := fmt.Sprintf(`{"method": "details", "params": {"options": {"txid": "%s"}}}`, txID)
+ 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
+}