diff options
author | cori hudson <54032873+hyperobject@users.noreply.github.com> | 2019-08-26 15:00:31 -0400 |
---|---|---|
committer | Wim <wim@42.be> | 2019-08-26 21:00:31 +0200 |
commit | 921f2dfcdf1a6263220b55eb55716e497373dfcf (patch) | |
tree | 436478bd7b61ea598d75af0d27520b512dad1683 /vendor/github.com/keybase/go-keybase-chat-bot/kbchat/wallet.go | |
parent | 79a006c8de311a7bbab540e62bd3fac998d415d5 (diff) | |
download | matterbridge-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.go | 48 |
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 +} |