user groups commands

This commit is contained in:
abhishek9686 2024-08-24 13:40:41 +05:30
parent d67fecf27f
commit a5c66f1b87
2 changed files with 121 additions and 14 deletions

112
cli/cmd/user/groups.go Normal file
View file

@ -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)
}

View file

@ -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)
}