mirror of https://github.com/k3d-io/k3d
parent
2162504ee1
commit
831e58fdce
@ -0,0 +1,120 @@ |
||||
/* |
||||
Copyright © 2020-2021 The k3d Author(s) |
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy |
||||
of this software and associated documentation files (the "Software"), to deal |
||||
in the Software without restriction, including without limitation the rights |
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
||||
copies of the Software, and to permit persons to whom the Software is |
||||
furnished to do so, subject to the following conditions: |
||||
|
||||
The above copyright notice and this permission notice shall be included in |
||||
all copies or substantial portions of the Software. |
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN |
||||
THE SOFTWARE. |
||||
*/ |
||||
package cluster |
||||
|
||||
import ( |
||||
"github.com/rancher/k3d/v4/cmd/util" |
||||
cliutil "github.com/rancher/k3d/v4/cmd/util" |
||||
"github.com/rancher/k3d/v4/pkg/client" |
||||
conf "github.com/rancher/k3d/v4/pkg/config/v1alpha3" |
||||
"github.com/rancher/k3d/v4/pkg/runtimes" |
||||
k3d "github.com/rancher/k3d/v4/pkg/types" |
||||
log "github.com/sirupsen/logrus" |
||||
"github.com/spf13/cobra" |
||||
) |
||||
|
||||
// NewCmdNodeEdit returns a new cobra command
|
||||
func NewCmdNodeEdit() *cobra.Command { |
||||
|
||||
// create new cobra command
|
||||
cmd := &cobra.Command{ |
||||
Use: "edit NAME", |
||||
Short: "[EXPERIMENTAL] Edit cluster(s).", |
||||
Long: `[EXPERIMENTAL] Edit cluster(s).`, |
||||
Args: cobra.ExactArgs(1), |
||||
Aliases: []string{"update"}, |
||||
ValidArgsFunction: util.ValidArgsAvailableNodes, |
||||
Run: func(cmd *cobra.Command, args []string) { |
||||
|
||||
existingCluster, changeset := parseEditClusterCmd(cmd, args) |
||||
|
||||
log.Debugf("===== Current =====\n%+v\n===== Changeset =====\n%+v\n", existingCluster, changeset) |
||||
|
||||
log.Infof("Successfully updated %s", existingCluster.Name) |
||||
|
||||
}, |
||||
} |
||||
|
||||
// add subcommands
|
||||
|
||||
// add flags
|
||||
cmd.Flags().StringArray("port-add", nil, "[EXPERIMENTAL] Map ports from the node containers (via the serverlb) to the host (Format: `[HOST:][HOSTPORT:]CONTAINERPORT[/PROTOCOL][@NODEFILTER]`)\n - Example: `k3d node edit k3d-mycluster-serverlb --port-add 8080:80`") |
||||
|
||||
// done
|
||||
return cmd |
||||
} |
||||
|
||||
// parseEditClusterCmd parses the command input into variables required to delete nodes
|
||||
func parseEditClusterCmd(cmd *cobra.Command, args []string) (*k3d.Cluster, *conf.SimpleConfig) { |
||||
|
||||
existingCluster, err := client.ClusterGet(cmd.Context(), runtimes.SelectedRuntime, &k3d.Cluster{Name: args[0]}) |
||||
if err != nil { |
||||
log.Fatalln(err) |
||||
} |
||||
|
||||
if existingCluster == nil { |
||||
log.Infof("Cluster %s not found", args[0]) |
||||
return nil, nil |
||||
} |
||||
|
||||
changeset := conf.SimpleConfig{} |
||||
|
||||
/* |
||||
* --port-add |
||||
*/ |
||||
portFlags, err := cmd.Flags().GetStringArray("port-add") |
||||
if err != nil { |
||||
log.Errorln(err) |
||||
return nil, nil |
||||
} |
||||
|
||||
// init portmap
|
||||
changeset.Ports = []conf.PortWithNodeFilters{} |
||||
|
||||
portFilterMap := make(map[string][]string, 1) |
||||
for _, portFlag := range portFlags { |
||||
|
||||
// split node filter from the specified volume
|
||||
portmap, filters, err := cliutil.SplitFiltersFromFlag(portFlag) |
||||
if err != nil { |
||||
log.Fatalln(err) |
||||
} |
||||
|
||||
// create new entry or append filter to existing entry
|
||||
if _, exists := portFilterMap[portmap]; exists { |
||||
log.Fatalln("Same Portmapping can not be used for multiple nodes") |
||||
} else { |
||||
portFilterMap[portmap] = filters |
||||
} |
||||
} |
||||
|
||||
for port, nodeFilters := range portFilterMap { |
||||
changeset.Ports = append(changeset.Ports, conf.PortWithNodeFilters{ |
||||
Port: port, |
||||
NodeFilters: nodeFilters, |
||||
}) |
||||
} |
||||
|
||||
log.Tracef("PortFilterMap: %+v", portFilterMap) |
||||
|
||||
return existingCluster, &changeset |
||||
} |
Loading…
Reference in new issue