|
@@ -1,10 +1,8 @@
|
|
|
-package ui
|
|
|
|
|
|
|
+package cmd
|
|
|
|
|
|
|
|
import (
|
|
import (
|
|
|
"errors"
|
|
"errors"
|
|
|
- "log"
|
|
|
|
|
|
|
|
|
|
- "github.com/ayn2op/discordo/internal/config"
|
|
|
|
|
"github.com/ayn2op/discordo/internal/constants"
|
|
"github.com/ayn2op/discordo/internal/constants"
|
|
|
"github.com/diamondburned/arikawa/v3/api"
|
|
"github.com/diamondburned/arikawa/v3/api"
|
|
|
"github.com/gdamore/tcell/v2"
|
|
"github.com/gdamore/tcell/v2"
|
|
@@ -12,27 +10,24 @@ import (
|
|
|
"github.com/zalando/go-keyring"
|
|
"github.com/zalando/go-keyring"
|
|
|
)
|
|
)
|
|
|
|
|
|
|
|
-type Token struct {
|
|
|
|
|
- Value string
|
|
|
|
|
- Error error
|
|
|
|
|
-}
|
|
|
|
|
|
|
+type DoneFn func(token string, err error)
|
|
|
|
|
|
|
|
type LoginForm struct {
|
|
type LoginForm struct {
|
|
|
*tview.Form
|
|
*tview.Form
|
|
|
- Token chan Token
|
|
|
|
|
|
|
+ done DoneFn
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
-func NewLoginForm(cfg *config.Config) *LoginForm {
|
|
|
|
|
|
|
+func NewLoginForm(done DoneFn) *LoginForm {
|
|
|
lf := &LoginForm{
|
|
lf := &LoginForm{
|
|
|
- Form: tview.NewForm(),
|
|
|
|
|
- Token: make(chan Token, 1),
|
|
|
|
|
|
|
+ Form: tview.NewForm(),
|
|
|
|
|
+ done: done,
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
lf.AddInputField("Email", "", 0, nil, nil)
|
|
lf.AddInputField("Email", "", 0, nil, nil)
|
|
|
lf.AddPasswordField("Password", "", 0, 0, nil)
|
|
lf.AddPasswordField("Password", "", 0, 0, nil)
|
|
|
lf.AddPasswordField("Code (optional)", "", 0, 0, nil)
|
|
lf.AddPasswordField("Code (optional)", "", 0, 0, nil)
|
|
|
lf.AddCheckbox("Remember Me", true, nil)
|
|
lf.AddCheckbox("Remember Me", true, nil)
|
|
|
- lf.AddButton("Login", lf.onLoginButtonSelected)
|
|
|
|
|
|
|
+ lf.AddButton("Login", lf.login)
|
|
|
|
|
|
|
|
lf.SetTitle("Login")
|
|
lf.SetTitle("Login")
|
|
|
lf.SetTitleColor(tcell.GetColor(cfg.Theme.TitleColor))
|
|
lf.SetTitleColor(tcell.GetColor(cfg.Theme.TitleColor))
|
|
@@ -46,7 +41,7 @@ func NewLoginForm(cfg *config.Config) *LoginForm {
|
|
|
return lf
|
|
return lf
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
-func (lf *LoginForm) onLoginButtonSelected() {
|
|
|
|
|
|
|
+func (lf *LoginForm) login() {
|
|
|
email := lf.GetFormItem(0).(*tview.InputField).GetText()
|
|
email := lf.GetFormItem(0).(*tview.InputField).GetText()
|
|
|
password := lf.GetFormItem(1).(*tview.InputField).GetText()
|
|
password := lf.GetFormItem(1).(*tview.InputField).GetText()
|
|
|
if email == "" || password == "" {
|
|
if email == "" || password == "" {
|
|
@@ -58,7 +53,10 @@ func (lf *LoginForm) onLoginButtonSelected() {
|
|
|
// Log in using the provided email and password.
|
|
// Log in using the provided email and password.
|
|
|
lr, err := apiClient.Login(email, password)
|
|
lr, err := apiClient.Login(email, password)
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
- lf.Token <- Token{Error: err}
|
|
|
|
|
|
|
+ if lf.done != nil {
|
|
|
|
|
+ lf.done("", err)
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
return
|
|
return
|
|
|
}
|
|
}
|
|
|
|
|
|
|
@@ -66,19 +64,28 @@ func (lf *LoginForm) onLoginButtonSelected() {
|
|
|
if lr.MFA && lr.Token == "" {
|
|
if lr.MFA && lr.Token == "" {
|
|
|
code := lf.GetFormItem(2).(*tview.InputField).GetText()
|
|
code := lf.GetFormItem(2).(*tview.InputField).GetText()
|
|
|
if code == "" {
|
|
if code == "" {
|
|
|
- lf.Token <- Token{Error: errors.New("code required")}
|
|
|
|
|
|
|
+ if lf.done != nil {
|
|
|
|
|
+ lf.done("", errors.New("code required"))
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
return
|
|
return
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
lr, err = apiClient.TOTP(code, lr.Ticket)
|
|
lr, err = apiClient.TOTP(code, lr.Ticket)
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
- lf.Token <- Token{Error: err}
|
|
|
|
|
|
|
+ if lf.done != nil {
|
|
|
|
|
+ lf.done("", err)
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
return
|
|
return
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
if lr.Token == "" {
|
|
if lr.Token == "" {
|
|
|
- lf.Token <- Token{Error: errors.New("missing token")}
|
|
|
|
|
|
|
+ if lf.done != nil {
|
|
|
|
|
+ lf.done("", errors.New("missing token"))
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
return
|
|
return
|
|
|
}
|
|
}
|
|
|
|
|
|
|
@@ -86,10 +93,14 @@ func (lf *LoginForm) onLoginButtonSelected() {
|
|
|
if rememberMe {
|
|
if rememberMe {
|
|
|
go func() {
|
|
go func() {
|
|
|
if err := keyring.Set(constants.Name, "token", lr.Token); err != nil {
|
|
if err := keyring.Set(constants.Name, "token", lr.Token); err != nil {
|
|
|
- log.Println(err)
|
|
|
|
|
|
|
+ if lf.done != nil {
|
|
|
|
|
+ lf.done("", err)
|
|
|
|
|
+ }
|
|
|
}
|
|
}
|
|
|
}()
|
|
}()
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- lf.Token <- Token{Value: lr.Token}
|
|
|
|
|
|
|
+ if lf.done != nil {
|
|
|
|
|
+ lf.done(lr.Token, nil)
|
|
|
|
|
+ }
|
|
|
}
|
|
}
|