Reformat the cli again
This commit is contained in:
parent
b4c43671f8
commit
89621fb006
15 changed files with 432 additions and 362 deletions
99
cmd/signaldctl/cmd/account/link/link-account.go
Normal file
99
cmd/signaldctl/cmd/account/link/link-account.go
Normal file
|
@ -0,0 +1,99 @@
|
||||||
|
// Copyright © 2021 Finn Herzfeld <finn@janky.solutions>
|
||||||
|
//
|
||||||
|
// This program is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// This program is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU General Public License
|
||||||
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
package link
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"log"
|
||||||
|
"os"
|
||||||
|
|
||||||
|
"github.com/jedib0t/go-pretty/v6/table"
|
||||||
|
"github.com/mdp/qrterminal"
|
||||||
|
"github.com/spf13/cobra"
|
||||||
|
"gopkg.in/yaml.v2"
|
||||||
|
|
||||||
|
"gitlab.com/signald/signald-go/cmd/signaldctl/common"
|
||||||
|
"gitlab.com/signald/signald-go/signald"
|
||||||
|
"gitlab.com/signald/signald-go/signald/client-protocol/v0"
|
||||||
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
noWait bool
|
||||||
|
|
||||||
|
LinkAccountCmd = &cobra.Command{
|
||||||
|
Use: "link",
|
||||||
|
Short: "create a local account by linking to an existing Signal account",
|
||||||
|
Run: func(_ *cobra.Command, _ []string) {
|
||||||
|
requestID := signald.GenerateID()
|
||||||
|
err := common.Signald.RawRequest(v0.LegacyRequest{Type: "link", ID: requestID})
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal("error sending request: ", err)
|
||||||
|
}
|
||||||
|
c := make(chan v0.LegacyResponse)
|
||||||
|
go common.Signald.Listen(c)
|
||||||
|
uri := common.GetResponse(c, requestID)
|
||||||
|
if uri.Type != "linking_uri" {
|
||||||
|
log.Fatalf("unexpected response from signald when requesting link: %+v", uri)
|
||||||
|
}
|
||||||
|
|
||||||
|
switch common.OutputFormat {
|
||||||
|
case common.OutputFormatJSON:
|
||||||
|
err := json.NewEncoder(os.Stdout).Encode(uri.Data.URI)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err, "error encoding response to stdout")
|
||||||
|
}
|
||||||
|
case common.OutputFormatYAML:
|
||||||
|
err := yaml.NewEncoder(os.Stdout).Encode(uri.Data.URI)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err, "error encoding response to stdout")
|
||||||
|
}
|
||||||
|
case common.OutputFormatCSV, common.OutputFormatTable:
|
||||||
|
t := table.NewWriter()
|
||||||
|
t.SetOutputMirror(os.Stdout)
|
||||||
|
t.AppendHeader(table.Row{"URI"})
|
||||||
|
t.AppendRow(table.Row{uri.Data.URI})
|
||||||
|
if common.OutputFormat == common.OutputFormatCSV {
|
||||||
|
t.RenderCSV()
|
||||||
|
} else {
|
||||||
|
t.Render()
|
||||||
|
}
|
||||||
|
case common.OutputFormatQR, common.OutputFormatDefault:
|
||||||
|
qrterminal.Generate(uri.Data.URI, qrterminal.M, os.Stdout)
|
||||||
|
default:
|
||||||
|
log.Fatal("unsupported output format")
|
||||||
|
}
|
||||||
|
|
||||||
|
if noWait {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
finish := common.GetResponse(c, requestID)
|
||||||
|
if finish.Type == "linking_successful" {
|
||||||
|
log.Println("linking successful")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if finish.Type == "linking_error" {
|
||||||
|
log.Fatal("error from signald:", finish.Data.Message)
|
||||||
|
} else {
|
||||||
|
log.Fatal("unexpected message from signald:", finish.Data.Message)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
LinkAccountCmd.Flags().BoolVar(&noWait, "no-wait", false, "return after the linking URI is printed to stdout. By default, signaldctl will wait until the server acknowledges that the linking has completed before exiting")
|
||||||
|
}
|
|
@ -13,7 +13,7 @@
|
||||||
// You should have received a copy of the GNU General Public License
|
// You should have received a copy of the GNU General Public License
|
||||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
package account
|
package list
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
@ -30,10 +30,9 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
GetAccountCmd = &cobra.Command{
|
ListAccountCmd = &cobra.Command{
|
||||||
Use: "account",
|
Use: "list",
|
||||||
Aliases: []string{"accounts"},
|
Short: "return a list of accounts",
|
||||||
Short: "return a list of accounts",
|
|
||||||
Run: func(_ *cobra.Command, _ []string) {
|
Run: func(_ *cobra.Command, _ []string) {
|
||||||
requestID := signald.GenerateID()
|
requestID := signald.GenerateID()
|
||||||
err := common.Signald.RawRequest(v0.LegacyRequest{
|
err := common.Signald.RawRequest(v0.LegacyRequest{
|
66
cmd/signaldctl/cmd/account/register/register-account.go
Normal file
66
cmd/signaldctl/cmd/account/register/register-account.go
Normal file
|
@ -0,0 +1,66 @@
|
||||||
|
// Copyright © 2021 Finn Herzfeld <finn@janky.solutions>
|
||||||
|
//
|
||||||
|
// This program is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// This program is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU General Public License
|
||||||
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
package register
|
||||||
|
|
||||||
|
import (
|
||||||
|
"log"
|
||||||
|
|
||||||
|
"github.com/spf13/cobra"
|
||||||
|
|
||||||
|
"gitlab.com/signald/signald-go/cmd/signaldctl/common"
|
||||||
|
"gitlab.com/signald/signald-go/signald"
|
||||||
|
"gitlab.com/signald/signald-go/signald/client-protocol/v0"
|
||||||
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
phoneNumber string
|
||||||
|
voice bool
|
||||||
|
|
||||||
|
RegisterAccountCmd = &cobra.Command{
|
||||||
|
Use: "register",
|
||||||
|
Short: "begin the process of creating a new account",
|
||||||
|
PreRun: func(_ *cobra.Command, _ []string) {
|
||||||
|
if phoneNumber == "" {
|
||||||
|
log.Fatal("--phone-number required")
|
||||||
|
}
|
||||||
|
},
|
||||||
|
Run: func(_ *cobra.Command, _ []string) {
|
||||||
|
requestID := signald.GenerateID()
|
||||||
|
err := common.Signald.RawRequest(v0.LegacyRequest{
|
||||||
|
Type: "register",
|
||||||
|
ID: requestID,
|
||||||
|
Username: phoneNumber,
|
||||||
|
Voice: voice,
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal("error sending request to signald: ", err)
|
||||||
|
}
|
||||||
|
c := make(chan v0.LegacyResponse)
|
||||||
|
go common.Signald.Listen(c)
|
||||||
|
response := common.GetResponse(c, requestID)
|
||||||
|
if response.Type == "verification_required" {
|
||||||
|
log.Println("verification code requested. submit with: signaldctl account verify --phone-number", phoneNumber, "--code XXX-XXX")
|
||||||
|
} else {
|
||||||
|
log.Fatalf("unexpected response from signald when requesting verification code: %+v", response)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
RegisterAccountCmd.Flags().StringVarP(&phoneNumber, "number", "n", "", "phone number being registered")
|
||||||
|
RegisterAccountCmd.Flags().BoolVarP(&voice, "voice", "V", false, "request verification code be sent via an automated voice call (code is sent via SMS by default)")
|
||||||
|
}
|
37
cmd/signaldctl/cmd/account/root.go
Normal file
37
cmd/signaldctl/cmd/account/root.go
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
// Copyright © 2021 Finn Herzfeld <finn@janky.solutions>
|
||||||
|
//
|
||||||
|
// This program is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// This program is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU General Public License
|
||||||
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
package account
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/spf13/cobra"
|
||||||
|
|
||||||
|
"gitlab.com/signald/signald-go/cmd/signaldctl/cmd/account/link"
|
||||||
|
"gitlab.com/signald/signald-go/cmd/signaldctl/cmd/account/list"
|
||||||
|
"gitlab.com/signald/signald-go/cmd/signaldctl/cmd/account/register"
|
||||||
|
"gitlab.com/signald/signald-go/cmd/signaldctl/cmd/account/verify"
|
||||||
|
)
|
||||||
|
|
||||||
|
var AccountCmd = &cobra.Command{
|
||||||
|
Use: "account",
|
||||||
|
Aliases: []string{"accounts"},
|
||||||
|
}
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
AccountCmd.AddCommand(link.LinkAccountCmd)
|
||||||
|
AccountCmd.AddCommand(list.ListAccountCmd)
|
||||||
|
AccountCmd.AddCommand(register.RegisterAccountCmd)
|
||||||
|
AccountCmd.AddCommand(verify.VerifyAccountCmd)
|
||||||
|
}
|
69
cmd/signaldctl/cmd/account/verify/verify-account.go
Normal file
69
cmd/signaldctl/cmd/account/verify/verify-account.go
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
// Copyright © 2021 Finn Herzfeld <finn@janky.solutions>
|
||||||
|
//
|
||||||
|
// This program is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// This program is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU General Public License
|
||||||
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
package verify
|
||||||
|
|
||||||
|
import (
|
||||||
|
"log"
|
||||||
|
|
||||||
|
"github.com/spf13/cobra"
|
||||||
|
|
||||||
|
"gitlab.com/signald/signald-go/cmd/signaldctl/common"
|
||||||
|
"gitlab.com/signald/signald-go/signald"
|
||||||
|
"gitlab.com/signald/signald-go/signald/client-protocol/v0"
|
||||||
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
phoneNumber string
|
||||||
|
code string
|
||||||
|
|
||||||
|
VerifyAccountCmd = &cobra.Command{
|
||||||
|
Use: "verify",
|
||||||
|
Short: "verify an account and complete the registration process",
|
||||||
|
PreRun: func(_ *cobra.Command, _ []string) {
|
||||||
|
if phoneNumber == "" {
|
||||||
|
log.Fatal("--phone-number required")
|
||||||
|
}
|
||||||
|
if code == "" {
|
||||||
|
log.Fatal("--code required")
|
||||||
|
}
|
||||||
|
},
|
||||||
|
Run: func(_ *cobra.Command, _ []string) {
|
||||||
|
requestID := signald.GenerateID()
|
||||||
|
err := common.Signald.RawRequest(v0.LegacyRequest{
|
||||||
|
Type: "verify",
|
||||||
|
ID: requestID,
|
||||||
|
Username: phoneNumber,
|
||||||
|
Code: code,
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal("error sending request to signald: ", err)
|
||||||
|
}
|
||||||
|
c := make(chan v0.LegacyResponse)
|
||||||
|
go common.Signald.Listen(c)
|
||||||
|
response := common.GetResponse(c, requestID)
|
||||||
|
if response.Type == "verification_succeeded" {
|
||||||
|
log.Fatal("verification code requested. re-run with --verify")
|
||||||
|
} else {
|
||||||
|
log.Fatalf("unexpected response from signald when requesting verification code: %+v", response)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
VerifyAccountCmd.Flags().StringVarP(&phoneNumber, "phone-number", "n", "", "phone number being verified")
|
||||||
|
VerifyAccountCmd.Flags().StringVarP(&code, "code", "c", "", "verification code to submit")
|
||||||
|
}
|
|
@ -1,129 +0,0 @@
|
||||||
// Copyright © 2021 Finn Herzfeld <finn@janky.solutions>
|
|
||||||
//
|
|
||||||
// This program is free software: you can redistribute it and/or modify
|
|
||||||
// it under the terms of the GNU General Public License as published by
|
|
||||||
// the Free Software Foundation, either version 3 of the License, or
|
|
||||||
// (at your option) any later version.
|
|
||||||
//
|
|
||||||
// This program is distributed in the hope that it will be useful,
|
|
||||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
// GNU General Public License for more details.
|
|
||||||
//
|
|
||||||
// You should have received a copy of the GNU General Public License
|
|
||||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
package account
|
|
||||||
|
|
||||||
import (
|
|
||||||
"log"
|
|
||||||
|
|
||||||
"github.com/spf13/cobra"
|
|
||||||
|
|
||||||
"gitlab.com/signald/signald-go/signald/client-protocol/v0"
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
actionLink bool
|
|
||||||
actionRequestCode bool
|
|
||||||
actionVerify bool
|
|
||||||
|
|
||||||
phoneNumber string
|
|
||||||
code string
|
|
||||||
voice bool
|
|
||||||
noWait bool
|
|
||||||
|
|
||||||
CreateAccountCmd = &cobra.Command{
|
|
||||||
Use: "account",
|
|
||||||
Aliases: []string{"accounts"},
|
|
||||||
Short: "create an account",
|
|
||||||
PreRun: func(_ *cobra.Command, _ []string) {
|
|
||||||
|
|
||||||
actionCount := 0
|
|
||||||
if actionLink {
|
|
||||||
actionCount++
|
|
||||||
}
|
|
||||||
if actionRequestCode {
|
|
||||||
actionCount++
|
|
||||||
}
|
|
||||||
if actionVerify {
|
|
||||||
actionCount++
|
|
||||||
}
|
|
||||||
if actionCount > 1 {
|
|
||||||
log.Fatal("invalid arguments: must select exactly one of --request-code, --verify or --link")
|
|
||||||
}
|
|
||||||
|
|
||||||
if actionLink {
|
|
||||||
if phoneNumber != "" {
|
|
||||||
log.Fatal("cannot use --phone-number with --link")
|
|
||||||
}
|
|
||||||
if code != "" {
|
|
||||||
log.Fatal("cannot use --code with --link")
|
|
||||||
}
|
|
||||||
if voice {
|
|
||||||
log.Fatal("cannot use --voice with --link")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if actionRequestCode {
|
|
||||||
if phoneNumber == "" {
|
|
||||||
log.Fatal("--phone-number required")
|
|
||||||
}
|
|
||||||
if code != "" {
|
|
||||||
log.Fatal("cannot use --code with --request-code")
|
|
||||||
}
|
|
||||||
if noWait {
|
|
||||||
log.Fatal("cannot use --no-wait with --request-code")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if actionVerify {
|
|
||||||
if phoneNumber == "" {
|
|
||||||
log.Fatal("--phone-number required")
|
|
||||||
}
|
|
||||||
if code == "" {
|
|
||||||
log.Fatal("--code required")
|
|
||||||
}
|
|
||||||
if voice {
|
|
||||||
log.Fatal("cannot use --voice with --verify")
|
|
||||||
}
|
|
||||||
if noWait {
|
|
||||||
log.Fatal("cannot use --no-wait with --verify")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
Run: func(_ *cobra.Command, _ []string) {
|
|
||||||
if actionLink {
|
|
||||||
link()
|
|
||||||
}
|
|
||||||
|
|
||||||
if actionRequestCode {
|
|
||||||
requestCode()
|
|
||||||
}
|
|
||||||
|
|
||||||
if actionVerify {
|
|
||||||
verify()
|
|
||||||
}
|
|
||||||
},
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
CreateAccountCmd.Flags().BoolVarP(&actionLink, "link", "l", false, "link an existing account")
|
|
||||||
CreateAccountCmd.Flags().BoolVarP(&actionRequestCode, "request-code", "r", false, "request a verification code")
|
|
||||||
CreateAccountCmd.Flags().BoolVarP(&actionVerify, "verify", "v", false, "submit a verification code and complete a new account registration")
|
|
||||||
|
|
||||||
CreateAccountCmd.Flags().StringVarP(&phoneNumber, "number", "n", "", "only with --request-code or --verify. phone number being registered")
|
|
||||||
CreateAccountCmd.Flags().StringVarP(&code, "code", "c", "", "only with --verify. verification code to submit")
|
|
||||||
CreateAccountCmd.Flags().BoolVarP(&voice, "voice", "V", false, "only with --request-code. request verification code be sent via an automated voice call (code is sent via SMS by default)")
|
|
||||||
CreateAccountCmd.Flags().BoolVar(&noWait, "no-wait", false, "only with --link. return after the linking URI is printed to stdout. By default, --link will wait until the server acknowledges that the linking has completed")
|
|
||||||
}
|
|
||||||
|
|
||||||
func getResponse(c chan v0.LegacyResponse, id string) v0.LegacyResponse {
|
|
||||||
for {
|
|
||||||
message := <-c
|
|
||||||
if message.ID == id {
|
|
||||||
return message
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,86 +0,0 @@
|
||||||
// Copyright © 2021 Finn Herzfeld <finn@janky.solutions>
|
|
||||||
//
|
|
||||||
// This program is free software: you can redistribute it and/or modify
|
|
||||||
// it under the terms of the GNU General Public License as published by
|
|
||||||
// the Free Software Foundation, either version 3 of the License, or
|
|
||||||
// (at your option) any later version.
|
|
||||||
//
|
|
||||||
// This program is distributed in the hope that it will be useful,
|
|
||||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
// GNU General Public License for more details.
|
|
||||||
//
|
|
||||||
// You should have received a copy of the GNU General Public License
|
|
||||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
package account
|
|
||||||
|
|
||||||
import (
|
|
||||||
"encoding/json"
|
|
||||||
"log"
|
|
||||||
"os"
|
|
||||||
|
|
||||||
"github.com/jedib0t/go-pretty/v6/table"
|
|
||||||
"github.com/mdp/qrterminal"
|
|
||||||
"gopkg.in/yaml.v2"
|
|
||||||
|
|
||||||
"gitlab.com/signald/signald-go/cmd/signaldctl/common"
|
|
||||||
"gitlab.com/signald/signald-go/signald"
|
|
||||||
"gitlab.com/signald/signald-go/signald/client-protocol/v0"
|
|
||||||
)
|
|
||||||
|
|
||||||
func link() {
|
|
||||||
requestID := signald.GenerateID()
|
|
||||||
err := common.Signald.RawRequest(v0.LegacyRequest{Type: "link", ID: requestID})
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("error sending request: ", err)
|
|
||||||
}
|
|
||||||
c := make(chan v0.LegacyResponse)
|
|
||||||
go common.Signald.Listen(c)
|
|
||||||
uri := getResponse(c, requestID)
|
|
||||||
if uri.Type != "linking_uri" {
|
|
||||||
log.Fatalf("unexpected response from signald when requesting link: %+v", uri)
|
|
||||||
}
|
|
||||||
|
|
||||||
switch common.OutputFormat {
|
|
||||||
case common.OutputFormatJSON:
|
|
||||||
err := json.NewEncoder(os.Stdout).Encode(uri.Data.URI)
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal(err, "error encoding response to stdout")
|
|
||||||
}
|
|
||||||
case common.OutputFormatYAML:
|
|
||||||
err := yaml.NewEncoder(os.Stdout).Encode(uri.Data.URI)
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal(err, "error encoding response to stdout")
|
|
||||||
}
|
|
||||||
case common.OutputFormatCSV, common.OutputFormatTable:
|
|
||||||
t := table.NewWriter()
|
|
||||||
t.SetOutputMirror(os.Stdout)
|
|
||||||
t.AppendHeader(table.Row{"URI"})
|
|
||||||
t.AppendRow(table.Row{uri.Data.URI})
|
|
||||||
if common.OutputFormat == common.OutputFormatCSV {
|
|
||||||
t.RenderCSV()
|
|
||||||
} else {
|
|
||||||
t.Render()
|
|
||||||
}
|
|
||||||
case common.OutputFormatQR, common.OutputFormatDefault:
|
|
||||||
qrterminal.Generate(uri.Data.URI, qrterminal.M, os.Stdout)
|
|
||||||
default:
|
|
||||||
log.Fatal("unsupported output format")
|
|
||||||
}
|
|
||||||
|
|
||||||
if noWait {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
finish := getResponse(c, requestID)
|
|
||||||
if finish.Type == "linking_successful" {
|
|
||||||
log.Println("linking successful")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if finish.Type == "linking_error" {
|
|
||||||
log.Fatal("error from signald:", finish.Data.Message)
|
|
||||||
} else {
|
|
||||||
log.Fatal("unexpected message from signald:", finish.Data.Message)
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,45 +0,0 @@
|
||||||
// Copyright © 2021 Finn Herzfeld <finn@janky.solutions>
|
|
||||||
//
|
|
||||||
// This program is free software: you can redistribute it and/or modify
|
|
||||||
// it under the terms of the GNU General Public License as published by
|
|
||||||
// the Free Software Foundation, either version 3 of the License, or
|
|
||||||
// (at your option) any later version.
|
|
||||||
//
|
|
||||||
// This program is distributed in the hope that it will be useful,
|
|
||||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
// GNU General Public License for more details.
|
|
||||||
//
|
|
||||||
// You should have received a copy of the GNU General Public License
|
|
||||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
package account
|
|
||||||
|
|
||||||
import (
|
|
||||||
"log"
|
|
||||||
|
|
||||||
"gitlab.com/signald/signald-go/cmd/signaldctl/common"
|
|
||||||
"gitlab.com/signald/signald-go/signald"
|
|
||||||
"gitlab.com/signald/signald-go/signald/client-protocol/v0"
|
|
||||||
)
|
|
||||||
|
|
||||||
func requestCode() {
|
|
||||||
requestID := signald.GenerateID()
|
|
||||||
err := common.Signald.RawRequest(v0.LegacyRequest{
|
|
||||||
Type: "register",
|
|
||||||
ID: requestID,
|
|
||||||
Username: phoneNumber,
|
|
||||||
Voice: voice,
|
|
||||||
})
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("error sending request to signald: ", err)
|
|
||||||
}
|
|
||||||
c := make(chan v0.LegacyResponse)
|
|
||||||
go common.Signald.Listen(c)
|
|
||||||
response := getResponse(c, requestID)
|
|
||||||
if response.Type == "verification_required" {
|
|
||||||
log.Fatal("verification code requested. re-run with --verify")
|
|
||||||
} else {
|
|
||||||
log.Fatalf("unexpected response from signald when requesting verification code: %+v", response)
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,45 +0,0 @@
|
||||||
// Copyright © 2021 Finn Herzfeld <finn@janky.solutions>
|
|
||||||
//
|
|
||||||
// This program is free software: you can redistribute it and/or modify
|
|
||||||
// it under the terms of the GNU General Public License as published by
|
|
||||||
// the Free Software Foundation, either version 3 of the License, or
|
|
||||||
// (at your option) any later version.
|
|
||||||
//
|
|
||||||
// This program is distributed in the hope that it will be useful,
|
|
||||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
// GNU General Public License for more details.
|
|
||||||
//
|
|
||||||
// You should have received a copy of the GNU General Public License
|
|
||||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
package account
|
|
||||||
|
|
||||||
import (
|
|
||||||
"log"
|
|
||||||
|
|
||||||
"gitlab.com/signald/signald-go/cmd/signaldctl/common"
|
|
||||||
"gitlab.com/signald/signald-go/signald"
|
|
||||||
"gitlab.com/signald/signald-go/signald/client-protocol/v0"
|
|
||||||
)
|
|
||||||
|
|
||||||
func verify() {
|
|
||||||
requestID := signald.GenerateID()
|
|
||||||
err := common.Signald.RawRequest(v0.LegacyRequest{
|
|
||||||
Type: "verify",
|
|
||||||
ID: requestID,
|
|
||||||
Username: phoneNumber,
|
|
||||||
Code: code,
|
|
||||||
})
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("error sending request to signald: ", err)
|
|
||||||
}
|
|
||||||
c := make(chan v0.LegacyResponse)
|
|
||||||
go common.Signald.Listen(c)
|
|
||||||
response := getResponse(c, requestID)
|
|
||||||
if response.Type == "verification_succeeded" {
|
|
||||||
log.Fatal("verification code requested. re-run with --verify")
|
|
||||||
} else {
|
|
||||||
log.Fatalf("unexpected response from signald when requesting verification code: %+v", response)
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -13,7 +13,7 @@
|
||||||
// You should have received a copy of the GNU General Public License
|
// You should have received a copy of the GNU General Public License
|
||||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
package group
|
package list
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
@ -29,41 +29,16 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
account string
|
account string
|
||||||
groupID string
|
ListGroupCmd = &cobra.Command{
|
||||||
GetGroupCmd = &cobra.Command{
|
Use: "list",
|
||||||
Use: "group",
|
Short: "return a list of Signal groups",
|
||||||
Aliases: []string{"groups"},
|
|
||||||
Short: "return a list of Signal groups",
|
|
||||||
Run: func(_ *cobra.Command, _ []string) {
|
Run: func(_ *cobra.Command, _ []string) {
|
||||||
go common.Signald.Listen(nil)
|
go common.Signald.Listen(nil)
|
||||||
var resp v1.GroupList
|
req := v1.ListGroupsRequest{Account: account}
|
||||||
if len(groupID) == 0 || len(groupID) == 24 {
|
resp, err := req.Submit(common.Signald)
|
||||||
var err error
|
if err != nil {
|
||||||
req := v1.ListGroupsRequest{Account: account}
|
log.Fatal(err, "error communicating with signald")
|
||||||
resp, err = req.Submit(common.Signald)
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal(err, "error communicating with signald")
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(groupID) == 24 {
|
|
||||||
for _, group := range resp.LegacyGroups {
|
|
||||||
if group.GroupId == groupID {
|
|
||||||
resp = v1.GroupList{LegacyGroups: []*v1.JsonGroupInfo{group}}
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
log.Fatal("group not found")
|
|
||||||
}
|
|
||||||
} else if len(groupID) == 44 {
|
|
||||||
req := v1.GetGroupRequest{Account: account, GroupID: groupID}
|
|
||||||
group, err := req.Submit(common.Signald)
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal(err, "error communicating with signald")
|
|
||||||
}
|
|
||||||
resp = v1.GroupList{Groups: []*v1.JsonGroupV2Info{&group}}
|
|
||||||
} else {
|
|
||||||
log.Fatal("malformed group ID (expected length of 24 or 44)")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
switch common.OutputFormat {
|
switch common.OutputFormat {
|
||||||
|
@ -103,7 +78,6 @@ var (
|
||||||
)
|
)
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
GetGroupCmd.Flags().StringVarP(&account, "account", "a", "", "the signald account to use")
|
ListGroupCmd.Flags().StringVarP(&account, "account", "a", "", "the signald account to use")
|
||||||
GetGroupCmd.Flags().StringVarP(&groupID, "group-id", "g", "", "if set, fetches the latest state of a group from the server (local state is used for legacy groups). If unset, return all groups")
|
common.Must(ListGroupCmd.MarkFlagRequired("account"))
|
||||||
common.Must(GetGroupCmd.MarkFlagRequired("account"))
|
|
||||||
}
|
}
|
|
@ -13,16 +13,19 @@
|
||||||
// You should have received a copy of the GNU General Public License
|
// You should have received a copy of the GNU General Public License
|
||||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
package create
|
package group
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
|
|
||||||
"gitlab.com/signald/signald-go/cmd/signaldctl/cmd/create/account"
|
"gitlab.com/signald/signald-go/cmd/signaldctl/cmd/group/list"
|
||||||
)
|
)
|
||||||
|
|
||||||
var CreateCmd = &cobra.Command{Use: "create"}
|
var GroupCmd = &cobra.Command{
|
||||||
|
Use: "group",
|
||||||
|
Aliases: []string{"groups"},
|
||||||
|
}
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
CreateCmd.AddCommand(account.CreateAccountCmd)
|
GroupCmd.AddCommand(list.ListGroupCmd)
|
||||||
}
|
}
|
|
@ -13,18 +13,19 @@
|
||||||
// You should have received a copy of the GNU General Public License
|
// You should have received a copy of the GNU General Public License
|
||||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
package get
|
package message
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
|
|
||||||
"gitlab.com/signald/signald-go/cmd/signaldctl/cmd/get/account"
|
"gitlab.com/signald/signald-go/cmd/signaldctl/cmd/message/send"
|
||||||
"gitlab.com/signald/signald-go/cmd/signaldctl/cmd/get/group"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var GetCmd = &cobra.Command{Use: "get"}
|
var MessageCmd = &cobra.Command{
|
||||||
|
Use: "message",
|
||||||
|
Aliases: []string{"msg", "messages"},
|
||||||
|
}
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
GetCmd.AddCommand(group.GetGroupCmd)
|
MessageCmd.AddCommand(send.SendMessageCmd)
|
||||||
GetCmd.AddCommand(account.GetAccountCmd)
|
|
||||||
}
|
}
|
115
cmd/signaldctl/cmd/message/send/send-message.go
Normal file
115
cmd/signaldctl/cmd/message/send/send-message.go
Normal file
|
@ -0,0 +1,115 @@
|
||||||
|
// Copyright © 2021 Finn Herzfeld <finn@janky.solutions>
|
||||||
|
//
|
||||||
|
// This program is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// This program is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU General Public License
|
||||||
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
package send
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"fmt"
|
||||||
|
"log"
|
||||||
|
"os"
|
||||||
|
|
||||||
|
"github.com/jedib0t/go-pretty/v6/table"
|
||||||
|
"github.com/spf13/cobra"
|
||||||
|
"gopkg.in/yaml.v2"
|
||||||
|
|
||||||
|
"gitlab.com/signald/signald-go/cmd/signaldctl/common"
|
||||||
|
"gitlab.com/signald/signald-go/signald/client-protocol/v1"
|
||||||
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
account string
|
||||||
|
to string
|
||||||
|
message string
|
||||||
|
|
||||||
|
SendMessageCmd = &cobra.Command{
|
||||||
|
Use: "send",
|
||||||
|
Short: "send a message",
|
||||||
|
PreRun: func(_ *cobra.Command, _ []string) {
|
||||||
|
if account == "" {
|
||||||
|
log.Fatal("--account required")
|
||||||
|
}
|
||||||
|
if to == "" {
|
||||||
|
log.Fatal("--to required")
|
||||||
|
}
|
||||||
|
if message == "" {
|
||||||
|
log.Fatal("--message required")
|
||||||
|
}
|
||||||
|
},
|
||||||
|
Run: func(_ *cobra.Command, _ []string) {
|
||||||
|
req := v1.SendRequest{
|
||||||
|
Username: account,
|
||||||
|
MessageBody: message,
|
||||||
|
RecipientAddress: &v1.JsonAddress{Number: to},
|
||||||
|
}
|
||||||
|
resp, err := req.Submit(common.Signald)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal("error sending request to signald: ", err)
|
||||||
|
}
|
||||||
|
switch common.OutputFormat {
|
||||||
|
case common.OutputFormatJSON:
|
||||||
|
err := json.NewEncoder(os.Stdout).Encode(resp)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err, "error encoding response to stdout")
|
||||||
|
}
|
||||||
|
case common.OutputFormatYAML:
|
||||||
|
err := yaml.NewEncoder(os.Stdout).Encode(resp)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err, "error encoding response to stdout")
|
||||||
|
}
|
||||||
|
case common.OutputFormatCSV, common.OutputFormatTable, common.OutputFormatDefault:
|
||||||
|
t := table.NewWriter()
|
||||||
|
t.SetOutputMirror(os.Stdout)
|
||||||
|
t.AppendHeader(table.Row{"Number", "UUID", "Duration", "Send Error"})
|
||||||
|
for _, result := range resp.Results {
|
||||||
|
if result.Success != nil {
|
||||||
|
t.AppendRow(table.Row{
|
||||||
|
result.Address.Number,
|
||||||
|
result.Address.UUID,
|
||||||
|
result.Success.Duration,
|
||||||
|
nil,
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
var sendError string
|
||||||
|
if result.IdentityFailure != "" {
|
||||||
|
sendError = fmt.Sprintf("identity failure: %s\n", result.IdentityFailure)
|
||||||
|
}
|
||||||
|
if result.NetworkFailure {
|
||||||
|
sendError = "network failure"
|
||||||
|
}
|
||||||
|
if result.UnregisteredFailure {
|
||||||
|
sendError = "not on"
|
||||||
|
}
|
||||||
|
t.AppendRow(table.Row{result.Address.Number, result.Address.UUID, nil, sendError})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if common.OutputFormat == common.OutputFormatCSV {
|
||||||
|
t.RenderCSV()
|
||||||
|
} else {
|
||||||
|
t.Render()
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
log.Fatal("Unsupported output format")
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
SendMessageCmd.Flags().StringVarP(&account, "account", "a", "", "local account to use")
|
||||||
|
SendMessageCmd.Flags().StringVarP(&to, "to", "t", "", "account to send the message to")
|
||||||
|
SendMessageCmd.Flags().StringVarP(&message, "message", "m", "", "the body of the message to send")
|
||||||
|
}
|
|
@ -23,8 +23,9 @@ import (
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
"github.com/spf13/viper"
|
"github.com/spf13/viper"
|
||||||
|
|
||||||
"gitlab.com/signald/signald-go/cmd/signaldctl/cmd/create"
|
"gitlab.com/signald/signald-go/cmd/signaldctl/cmd/account"
|
||||||
"gitlab.com/signald/signald-go/cmd/signaldctl/cmd/get"
|
"gitlab.com/signald/signald-go/cmd/signaldctl/cmd/group"
|
||||||
|
"gitlab.com/signald/signald-go/cmd/signaldctl/cmd/message"
|
||||||
"gitlab.com/signald/signald-go/cmd/signaldctl/common"
|
"gitlab.com/signald/signald-go/cmd/signaldctl/common"
|
||||||
"gitlab.com/signald/signald-go/signald"
|
"gitlab.com/signald/signald-go/signald"
|
||||||
)
|
)
|
||||||
|
@ -59,9 +60,10 @@ func init() {
|
||||||
cobra.OnInitialize(initConfig)
|
cobra.OnInitialize(initConfig)
|
||||||
RootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is $HOME/.signaldctl.yaml)")
|
RootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is $HOME/.signaldctl.yaml)")
|
||||||
RootCmd.PersistentFlags().StringVarP(&socketPath, "socket", "s", "/var/run/signald/signald.sock", "the path to the signald socket file")
|
RootCmd.PersistentFlags().StringVarP(&socketPath, "socket", "s", "/var/run/signald/signald.sock", "the path to the signald socket file")
|
||||||
RootCmd.PersistentFlags().StringVarP(&common.OutputFormat, "output-format", "o", "default", "the output format. Options are table (default), json or yaml")
|
RootCmd.PersistentFlags().StringVarP(&common.OutputFormat, "output-format", "o", "default", "the output format. options are usually table, yaml and json, default is usually table. Some commands have other options.")
|
||||||
RootCmd.AddCommand(get.GetCmd)
|
RootCmd.AddCommand(group.GroupCmd)
|
||||||
RootCmd.AddCommand(create.CreateCmd)
|
RootCmd.AddCommand(account.AccountCmd)
|
||||||
|
RootCmd.AddCommand(message.MessageCmd)
|
||||||
}
|
}
|
||||||
|
|
||||||
// initConfig reads in config file and ENV variables if set.
|
// initConfig reads in config file and ENV variables if set.
|
||||||
|
|
|
@ -4,6 +4,7 @@ import (
|
||||||
"log"
|
"log"
|
||||||
|
|
||||||
"gitlab.com/signald/signald-go/signald"
|
"gitlab.com/signald/signald-go/signald"
|
||||||
|
"gitlab.com/signald/signald-go/signald/client-protocol/v0"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
|
@ -17,3 +18,12 @@ func Must(err error) {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func GetResponse(c chan v0.LegacyResponse, id string) v0.LegacyResponse {
|
||||||
|
for {
|
||||||
|
message := <-c
|
||||||
|
if message.ID == id {
|
||||||
|
return message
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue