mirror of
https://github.com/42wim/matterbridge.git
synced 2024-12-19 01:22:38 +01:00
Update vendor keybase/go-keybase-chat-bot (#1019)
This commit is contained in:
parent
250b3bb579
commit
d893421c7b
2
go.mod
2
go.mod
@ -19,7 +19,7 @@ require (
|
|||||||
github.com/hashicorp/golang-lru v0.5.3
|
github.com/hashicorp/golang-lru v0.5.3
|
||||||
github.com/hpcloud/tail v1.0.0 // indirect
|
github.com/hpcloud/tail v1.0.0 // indirect
|
||||||
github.com/jpillora/backoff v1.0.0
|
github.com/jpillora/backoff v1.0.0
|
||||||
github.com/keybase/go-keybase-chat-bot v0.0.0-20200207200343-9aca502dc88a
|
github.com/keybase/go-keybase-chat-bot v0.0.0-20200226211841-4e48f3eaef3e
|
||||||
github.com/labstack/echo/v4 v4.1.13
|
github.com/labstack/echo/v4 v4.1.13
|
||||||
github.com/lrstanley/girc v0.0.0-20190801035559-4fc93959e1a7
|
github.com/lrstanley/girc v0.0.0-20190801035559-4fc93959e1a7
|
||||||
github.com/matterbridge/Rocket.Chat.Go.SDK v0.0.0-20190210153444-cc9d05784d5d
|
github.com/matterbridge/Rocket.Chat.Go.SDK v0.0.0-20190210153444-cc9d05784d5d
|
||||||
|
4
go.sum
4
go.sum
@ -102,8 +102,8 @@ github.com/jtolds/gls v4.20.0+incompatible/go.mod h1:QJZ7F/aHp+rZTRtaJ1ow/lLfFfV
|
|||||||
github.com/julienschmidt/httprouter v1.2.0/go.mod h1:SYymIcj16QtmaHHD7aYtjjsJG7VTCxuUUipMqKk8s4w=
|
github.com/julienschmidt/httprouter v1.2.0/go.mod h1:SYymIcj16QtmaHHD7aYtjjsJG7VTCxuUUipMqKk8s4w=
|
||||||
github.com/kardianos/osext v0.0.0-20170510131534-ae77be60afb1 h1:PJPDf8OUfOK1bb/NeTKd4f1QXZItOX389VN3B6qC8ro=
|
github.com/kardianos/osext v0.0.0-20170510131534-ae77be60afb1 h1:PJPDf8OUfOK1bb/NeTKd4f1QXZItOX389VN3B6qC8ro=
|
||||||
github.com/kardianos/osext v0.0.0-20170510131534-ae77be60afb1/go.mod h1:1NbS8ALrpOvjt0rHPNLyCIeMtbizbir8U//inJ+zuB8=
|
github.com/kardianos/osext v0.0.0-20170510131534-ae77be60afb1/go.mod h1:1NbS8ALrpOvjt0rHPNLyCIeMtbizbir8U//inJ+zuB8=
|
||||||
github.com/keybase/go-keybase-chat-bot v0.0.0-20200207200343-9aca502dc88a h1:vwIVtvtOEn0edqYFeSTklvSmZG9WrnG5EywouKzZs1s=
|
github.com/keybase/go-keybase-chat-bot v0.0.0-20200226211841-4e48f3eaef3e h1:KbPTfR/PYuau1IzKoE4lnd8yby5I2pBj+VR6fSVbYU8=
|
||||||
github.com/keybase/go-keybase-chat-bot v0.0.0-20200207200343-9aca502dc88a/go.mod h1:vNc28YFzigVJod0j5EbuTtRIe7swx8vodh2yA4jZ2s8=
|
github.com/keybase/go-keybase-chat-bot v0.0.0-20200226211841-4e48f3eaef3e/go.mod h1:vNc28YFzigVJod0j5EbuTtRIe7swx8vodh2yA4jZ2s8=
|
||||||
github.com/keybase/go-ps v0.0.0-20161005175911-668c8856d999 h1:2d+FLQbz4xRTi36DO1qYNUwfORax9XcQ0jhbO81Vago=
|
github.com/keybase/go-ps v0.0.0-20161005175911-668c8856d999 h1:2d+FLQbz4xRTi36DO1qYNUwfORax9XcQ0jhbO81Vago=
|
||||||
github.com/keybase/go-ps v0.0.0-20161005175911-668c8856d999/go.mod h1:hY+WOq6m2FpbvyrI93sMaypsttvaIL5nhVR92dTMUcQ=
|
github.com/keybase/go-ps v0.0.0-20161005175911-668c8856d999/go.mod h1:hY+WOq6m2FpbvyrI93sMaypsttvaIL5nhVR92dTMUcQ=
|
||||||
github.com/kisielk/errcheck v1.1.0/go.mod h1:EZBBE59ingxPouuu3KfxchcWSUPOHkagtvWXihfKN4Q=
|
github.com/kisielk/errcheck v1.1.0/go.mod h1:EZBBE59ingxPouuu3KfxchcWSUPOHkagtvWXihfKN4Q=
|
||||||
|
57
vendor/github.com/keybase/go-keybase-chat-bot/kbchat/kbchat.go
generated
vendored
57
vendor/github.com/keybase/go-keybase-chat-bot/kbchat/kbchat.go
generated
vendored
@ -8,12 +8,13 @@ import (
|
|||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"log"
|
"log"
|
||||||
|
"os"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
"strings"
|
|
||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/keybase/go-keybase-chat-bot/kbchat/types/chat1"
|
"github.com/keybase/go-keybase-chat-bot/kbchat/types/chat1"
|
||||||
|
"github.com/keybase/go-keybase-chat-bot/kbchat/types/keybase1"
|
||||||
"github.com/keybase/go-keybase-chat-bot/kbchat/types/stellar1"
|
"github.com/keybase/go-keybase-chat-bot/kbchat/types/stellar1"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -29,30 +30,39 @@ type API struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func getUsername(runOpts RunOptions) (username string, err error) {
|
func getUsername(runOpts RunOptions) (username string, err error) {
|
||||||
p := runOpts.Command("status")
|
p := runOpts.Command("whoami", "-json")
|
||||||
output, err := p.StdoutPipe()
|
output, err := p.StdoutPipe()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
|
p.ExtraFiles = []*os.File{output.(*os.File)}
|
||||||
if err = p.Start(); err != nil {
|
if err = p.Start(); err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
|
|
||||||
doneCh := make(chan error)
|
doneCh := make(chan error)
|
||||||
go func() {
|
go func() {
|
||||||
scanner := bufio.NewScanner(output)
|
defer func() { close(doneCh) }()
|
||||||
if !scanner.Scan() {
|
statusJSON, err := ioutil.ReadAll(output)
|
||||||
doneCh <- errors.New("unable to find Keybase username")
|
if err != nil {
|
||||||
|
doneCh <- fmt.Errorf("error reading whoami output: %v", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
text := scanner.Text()
|
var status keybase1.CurrentStatus
|
||||||
toks := strings.Fields(text)
|
if err := json.Unmarshal(statusJSON, &status); err != nil {
|
||||||
if len(toks) != 2 {
|
doneCh <- fmt.Errorf("invalid whoami JSON %q: %v", statusJSON, err)
|
||||||
doneCh <- fmt.Errorf("invalid Keybase username output: %q", text)
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
username = toks[1]
|
if status.LoggedIn && status.User != nil {
|
||||||
doneCh <- nil
|
username = status.User.Username
|
||||||
|
doneCh <- nil
|
||||||
|
} else {
|
||||||
|
doneCh <- fmt.Errorf("unable to authenticate to keybase service: logged in: %v user: %+v", status.LoggedIn, status.User)
|
||||||
|
}
|
||||||
|
// Cleanup the command
|
||||||
|
if err := p.Wait(); err != nil {
|
||||||
|
log.Printf("unable to wait for cmd: %v", err)
|
||||||
|
}
|
||||||
}()
|
}()
|
||||||
|
|
||||||
select {
|
select {
|
||||||
@ -176,6 +186,7 @@ func (a *API) startPipes() (err error) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
a.apiCmd.ExtraFiles = []*os.File{output.(*os.File)}
|
||||||
if err := a.apiCmd.Start(); err != nil {
|
if err := a.apiCmd.Start(); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -360,7 +371,14 @@ func (a *API) Listen(opts ListenOptions) (*NewSubscription, error) {
|
|||||||
a.registerSubscription(sub)
|
a.registerSubscription(sub)
|
||||||
pause := 2 * time.Second
|
pause := 2 * time.Second
|
||||||
readScanner := func(boutput *bufio.Scanner) {
|
readScanner := func(boutput *bufio.Scanner) {
|
||||||
|
defer func() { done <- struct{}{} }()
|
||||||
for {
|
for {
|
||||||
|
select {
|
||||||
|
case <-shutdownCh:
|
||||||
|
log.Printf("readScanner: received shutdown")
|
||||||
|
return
|
||||||
|
default:
|
||||||
|
}
|
||||||
boutput.Scan()
|
boutput.Scan()
|
||||||
t := boutput.Text()
|
t := boutput.Text()
|
||||||
var typeHolder TypeHolder
|
var typeHolder TypeHolder
|
||||||
@ -413,12 +431,17 @@ func (a *API) Listen(opts ListenOptions) (*NewSubscription, error) {
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
done <- struct{}{}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
attempts := 0
|
attempts := 0
|
||||||
maxAttempts := 1800
|
maxAttempts := 1800
|
||||||
go func() {
|
go func() {
|
||||||
|
defer func() {
|
||||||
|
close(newMsgsCh)
|
||||||
|
close(newConvsCh)
|
||||||
|
close(newWalletCh)
|
||||||
|
close(errorCh)
|
||||||
|
}()
|
||||||
for {
|
for {
|
||||||
select {
|
select {
|
||||||
case <-shutdownCh:
|
case <-shutdownCh:
|
||||||
@ -428,6 +451,9 @@ func (a *API) Listen(opts ListenOptions) (*NewSubscription, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if attempts >= maxAttempts {
|
if attempts >= maxAttempts {
|
||||||
|
if err := a.LogSend("Listen: failed to auth, giving up"); err != nil {
|
||||||
|
log.Printf("Listen: logsend failed to send: %v", err)
|
||||||
|
}
|
||||||
panic("Listen: failed to auth, giving up")
|
panic("Listen: failed to auth, giving up")
|
||||||
}
|
}
|
||||||
attempts++
|
attempts++
|
||||||
@ -456,8 +482,10 @@ func (a *API) Listen(opts ListenOptions) (*NewSubscription, error) {
|
|||||||
time.Sleep(pause)
|
time.Sleep(pause)
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
p.ExtraFiles = []*os.File{stderr.(*os.File), output.(*os.File)}
|
||||||
boutput := bufio.NewScanner(output)
|
boutput := bufio.NewScanner(output)
|
||||||
if err := p.Start(); err != nil {
|
if err := p.Start(); err != nil {
|
||||||
|
|
||||||
log.Printf("Listen: failed to make listen scanner: %s", err)
|
log.Printf("Listen: failed to make listen scanner: %s", err)
|
||||||
time.Sleep(pause)
|
time.Sleep(pause)
|
||||||
continue
|
continue
|
||||||
@ -505,6 +533,11 @@ func (a *API) Shutdown() error {
|
|||||||
for _, sub := range a.subscriptions {
|
for _, sub := range a.subscriptions {
|
||||||
sub.Shutdown()
|
sub.Shutdown()
|
||||||
}
|
}
|
||||||
|
if a.apiCmd != nil {
|
||||||
|
if err := a.apiCmd.Wait(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if a.runOpts.Oneshot != nil {
|
if a.runOpts.Oneshot != nil {
|
||||||
err := a.runOpts.Command("logout", "--force").Run()
|
err := a.runOpts.Command("logout", "--force").Run()
|
||||||
|
20
vendor/github.com/keybase/go-keybase-chat-bot/kbchat/team.go
generated
vendored
20
vendor/github.com/keybase/go-keybase-chat-bot/kbchat/team.go
generated
vendored
@ -1,8 +1,10 @@
|
|||||||
package kbchat
|
package kbchat
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bytes"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"log"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/keybase/go-keybase-chat-bot/kbchat/types/keybase1"
|
"github.com/keybase/go-keybase-chat-bot/kbchat/types/keybase1"
|
||||||
@ -27,13 +29,18 @@ func (a *API) ListMembersOfTeam(teamName string) (res keybase1.TeamMembersDetail
|
|||||||
apiInput := fmt.Sprintf(`{"method": "list-team-memberships", "params": {"options": {"team": "%s"}}}`, teamName)
|
apiInput := fmt.Sprintf(`{"method": "list-team-memberships", "params": {"options": {"team": "%s"}}}`, teamName)
|
||||||
cmd := a.runOpts.Command("team", "api")
|
cmd := a.runOpts.Command("team", "api")
|
||||||
cmd.Stdin = strings.NewReader(apiInput)
|
cmd.Stdin = strings.NewReader(apiInput)
|
||||||
bytes, err := cmd.CombinedOutput()
|
var stderr bytes.Buffer
|
||||||
|
cmd.Stderr = &stderr
|
||||||
|
output, err := cmd.Output()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return res, APIError{err}
|
return res, APIError{err}
|
||||||
}
|
}
|
||||||
|
if stderr.Len() != 0 {
|
||||||
|
log.Printf("ListMembersOfTeam error: %s", stderr.String())
|
||||||
|
}
|
||||||
|
|
||||||
members := ListTeamMembers{}
|
members := ListTeamMembers{}
|
||||||
err = json.Unmarshal(bytes, &members)
|
err = json.Unmarshal(output, &members)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return res, UnmarshalError{err}
|
return res, UnmarshalError{err}
|
||||||
}
|
}
|
||||||
@ -47,13 +54,18 @@ func (a *API) ListUserMemberships(username string) ([]keybase1.AnnotatedMemberIn
|
|||||||
apiInput := fmt.Sprintf(`{"method": "list-user-memberships", "params": {"options": {"username": "%s"}}}`, username)
|
apiInput := fmt.Sprintf(`{"method": "list-user-memberships", "params": {"options": {"username": "%s"}}}`, username)
|
||||||
cmd := a.runOpts.Command("team", "api")
|
cmd := a.runOpts.Command("team", "api")
|
||||||
cmd.Stdin = strings.NewReader(apiInput)
|
cmd.Stdin = strings.NewReader(apiInput)
|
||||||
bytes, err := cmd.CombinedOutput()
|
var stderr bytes.Buffer
|
||||||
|
cmd.Stderr = &stderr
|
||||||
|
output, err := cmd.Output()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, APIError{err}
|
return nil, APIError{err}
|
||||||
}
|
}
|
||||||
|
if stderr.Len() != 0 {
|
||||||
|
log.Printf("ListUserMemberships error: %s", stderr.String())
|
||||||
|
}
|
||||||
|
|
||||||
members := ListUserMemberships{}
|
members := ListUserMemberships{}
|
||||||
err = json.Unmarshal(bytes, &members)
|
err = json.Unmarshal(output, &members)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, UnmarshalError{err}
|
return nil, UnmarshalError{err}
|
||||||
}
|
}
|
||||||
|
2
vendor/modules.txt
vendored
2
vendor/modules.txt
vendored
@ -77,7 +77,7 @@ github.com/hashicorp/hcl/json/token
|
|||||||
github.com/jpillora/backoff
|
github.com/jpillora/backoff
|
||||||
# github.com/kardianos/osext v0.0.0-20170510131534-ae77be60afb1
|
# github.com/kardianos/osext v0.0.0-20170510131534-ae77be60afb1
|
||||||
github.com/kardianos/osext
|
github.com/kardianos/osext
|
||||||
# github.com/keybase/go-keybase-chat-bot v0.0.0-20200207200343-9aca502dc88a
|
# github.com/keybase/go-keybase-chat-bot v0.0.0-20200226211841-4e48f3eaef3e
|
||||||
github.com/keybase/go-keybase-chat-bot/kbchat
|
github.com/keybase/go-keybase-chat-bot/kbchat
|
||||||
github.com/keybase/go-keybase-chat-bot/kbchat/types/chat1
|
github.com/keybase/go-keybase-chat-bot/kbchat/types/chat1
|
||||||
github.com/keybase/go-keybase-chat-bot/kbchat/types/gregor1
|
github.com/keybase/go-keybase-chat-bot/kbchat/types/gregor1
|
||||||
|
Loading…
Reference in New Issue
Block a user