mirror of
				https://github.com/siderolabs/talos.git
				synced 2025-10-26 14:01:39 +01:00 
			
		
		
		
	This implements `osctl cluster destroy` for Firecracker, adds new utility command `osctl cluser show`. Firecracker mode now has control process for firecracker VMs, allowing clean reboots and background operations. Lots of small fixes to Firecracker mode, clean CNI shutdown, cleaning up netns, etc. Signed-off-by: Andrey Smirnov <smirnov.andrey@gmail.com>
		
			
				
	
	
		
			75 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // This Source Code Form is subject to the terms of the Mozilla Public
 | |
| // License, v. 2.0. If a copy of the MPL was not distributed with this
 | |
| // file, You can obtain one at http://mozilla.org/MPL/2.0/.
 | |
| 
 | |
| package docker
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"net"
 | |
| 	"strconv"
 | |
| 
 | |
| 	"github.com/talos-systems/talos/internal/pkg/provision"
 | |
| 	"github.com/talos-systems/talos/pkg/config/machine"
 | |
| )
 | |
| 
 | |
| func (p *provisioner) Reflect(ctx context.Context, clusterName, stateDirectory string) (provision.Cluster, error) {
 | |
| 	res := &result{
 | |
| 		clusterInfo: provision.ClusterInfo{
 | |
| 			ClusterName: clusterName,
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	// find network assuming network name == cluster name
 | |
| 	networks, err := p.listNetworks(ctx, clusterName)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	if len(networks) > 0 {
 | |
| 		network := networks[0]
 | |
| 
 | |
| 		var cidr *net.IPNet
 | |
| 		_, cidr, err = net.ParseCIDR(network.IPAM.Config[0].Subnet)
 | |
| 
 | |
| 		if err != nil {
 | |
| 			return nil, err
 | |
| 		}
 | |
| 
 | |
| 		res.clusterInfo.Network.Name = network.Name
 | |
| 		res.clusterInfo.Network.CIDR = *cidr
 | |
| 		res.clusterInfo.Network.GatewayAddr = net.ParseIP(network.IPAM.Config[0].Gateway)
 | |
| 
 | |
| 		mtuStr := network.Options["com.docker.network.driver.mtu"]
 | |
| 		res.clusterInfo.Network.MTU, err = strconv.Atoi(mtuStr)
 | |
| 
 | |
| 		if err != nil {
 | |
| 			return nil, err
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	// find nodes (containers)
 | |
| 	nodes, err := p.listNodes(ctx, clusterName)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	for _, node := range nodes {
 | |
| 		t, err := machine.ParseType(node.Labels["talos.type"])
 | |
| 		if err != nil {
 | |
| 			return nil, err
 | |
| 		}
 | |
| 
 | |
| 		res.clusterInfo.Nodes = append(res.clusterInfo.Nodes,
 | |
| 			provision.NodeInfo{
 | |
| 				ID:   node.ID,
 | |
| 				Name: node.Names[0],
 | |
| 				Type: t,
 | |
| 
 | |
| 				PrivateIP: net.ParseIP(node.NetworkSettings.Networks[res.clusterInfo.Network.Name].IPAddress),
 | |
| 			})
 | |
| 	}
 | |
| 
 | |
| 	return res, nil
 | |
| }
 |