1
0
mirror of https://github.com/rancher/os.git synced 2025-06-26 06:51:40 +00:00
os/cmd/network/network.go

84 lines
2.0 KiB
Go
Raw Normal View History

2015-03-02 23:03:21 +00:00
package network
import (
2015-12-10 15:56:15 +00:00
"bufio"
2015-03-02 23:03:21 +00:00
"fmt"
2015-12-10 15:56:15 +00:00
"io/ioutil"
2015-03-02 23:03:21 +00:00
"os"
"os/exec"
2015-12-10 15:56:15 +00:00
"strings"
2015-03-02 23:03:21 +00:00
log "github.com/Sirupsen/logrus"
"github.com/docker/libnetwork/resolvconf"
2015-07-29 07:45:06 +00:00
"github.com/rancher/netconf"
"github.com/rancher/os/cmd/cloudinit"
"github.com/rancher/os/config"
2015-03-02 23:03:21 +00:00
)
const (
NETWORK_DONE = "/var/run/network.done"
WAIT_FOR_NETWORK = "wait-for-network"
)
func sendTerm(proc string) {
cmd := exec.Command("killall", "-TERM", proc)
cmd.Stderr = os.Stderr
cmd.Stdout = os.Stdout
cmd.Run()
}
2015-03-02 23:03:21 +00:00
func Main() {
args := os.Args
if len(args) > 1 {
fmt.Println("call " + args[0] + " to load network config from cloud-config.yml")
2015-03-02 23:03:21 +00:00
return
}
os.Remove(NETWORK_DONE) // ignore error
2015-03-02 23:03:21 +00:00
cfg, err := config.LoadConfig()
if err != nil {
log.Fatal(err)
}
2015-12-10 15:56:15 +00:00
hostname, _ := cloudinit.SetHostname(cfg) // ignore error
log.Infof("Network: hostname: '%s'", hostname)
2015-07-29 07:45:06 +00:00
if err := netconf.ApplyNetworkConfigs(&cfg.Rancher.Network); err != nil {
log.Error(err)
}
2015-12-10 15:56:15 +00:00
hostname, _ = cloudinit.SetHostname(cfg) // ignore error
log.Infof("Network: hostname: '%s' (from DHCP, if not set by cloud-config)", hostname)
if hostname != "" {
hosts, err := os.Open("/etc/hosts")
defer hosts.Close()
if err != nil {
log.Fatal(err)
}
lines := bufio.NewScanner(hosts)
hostsContent := ""
for lines.Scan() {
line := strings.TrimSpace(lines.Text())
fields := strings.Fields(line)
if len(fields) > 0 && fields[0] == "127.0.1.1" {
hostsContent += "127.0.1.1 " + hostname + "\n"
continue
}
hostsContent += line + "\n"
}
if err := ioutil.WriteFile("/etc/hosts", []byte(hostsContent), 0600); err != nil {
log.Error(err)
}
}
if cfg.Rancher.Network.Dns.Override {
log.WithFields(log.Fields{"nameservers": cfg.Rancher.Network.Dns.Nameservers}).Info("Override nameservers")
if _, err := resolvconf.Build("/etc/resolv.conf", cfg.Rancher.Network.Dns.Nameservers, cfg.Rancher.Network.Dns.Search, nil); err != nil {
log.Error(err)
}
2015-03-02 23:03:21 +00:00
}
2015-12-20 05:20:07 +00:00
if f, err := os.Create(NETWORK_DONE); err != nil {
log.Error(err)
2015-12-20 05:20:07 +00:00
} else {
f.Close()
}
sendTerm(WAIT_FOR_NETWORK)
select {}
2015-03-02 23:03:21 +00:00
}