You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
161 lines
3.6 KiB
161 lines
3.6 KiB
6 years ago
|
package keybase
|
||
6 years ago
|
|
||
|
import (
|
||
|
"encoding/json"
|
||
5 years ago
|
"fmt"
|
||
6 years ago
|
"os/exec"
|
||
5 years ago
|
"strings"
|
||
6 years ago
|
)
|
||
|
|
||
6 years ago
|
// Possible MemberTypes
|
||
|
const (
|
||
|
TEAM string = "team"
|
||
|
USER string = "impteamnative"
|
||
|
)
|
||
|
|
||
|
// Possible TopicTypes
|
||
|
const (
|
||
|
DEV string = "dev"
|
||
|
CHAT string = "chat"
|
||
|
)
|
||
|
|
||
6 years ago
|
// NewKeybase returns a new Keybase. Optionally, you can pass a string containing the path to the Keybase executable as the first argument.
|
||
6 years ago
|
func NewKeybase(path ...string) *Keybase {
|
||
|
k := &Keybase{}
|
||
6 years ago
|
if len(path) < 1 {
|
||
6 years ago
|
k.Path = "keybase"
|
||
|
} else {
|
||
|
k.Path = path[0]
|
||
|
}
|
||
5 years ago
|
|
||
|
s := k.status()
|
||
6 years ago
|
k.Version = k.version()
|
||
5 years ago
|
k.LoggedIn = s.LoggedIn
|
||
6 years ago
|
if k.LoggedIn {
|
||
5 years ago
|
k.Username = s.Username
|
||
|
k.Device = s.Device.Name
|
||
6 years ago
|
}
|
||
|
return k
|
||
|
}
|
||
|
|
||
5 years ago
|
// NewBotCommand returns a new BotCommand instance
|
||
5 years ago
|
func NewBotCommand(name, description, usage string, extendedDescription ...BotCommandExtendedDescription) BotCommand {
|
||
|
result := BotCommand{
|
||
5 years ago
|
Name: name,
|
||
|
Description: description,
|
||
5 years ago
|
Usage: usage,
|
||
|
}
|
||
|
|
||
|
if len(extendedDescription) > 0 {
|
||
|
result.ExtendedDescription = &extendedDescription[0]
|
||
|
}
|
||
|
|
||
|
return result
|
||
|
}
|
||
|
|
||
|
// NewBotCommandExtendedDescription
|
||
|
func NewBotCommandExtendedDescription(title, desktopBody, mobileBody string) BotCommandExtendedDescription {
|
||
|
return BotCommandExtendedDescription{
|
||
|
Title: title,
|
||
|
DesktopBody: desktopBody,
|
||
|
MobileBody: mobileBody,
|
||
5 years ago
|
}
|
||
|
}
|
||
|
|
||
5 years ago
|
// Exec executes the given Keybase command
|
||
|
func (k *Keybase) Exec(command ...string) ([]byte, error) {
|
||
|
out, err := exec.Command(k.Path, command...).Output()
|
||
|
if err != nil {
|
||
|
return []byte{}, err
|
||
|
}
|
||
|
return out, nil
|
||
|
}
|
||
|
|
||
6 years ago
|
// NewChat returns a new Chat instance
|
||
6 years ago
|
func (k *Keybase) NewChat(channel Channel) Chat {
|
||
6 years ago
|
return Chat{
|
||
|
keybase: k,
|
||
|
Channel: channel,
|
||
6 years ago
|
}
|
||
|
}
|
||
|
|
||
6 years ago
|
// NewTeam returns a new Team instance
|
||
|
func (k *Keybase) NewTeam(name string) Team {
|
||
|
return Team{
|
||
|
keybase: k,
|
||
|
Name: name,
|
||
|
}
|
||
|
}
|
||
|
|
||
5 years ago
|
// NewKV returns a new KV instance
|
||
|
func (k *Keybase) NewKV(team string) KV {
|
||
|
return KV{
|
||
|
keybase: k,
|
||
|
Team: team,
|
||
|
}
|
||
|
}
|
||
|
|
||
5 years ago
|
// NewWallet returns a new Wallet instance
|
||
|
func (k *Keybase) NewWallet() Wallet {
|
||
|
return Wallet{
|
||
|
keybase: k,
|
||
|
}
|
||
|
}
|
||
|
|
||
5 years ago
|
// status returns the results of the `keybase status` command, which includes
|
||
|
// information about the client, and the currently logged-in Keybase user.
|
||
|
func (k *Keybase) status() status {
|
||
5 years ago
|
cmdOut, err := k.Exec("status", "-j")
|
||
6 years ago
|
if err != nil {
|
||
5 years ago
|
return status{}
|
||
6 years ago
|
}
|
||
|
|
||
|
var s status
|
||
|
json.Unmarshal(cmdOut, &s)
|
||
|
|
||
5 years ago
|
return s
|
||
6 years ago
|
}
|
||
|
|
||
6 years ago
|
// version returns the version string of the client.
|
||
6 years ago
|
func (k *Keybase) version() string {
|
||
5 years ago
|
cmdOut, err := k.Exec("version", "-S", "-f", "s")
|
||
6 years ago
|
if err != nil {
|
||
|
return ""
|
||
|
}
|
||
|
|
||
|
return string(cmdOut)
|
||
|
}
|
||
5 years ago
|
|
||
|
// UserLookup pulls information about users.
|
||
5 years ago
|
// The following fields are currently returned: basics, profile, proofs_summary, devices -- See https://keybase.io/docs/api/1.0/call/user/lookup for more info.
|
||
5 years ago
|
func (k *Keybase) UserLookup(users ...string) (UserAPI, error) {
|
||
5 years ago
|
var fields = []string{"basics", "profile", "proofs_summary", "devices"}
|
||
5 years ago
|
|
||
|
cmdOut, err := k.Exec("apicall", "--arg", fmt.Sprintf("usernames=%s", strings.Join(users, ",")), "--arg", fmt.Sprintf("fields=%s", strings.Join(fields, ",")), "user/lookup")
|
||
|
if err != nil {
|
||
|
return UserAPI{}, err
|
||
|
}
|
||
|
|
||
|
var r UserAPI
|
||
|
if err := json.Unmarshal(cmdOut, &r); err != nil {
|
||
|
return UserAPI{}, err
|
||
|
}
|
||
|
|
||
|
return r, nil
|
||
|
}
|
||
5 years ago
|
|
||
|
// UserCard pulls the information that is typically displayed when you open a user's profile.
|
||
|
func (k *Keybase) UserCard(user string) (UserCardAPI, error) {
|
||
|
cmdOut, err := k.Exec("apicall", "--arg", "username="+user, "user/card")
|
||
|
if err != nil {
|
||
|
return UserCardAPI{}, err
|
||
|
}
|
||
|
|
||
|
var r UserCardAPI
|
||
|
if err := json.Unmarshal(cmdOut, &r); err != nil {
|
||
|
return UserCardAPI{}, err
|
||
|
}
|
||
|
|
||
|
return r, nil
|
||
|
}
|