add:remove server config func

This commit is contained in:
2026-04-06 03:36:51 +09:00
parent 83aab9d943
commit 9e9134f659
6 changed files with 113 additions and 1 deletions

18
README.md Normal file
View 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
```

View File

@@ -0,0 +1,3 @@
package pages
type RemoveServerPageMsg struct{}

View File

@@ -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 {

View File

@@ -18,6 +18,7 @@ const (
pageFileAction pageFileAction
pageSend pageSend
pageCleanAll pageCleanAll
pageRemoveServer
) )
type TUIInterface struct { type TUIInterface struct {

View File

@@ -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" {

View File

@@ -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(