2015-03-02 23:03:21 +00:00
|
|
|
package network
|
|
|
|
|
|
|
|
import (
|
2015-12-10 15:56:15 +00:00
|
|
|
"bufio"
|
2016-04-08 20:04:35 +00:00
|
|
|
"flag"
|
2015-12-10 15:56:15 +00:00
|
|
|
"io/ioutil"
|
2015-03-02 23:03:21 +00:00
|
|
|
"os"
|
2015-11-06 16:53:00 +00:00
|
|
|
"os/exec"
|
2015-12-10 15:56:15 +00:00
|
|
|
"strings"
|
2015-03-02 23:03:21 +00:00
|
|
|
|
|
|
|
log "github.com/Sirupsen/logrus"
|
|
|
|
|
2015-11-30 11:06:21 +00:00
|
|
|
"github.com/docker/libnetwork/resolvconf"
|
2015-07-29 07:45:06 +00:00
|
|
|
"github.com/rancher/netconf"
|
2015-11-04 23:06:17 +00:00
|
|
|
"github.com/rancher/os/cmd/cloudinit"
|
2015-10-12 11:50:17 +00:00
|
|
|
"github.com/rancher/os/config"
|
2015-03-02 23:03:21 +00:00
|
|
|
)
|
|
|
|
|
2015-11-06 16:53:00 +00:00
|
|
|
const (
|
|
|
|
NETWORK_DONE = "/var/run/network.done"
|
|
|
|
WAIT_FOR_NETWORK = "wait-for-network"
|
|
|
|
)
|
|
|
|
|
2016-04-08 20:04:35 +00:00
|
|
|
var (
|
|
|
|
daemon bool
|
|
|
|
flags *flag.FlagSet
|
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
flags = flag.NewFlagSet(os.Args[0], flag.ContinueOnError)
|
|
|
|
flags.BoolVar(&daemon, "daemon", false, "run dhcpd as daemon")
|
|
|
|
}
|
|
|
|
|
2015-11-06 16:53:00 +00:00
|
|
|
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() {
|
2016-04-08 20:04:35 +00:00
|
|
|
flags.Parse(os.Args[1:])
|
|
|
|
|
|
|
|
log.Infof("Running network: daemon=%v", daemon)
|
|
|
|
|
2015-11-06 16:53:00 +00:00
|
|
|
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 {
|
2015-11-30 11:06:21 +00:00
|
|
|
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)
|
|
|
|
}
|
|
|
|
}
|
2015-11-30 11:06:21 +00:00
|
|
|
if cfg.Rancher.Network.Dns.Override {
|
|
|
|
log.WithFields(log.Fields{"nameservers": cfg.Rancher.Network.Dns.Nameservers}).Info("Override nameservers")
|
2015-11-26 12:41:42 +00:00
|
|
|
if _, err := resolvconf.Build("/etc/resolv.conf", cfg.Rancher.Network.Dns.Nameservers, cfg.Rancher.Network.Dns.Search, nil); err != nil {
|
2015-11-30 11:06:21 +00:00
|
|
|
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 {
|
2015-11-06 16:53:00 +00:00
|
|
|
log.Error(err)
|
2015-12-20 05:20:07 +00:00
|
|
|
} else {
|
|
|
|
f.Close()
|
2015-11-06 16:53:00 +00:00
|
|
|
}
|
|
|
|
sendTerm(WAIT_FOR_NETWORK)
|
2016-04-08 20:04:35 +00:00
|
|
|
|
|
|
|
if daemon {
|
|
|
|
select {}
|
|
|
|
}
|
2015-03-02 23:03:21 +00:00
|
|
|
}
|