refactor(cmd/fw): wtf is that error handling
This commit is contained in:
@@ -16,13 +16,14 @@ var (
|
|||||||
port int
|
port int
|
||||||
protocol string
|
protocol string
|
||||||
)
|
)
|
||||||
|
|
||||||
var UnbanCmd = &cobra.Command{
|
var UnbanCmd = &cobra.Command{
|
||||||
Use: "unban",
|
Use: "unban",
|
||||||
Short: "Unban IP",
|
Short: "Unban IP",
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
|
err := func() error {
|
||||||
if len(args) == 0 {
|
if len(args) == 0 {
|
||||||
fmt.Println("IP can't be empty")
|
return fmt.Errorf("IP can't be empty")
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
if ttl_fw == "" {
|
if ttl_fw == "" {
|
||||||
ttl_fw = "1y"
|
ttl_fw = "1y"
|
||||||
@@ -30,39 +31,38 @@ var UnbanCmd = &cobra.Command{
|
|||||||
ip := args[0]
|
ip := args[0]
|
||||||
db, err := storage.NewBanWriter()
|
db, err := storage.NewBanWriter()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println(err)
|
return err
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
cfg, err := config.LoadConfig()
|
cfg, err := config.LoadConfig()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println(err)
|
return err
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
fw := cfg.Firewall.Name
|
fw := cfg.Firewall.Name
|
||||||
b := blocker.GetBlocker(fw, cfg.Firewall.Config)
|
b := blocker.GetBlocker(fw, cfg.Firewall.Config)
|
||||||
if ip == "" {
|
if ip == "" {
|
||||||
fmt.Println("IP can't be empty")
|
return fmt.Errorf("IP can't be empty")
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
if net.ParseIP(ip) == nil {
|
if net.ParseIP(ip) == nil {
|
||||||
fmt.Println("Invalid IP")
|
return fmt.Errorf("Invalid IP")
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println(err)
|
return err
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
err = b.Unban(ip)
|
err = b.Unban(ip)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println(err)
|
return err
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
err = db.RemoveBan(ip)
|
err = db.RemoveBan(ip)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
fmt.Println("IP unblocked successfully!")
|
||||||
|
return nil
|
||||||
|
}()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println(err)
|
fmt.Println(err)
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
fmt.Println("IP unblocked successfully!")
|
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -70,9 +70,9 @@ var BanCmd = &cobra.Command{
|
|||||||
Use: "ban",
|
Use: "ban",
|
||||||
Short: "Ban IP",
|
Short: "Ban IP",
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
|
err := func() error {
|
||||||
if len(args) == 0 {
|
if len(args) == 0 {
|
||||||
fmt.Println("IP can't be empty")
|
return fmt.Errorf("IP can't be empty")
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
if ttl_fw == "" {
|
if ttl_fw == "" {
|
||||||
ttl_fw = "1y"
|
ttl_fw = "1y"
|
||||||
@@ -80,39 +80,38 @@ var BanCmd = &cobra.Command{
|
|||||||
ip := args[0]
|
ip := args[0]
|
||||||
db, err := storage.NewBanWriter()
|
db, err := storage.NewBanWriter()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println(err)
|
return err
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
cfg, err := config.LoadConfig()
|
cfg, err := config.LoadConfig()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println(err)
|
return err
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
fw := cfg.Firewall.Name
|
fw := cfg.Firewall.Name
|
||||||
b := blocker.GetBlocker(fw, cfg.Firewall.Config)
|
b := blocker.GetBlocker(fw, cfg.Firewall.Config)
|
||||||
if ip == "" {
|
if ip == "" {
|
||||||
fmt.Println("IP can't be empty")
|
return fmt.Errorf("IP can't be empty")
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
if net.ParseIP(ip) == nil {
|
if net.ParseIP(ip) == nil {
|
||||||
fmt.Println("Invalid IP")
|
return fmt.Errorf("Invalid IP")
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println(err)
|
return err
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
err = b.Ban(ip)
|
err = b.Ban(ip)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println(err)
|
return err
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
err = db.AddBan(ip, ttl_fw, "manual ban")
|
err = db.AddBan(ip, ttl_fw, "manual ban")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
fmt.Println("IP blocked successfully!")
|
||||||
|
return err
|
||||||
|
}()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println(err)
|
fmt.Println(err)
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
fmt.Println("IP blocked successfully!")
|
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user