From 622340610ad35a58fcb381078c8db4de8e09c439 Mon Sep 17 00:00:00 2001 From: raul Date: Tue, 2 Apr 2024 11:27:48 +0200 Subject: [PATCH] Create client.go --- cmd/client.go | 55 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100644 cmd/client.go diff --git a/cmd/client.go b/cmd/client.go new file mode 100644 index 0000000..aaf2f4e --- /dev/null +++ b/cmd/client.go @@ -0,0 +1,55 @@ +/* +Copyright © 2024 Raul +*/ + +package cmd + +import ( + "fmt" + "net" + "os" + + "github.com/spf13/cobra" +) + +// clientCmd represents the client command +var clientCmd = &cobra.Command{ + Use: "client", + Short: "A brief description of your command", + Long: `A longer description that spans multiple lines and likely contains examples +and usage of using your command. For example: + +Cobra is a CLI library for Go that empowers applications. +This application is a tool to generate the needed files +to quickly create a Cobra application.`, + Run: func(cmd *cobra.Command, args []string) { + client(cmd) + }, +} + +func init() { + rootCmd.AddCommand(clientCmd) + + // Here you will define your flags and configuration settings. + + // Cobra supports Persistent Flags which will work for this command + // and all subcommands, e.g.: + // clientCmd.PersistentFlags().String("foo", "", "A help for foo") + clientCmd.Flags().String("ip", "", "Server to connect to") + clientCmd.Flags().String("port", "1302", "Port to connect to") + + // Cobra supports local flags which will only run when this command + // is called directly, e.g.: + // clientCmd.Flags().BoolP("toggle", "t", false, "Help message for toggle") +} + +func client(cmd *cobra.Command) { + port, _ := cmd.Flags().GetString("port") + ip, _ := cmd.Flags().GetString("ip") + if ip == "" { + fmt.Println("Not enough arguments, run \"-h\" parameter to see all the parameters!") + os.Exit(1) + } + socket := ip + ":" + port + net.Dial("tcp", socket) +}