mirror of
https://github.com/gravitl/netmaker.git
synced 2025-10-06 03:46:02 +08:00
user groups commands
This commit is contained in:
parent
d67fecf27f
commit
a5c66f1b87
2 changed files with 121 additions and 14 deletions
112
cli/cmd/user/groups.go
Normal file
112
cli/cmd/user/groups.go
Normal 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)
|
||||
}
|
|
@ -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)
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue