add:remove server config func
This commit is contained in:
18
README.md
Normal file
18
README.md
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
# Main Repo is self-hosted on [Gitea](https://git.kokopi.dev/kokopi/filepass)
|
||||||
|
- This is a mirror
|
||||||
|
|
||||||
|
# Filepass
|
||||||
|
|
||||||
|
Originally hacked with bash, re-written in golang into a TUI.
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
```
|
||||||
|
./build.sh
|
||||||
|
|
||||||
|
# restart shell or w.e
|
||||||
|
# should be able to just run:
|
||||||
|
|
||||||
|
filepass
|
||||||
|
```
|
||||||
|
|
||||||
3
internal/pages/remove_server.go
Normal file
3
internal/pages/remove_server.go
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
package pages
|
||||||
|
|
||||||
|
type RemoveServerPageMsg struct{}
|
||||||
@@ -69,6 +69,14 @@ func (c *ConfigService) AddServer(name string, s Server) error {
|
|||||||
return c.flush()
|
return c.flush()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *ConfigService) RemoveServer(name string) error {
|
||||||
|
if !c.HasServer(name) {
|
||||||
|
return fmt.Errorf("server %q not found", name)
|
||||||
|
}
|
||||||
|
delete(c.servers, name)
|
||||||
|
return c.flush()
|
||||||
|
}
|
||||||
|
|
||||||
func (c *ConfigService) flush() error {
|
func (c *ConfigService) flush() error {
|
||||||
data, err := json.MarshalIndent(c.servers, "", " ")
|
data, err := json.MarshalIndent(c.servers, "", " ")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|||||||
@@ -18,6 +18,7 @@ const (
|
|||||||
pageFileAction
|
pageFileAction
|
||||||
pageSend
|
pageSend
|
||||||
pageCleanAll
|
pageCleanAll
|
||||||
|
pageRemoveServer
|
||||||
)
|
)
|
||||||
|
|
||||||
type TUIInterface struct {
|
type TUIInterface struct {
|
||||||
|
|||||||
@@ -22,6 +22,11 @@ type serverAddedMsg struct {
|
|||||||
servers map[string]services.Server
|
servers map[string]services.Server
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type serverRemovedMsg struct {
|
||||||
|
name string
|
||||||
|
servers map[string]services.Server
|
||||||
|
}
|
||||||
|
|
||||||
type clearFlashMsg struct{}
|
type clearFlashMsg struct{}
|
||||||
|
|
||||||
type storageFilesMsg struct {
|
type storageFilesMsg struct {
|
||||||
@@ -177,6 +182,21 @@ func (m TUIInterface) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
|
|||||||
m.FileOpSuccess = ""
|
m.FileOpSuccess = ""
|
||||||
return m, nil
|
return m, nil
|
||||||
|
|
||||||
|
case pages.RemoveServerPageMsg:
|
||||||
|
m.Page = pageRemoveServer
|
||||||
|
m.Selected = 0
|
||||||
|
return m, nil
|
||||||
|
|
||||||
|
case serverRemovedMsg:
|
||||||
|
m.Servers = msg.servers
|
||||||
|
m.ServerNames = sortedServerNames(msg.servers)
|
||||||
|
m.NoServers = len(msg.servers) == 0
|
||||||
|
m.Page = pageConfig
|
||||||
|
m.MenuItems = pages.ConfigMenuItems()
|
||||||
|
m.Selected = 0
|
||||||
|
m.FlashMsg = "✓ \"" + msg.name + "\" removed."
|
||||||
|
return m, clearFlashAfter(2 * time.Second)
|
||||||
|
|
||||||
case pages.CleanAllPageMsg:
|
case pages.CleanAllPageMsg:
|
||||||
m.Page = pageCleanAll
|
m.Page = pageCleanAll
|
||||||
m.CleanInput = newCleanInput()
|
m.CleanInput = newCleanInput()
|
||||||
@@ -266,6 +286,9 @@ func (m TUIInterface) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
|
|||||||
if m.Page == pageCleanAll {
|
if m.Page == pageCleanAll {
|
||||||
return m.updateCleanAll(msg)
|
return m.updateCleanAll(msg)
|
||||||
}
|
}
|
||||||
|
if m.Page == pageRemoveServer {
|
||||||
|
return m.updateRemoveServer(msg)
|
||||||
|
}
|
||||||
|
|
||||||
switch msg.String() {
|
switch msg.String() {
|
||||||
case "up", "k":
|
case "up", "k":
|
||||||
@@ -288,7 +311,9 @@ func (m TUIInterface) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
|
|||||||
return m, func() tea.Msg { return pages.AddServerPageMsg{} }
|
return m, func() tea.Msg { return pages.AddServerPageMsg{} }
|
||||||
case "server":
|
case "server":
|
||||||
return m, func() tea.Msg { return pages.SelectServerPageMsg{} }
|
return m, func() tea.Msg { return pages.SelectServerPageMsg{} }
|
||||||
// TODO: "edit", "remove"
|
case "remove":
|
||||||
|
return m, func() tea.Msg { return pages.RemoveServerPageMsg{} }
|
||||||
|
// TODO: "edit"
|
||||||
}
|
}
|
||||||
case "ctrl+c":
|
case "ctrl+c":
|
||||||
m.Quitting = true
|
m.Quitting = true
|
||||||
@@ -473,6 +498,42 @@ func (m TUIInterface) updateSend(msg tea.KeyPressMsg) (tea.Model, tea.Cmd) {
|
|||||||
return m, nil
|
return m, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (m TUIInterface) updateRemoveServer(msg tea.KeyPressMsg) (tea.Model, tea.Cmd) {
|
||||||
|
last := len(m.ServerNames) - 1
|
||||||
|
switch msg.String() {
|
||||||
|
case "up", "k":
|
||||||
|
if m.Selected > 0 {
|
||||||
|
m.Selected--
|
||||||
|
}
|
||||||
|
case "down", "j":
|
||||||
|
if m.Selected < last {
|
||||||
|
m.Selected++
|
||||||
|
}
|
||||||
|
case "enter":
|
||||||
|
if m.Selected >= 0 && m.Selected < len(m.ServerNames) {
|
||||||
|
name := m.ServerNames[m.Selected]
|
||||||
|
if err := m.Services.Config.RemoveServer(name); err != nil {
|
||||||
|
// surface error via flash on config page
|
||||||
|
m.Page = pageConfig
|
||||||
|
m.MenuItems = pages.ConfigMenuItems()
|
||||||
|
m.Selected = 0
|
||||||
|
m.FlashMsg = "✗ " + err.Error()
|
||||||
|
return m, clearFlashAfter(3 * time.Second)
|
||||||
|
}
|
||||||
|
servers := m.Services.Config.Servers()
|
||||||
|
return m, func() tea.Msg {
|
||||||
|
return serverRemovedMsg{name: name, servers: servers}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
case "ctrl+c":
|
||||||
|
m.Quitting = true
|
||||||
|
return m, tea.Quit
|
||||||
|
case "esc":
|
||||||
|
return m, func() tea.Msg { return pages.ConfigPageMsg{} }
|
||||||
|
}
|
||||||
|
return m, nil
|
||||||
|
}
|
||||||
|
|
||||||
func (m TUIInterface) updateCleanAll(msg tea.KeyPressMsg) (tea.Model, tea.Cmd) {
|
func (m TUIInterface) updateCleanAll(msg tea.KeyPressMsg) (tea.Model, tea.Cmd) {
|
||||||
if m.CleanOpLoading {
|
if m.CleanOpLoading {
|
||||||
if msg.String() == "ctrl+c" {
|
if msg.String() == "ctrl+c" {
|
||||||
|
|||||||
@@ -38,6 +38,8 @@ func (m TUIInterface) subtitle() string {
|
|||||||
return "Send File"
|
return "Send File"
|
||||||
case pageCleanAll:
|
case pageCleanAll:
|
||||||
return "Clean All"
|
return "Clean All"
|
||||||
|
case pageRemoveServer:
|
||||||
|
return "Remove Server"
|
||||||
default:
|
default:
|
||||||
return "Secure file transfer"
|
return "Secure file transfer"
|
||||||
}
|
}
|
||||||
@@ -71,6 +73,8 @@ func (m TUIInterface) View() tea.View {
|
|||||||
body = m.viewSend()
|
body = m.viewSend()
|
||||||
case pageCleanAll:
|
case pageCleanAll:
|
||||||
body = m.viewCleanAll()
|
body = m.viewCleanAll()
|
||||||
|
case pageRemoveServer:
|
||||||
|
body = m.viewRemoveServer()
|
||||||
default:
|
default:
|
||||||
body = m.viewMenu()
|
body = m.viewMenu()
|
||||||
}
|
}
|
||||||
@@ -114,6 +118,12 @@ func (m TUIInterface) View() tea.View {
|
|||||||
footerHint("enter", "confirm") +
|
footerHint("enter", "confirm") +
|
||||||
footerSep() +
|
footerSep() +
|
||||||
footerHint("esc", "back")
|
footerHint("esc", "back")
|
||||||
|
case pageRemoveServer:
|
||||||
|
footerStr = footerHint("↑↓", "navigate") +
|
||||||
|
footerSep() +
|
||||||
|
footerHint("enter", "remove") +
|
||||||
|
footerSep() +
|
||||||
|
footerHint("esc", "back")
|
||||||
case pageCleanAll:
|
case pageCleanAll:
|
||||||
footerStr = footerHint("enter", "confirm") +
|
footerStr = footerHint("enter", "confirm") +
|
||||||
footerSep() +
|
footerSep() +
|
||||||
@@ -262,6 +272,17 @@ func (m TUIInterface) viewSend() string {
|
|||||||
return lipgloss.JoinVertical(lipgloss.Left, crumb, queryLine, list)
|
return lipgloss.JoinVertical(lipgloss.Left, crumb, queryLine, list)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (m TUIInterface) viewRemoveServer() string {
|
||||||
|
if len(m.ServerNames) == 0 {
|
||||||
|
return styles.StatusWarnStyle.Render("⚠ No servers configured.")
|
||||||
|
}
|
||||||
|
var rows []string
|
||||||
|
for i, name := range m.ServerNames {
|
||||||
|
rows = append(rows, styles.ServerRowStyle(i == m.Selected, name))
|
||||||
|
}
|
||||||
|
return lipgloss.JoinVertical(lipgloss.Left, rows...)
|
||||||
|
}
|
||||||
|
|
||||||
func (m TUIInterface) viewCleanAll() string {
|
func (m TUIInterface) viewCleanAll() string {
|
||||||
fileCount := len(m.StorageFiles)
|
fileCount := len(m.StorageFiles)
|
||||||
warning := styles.CleanWarningStyle.Render(
|
warning := styles.CleanWarningStyle.Render(
|
||||||
|
|||||||
Reference in New Issue
Block a user