abhishek9686 преди 1 година
родител
ревизия
a5c66f1b87
променени са 2 файла, в които са добавени 121 реда и са изтрити 14 реда
  1. 112 0
      cli/cmd/user/groups.go
  2. 9 14
      cli/functions/user.go

+ 112 - 0
cli/cmd/user/groups.go

@@ -0,0 +1,112 @@
+package user
+
+import (
+	"fmt"
+	"os"
+	"strings"
+
+	"github.com/gravitl/netmaker/cli/cmd/commons"
+	"github.com/gravitl/netmaker/cli/functions"
+	"github.com/gravitl/netmaker/models"
+	"github.com/guumaster/tablewriter"
+	"github.com/spf13/cobra"
+)
+
+var userGroupCmd = &cobra.Command{
+	Use:   "group",
+	Args:  cobra.NoArgs,
+	Short: "Manage User Groups",
+	Long:  `Manage User Groups`,
+}
+
+// List Roles
+var (
+	groupID string
+)
+var userGroupListCmd = &cobra.Command{
+	Use:   "list",
+	Args:  cobra.NoArgs,
+	Short: "List all user groups",
+	Long:  `List all user groups`,
+	Run: func(cmd *cobra.Command, args []string) {
+		data := functions.ListUserGrps()
+		userGrps := data.Response.([]models.UserGroup)
+		switch commons.OutputFormat {
+		case commons.JsonOutput:
+			functions.PrettyPrint(data)
+		default:
+			table := tablewriter.NewWriter(os.Stdout)
+			h := []string{"ID", "MetaData", "Network Roles"}
+			table.SetHeader(h)
+			for _, d := range userGrps {
+
+				roleInfoStr := ""
+				for netID, netRoleMap := range d.NetworkRoles {
+					roleList := []string{}
+					for roleID := range netRoleMap {
+						roleList = append(roleList, roleID.String())
+					}
+					roleInfoStr += fmt.Sprintf("[%s]: %s", netID, strings.Join(roleList, ","))
+				}
+				e := []string{d.ID.String(), d.MetaData, roleInfoStr}
+				table.Append(e)
+			}
+			table.Render()
+		}
+	},
+}
+
+var userGroupCreateCmd = &cobra.Command{
+	Use:   "create",
+	Args:  cobra.NoArgs,
+	Short: "create user group",
+	Long:  `create user group`,
+	Run: func(cmd *cobra.Command, args []string) {
+		fmt.Println("CLI doesn't support creation of groups currently. Visit the dashboard to create one or refer to our api documentation https://docs.v2.netmaker.io/reference")
+	},
+}
+
+var userGroupDeleteCmd = &cobra.Command{
+	Use:   "delete",
+	Args:  cobra.NoArgs,
+	Short: "delete user group",
+	Long:  `delete user group`,
+	Run: func(cmd *cobra.Command, args []string) {
+		resp := functions.DeleteUserGrp(groupID)
+		if resp != nil {
+			fmt.Println(resp.Message)
+		}
+	},
+}
+
+var userGroupGetCmd = &cobra.Command{
+	Use:   "get",
+	Args:  cobra.NoArgs,
+	Short: "get user group",
+	Long:  `get user group`,
+	Run: func(cmd *cobra.Command, args []string) {
+		resp := functions.GetUserGrp(groupID)
+		if resp != nil {
+			fmt.Println(resp.Message)
+		}
+	},
+}
+
+func init() {
+	rootCmd.AddCommand(userGroupCmd)
+	// list roles cmd
+	userGroupCmd.AddCommand(userGroupListCmd)
+
+	// create roles cmd
+	userGroupCmd.AddCommand(userGroupCreateCmd)
+
+	// delete role cmd
+	userGroupDeleteCmd.Flags().StringVar(&groupID, "group-id", "", "user role ID")
+	userGroupDeleteCmd.MarkFlagRequired("role-id")
+	userGroupCmd.AddCommand(userGroupDeleteCmd)
+
+	// Get Role
+	userGroupGetCmd.Flags().StringVar(&groupID, "group-id", "", "user role ID")
+	userGroupGetCmd.MarkFlagRequired("group-id")
+	userGroupCmd.AddCommand(userGroupGetCmd)
+}

+ 9 - 14
cli/functions/user.go

@@ -37,13 +37,6 @@ func ListUsers() *[]models.ReturnUser {
 	return request[[]models.ReturnUser](http.MethodGet, "/api/users", nil)
 }
 
-func CreateUserRole(role models.UserRolePermissionTemplate) *models.SuccessResponse {
-	return request[models.SuccessResponse](http.MethodPost, "/api/v1/users/role", role)
-}
-func UpdateUserRole(role models.UserRolePermissionTemplate) *models.SuccessResponse {
-	return request[models.SuccessResponse](http.MethodPut, "/api/v1/users/role", role)
-}
-
 func ListUserRoles() *models.SuccessResponse {
 	return request[models.SuccessResponse](http.MethodGet, "/api/v1/users/roles", nil)
 }
@@ -55,11 +48,13 @@ func GetUserRole(roleID string) *models.SuccessResponse {
 	return request[models.SuccessResponse](http.MethodGet, fmt.Sprintf("/api/v1/users/role?role_id=%s", roleID), nil)
 }
 
-/*
+func ListUserGrps() *models.SuccessResponse {
+	return request[models.SuccessResponse](http.MethodGet, "/api/v1/users/groups", nil)
+}
 
-	r.HandleFunc("/api/v1/users/roles", logic.SecurityCheck(true, http.HandlerFunc(listRoles))).Methods(http.MethodGet)
-	r.HandleFunc("/api/v1/users/role", logic.SecurityCheck(true, http.HandlerFunc(getRole))).Methods(http.MethodGet)
-	r.HandleFunc("/api/v1/users/role", logic.SecurityCheck(true, http.HandlerFunc(createRole))).Methods(http.MethodPost)
-	r.HandleFunc("/api/v1/users/role", logic.SecurityCheck(true, http.HandlerFunc(updateRole))).Methods(http.MethodPut)
-	r.HandleFunc("/api/v1/users/role", logic.SecurityCheck(true, http.HandlerFunc(deleteRole))).Methods(http.MethodDelete)
-*/
+func DeleteUserGrp(grpID string) *models.SuccessResponse {
+	return request[models.SuccessResponse](http.MethodDelete, fmt.Sprintf("/api/v1/users/group?group_id=%s", grpID), nil)
+}
+func GetUserGrp(grpID string) *models.SuccessResponse {
+	return request[models.SuccessResponse](http.MethodGet, fmt.Sprintf("/api/v1/users/group?group_id=%s", grpID), nil)
+}