mirror of
https://github.com/swissmakers/fail2ban-ui.git
synced 2026-04-17 05:53:15 +02:00
Fix loading wrong filter problem, implement creation and deletion of filters and jails, fix some css mismatches, update the handlers and routes
This commit is contained in:
@@ -118,14 +118,21 @@ func (ac *AgentConnector) RestartWithMode(ctx context.Context) (string, error) {
|
||||
return "restart", nil
|
||||
}
|
||||
|
||||
func (ac *AgentConnector) GetFilterConfig(ctx context.Context, jail string) (string, error) {
|
||||
func (ac *AgentConnector) GetFilterConfig(ctx context.Context, jail string) (string, string, error) {
|
||||
var resp struct {
|
||||
Config string `json:"config"`
|
||||
Config string `json:"config"`
|
||||
FilePath string `json:"filePath"`
|
||||
}
|
||||
if err := ac.get(ctx, fmt.Sprintf("/v1/filters/%s", url.PathEscape(jail)), &resp); err != nil {
|
||||
return "", err
|
||||
return "", "", err
|
||||
}
|
||||
return resp.Config, nil
|
||||
// If agent doesn't return filePath, construct it (agent should handle .local priority)
|
||||
filePath := resp.FilePath
|
||||
if filePath == "" {
|
||||
// Default to .local path (agent should handle .local priority on its side)
|
||||
filePath = fmt.Sprintf("/etc/fail2ban/filter.d/%s.local", jail)
|
||||
}
|
||||
return resp.Config, filePath, nil
|
||||
}
|
||||
|
||||
func (ac *AgentConnector) SetFilterConfig(ctx context.Context, jail, content string) error {
|
||||
@@ -196,6 +203,14 @@ func (ac *AgentConnector) put(ctx context.Context, endpoint string, payload any,
|
||||
return ac.do(req, out)
|
||||
}
|
||||
|
||||
func (ac *AgentConnector) delete(ctx context.Context, endpoint string, out any) error {
|
||||
req, err := ac.newRequest(ctx, http.MethodDelete, endpoint, nil)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
return ac.do(req, out)
|
||||
}
|
||||
|
||||
func (ac *AgentConnector) newRequest(ctx context.Context, method, endpoint string, payload any) (*http.Request, error) {
|
||||
u := *ac.base
|
||||
u.Path = path.Join(ac.base.Path, strings.TrimPrefix(endpoint, "/"))
|
||||
@@ -310,14 +325,21 @@ func (ac *AgentConnector) TestFilter(ctx context.Context, filterName string, log
|
||||
}
|
||||
|
||||
// GetJailConfig implements Connector.
|
||||
func (ac *AgentConnector) GetJailConfig(ctx context.Context, jail string) (string, error) {
|
||||
func (ac *AgentConnector) GetJailConfig(ctx context.Context, jail string) (string, string, error) {
|
||||
var resp struct {
|
||||
Config string `json:"config"`
|
||||
Config string `json:"config"`
|
||||
FilePath string `json:"filePath"`
|
||||
}
|
||||
if err := ac.get(ctx, fmt.Sprintf("/v1/jails/%s/config", url.PathEscape(jail)), &resp); err != nil {
|
||||
return "", err
|
||||
return "", "", err
|
||||
}
|
||||
return resp.Config, nil
|
||||
// If agent doesn't return filePath, construct it (agent should handle .local priority)
|
||||
filePath := resp.FilePath
|
||||
if filePath == "" {
|
||||
// Default to .local path (agent should handle .local priority on its side)
|
||||
filePath = fmt.Sprintf("/etc/fail2ban/jail.d/%s.local", jail)
|
||||
}
|
||||
return resp.Config, filePath, nil
|
||||
}
|
||||
|
||||
// SetJailConfig implements Connector.
|
||||
@@ -415,3 +437,31 @@ func (ac *AgentConnector) EnsureJailLocalStructure(ctx context.Context) error {
|
||||
// For now, we'll try calling it and handle the error gracefully
|
||||
return ac.post(ctx, "/v1/jails/ensure-structure", nil, nil)
|
||||
}
|
||||
|
||||
// CreateJail implements Connector.
|
||||
func (ac *AgentConnector) CreateJail(ctx context.Context, jailName, content string) error {
|
||||
payload := map[string]interface{}{
|
||||
"name": jailName,
|
||||
"content": content,
|
||||
}
|
||||
return ac.post(ctx, "/v1/jails", payload, nil)
|
||||
}
|
||||
|
||||
// DeleteJail implements Connector.
|
||||
func (ac *AgentConnector) DeleteJail(ctx context.Context, jailName string) error {
|
||||
return ac.delete(ctx, fmt.Sprintf("/v1/jails/%s", jailName), nil)
|
||||
}
|
||||
|
||||
// CreateFilter implements Connector.
|
||||
func (ac *AgentConnector) CreateFilter(ctx context.Context, filterName, content string) error {
|
||||
payload := map[string]interface{}{
|
||||
"name": filterName,
|
||||
"content": content,
|
||||
}
|
||||
return ac.post(ctx, "/v1/filters", payload, nil)
|
||||
}
|
||||
|
||||
// DeleteFilter implements Connector.
|
||||
func (ac *AgentConnector) DeleteFilter(ctx context.Context, filterName string) error {
|
||||
return ac.delete(ctx, fmt.Sprintf("/v1/filters/%s", filterName), nil)
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user