2015-03-02 23:03:21 +00:00
|
|
|
package network
|
|
|
|
|
|
|
|
import (
|
2016-11-23 10:49:35 +00:00
|
|
|
"github.com/rancher/os/log"
|
2015-03-02 23:03:21 +00:00
|
|
|
|
2015-11-30 11:06:21 +00:00
|
|
|
"github.com/docker/libnetwork/resolvconf"
|
2015-10-12 11:50:17 +00:00
|
|
|
"github.com/rancher/os/config"
|
2016-04-15 04:58:07 +00:00
|
|
|
"github.com/rancher/os/hostname"
|
2016-10-19 23:21:35 +00:00
|
|
|
"github.com/rancher/os/netconf"
|
2015-03-02 23:03:21 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func Main() {
|
2016-11-23 10:49:35 +00:00
|
|
|
log.InitLogger()
|
2016-11-09 19:08:30 +00:00
|
|
|
log.Infof("Running network")
|
2016-04-08 20:04:35 +00:00
|
|
|
|
2016-06-02 01:41:55 +00:00
|
|
|
cfg := config.LoadConfig()
|
2016-11-09 19:08:30 +00:00
|
|
|
ApplyNetworkConfig(cfg)
|
|
|
|
|
|
|
|
select {}
|
|
|
|
}
|
2016-04-11 23:44:33 +00:00
|
|
|
|
2016-11-09 19:08:30 +00:00
|
|
|
func ApplyNetworkConfig(cfg *config.CloudConfig) {
|
2016-11-28 08:06:00 +00:00
|
|
|
nameservers := cfg.Rancher.Network.DNS.Nameservers
|
|
|
|
search := cfg.Rancher.Network.DNS.Search
|
|
|
|
userSetDNS := len(nameservers) > 0 || len(search) > 0
|
|
|
|
if !userSetDNS {
|
|
|
|
nameservers = cfg.Rancher.Defaults.Network.DNS.Nameservers
|
|
|
|
search = cfg.Rancher.Defaults.Network.DNS.Search
|
2016-04-15 17:38:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if _, err := resolvconf.Build("/etc/resolv.conf", nameservers, search, nil); err != nil {
|
2016-04-11 23:44:33 +00:00
|
|
|
log.Error(err)
|
|
|
|
}
|
|
|
|
|
2016-04-15 04:58:07 +00:00
|
|
|
if err := hostname.SetHostnameFromCloudConfig(cfg); err != nil {
|
|
|
|
log.Error(err)
|
|
|
|
}
|
|
|
|
|
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)
|
|
|
|
}
|
2016-04-11 23:44:33 +00:00
|
|
|
|
2016-04-15 17:38:31 +00:00
|
|
|
userSetHostname := cfg.Hostname != ""
|
2016-11-28 08:06:00 +00:00
|
|
|
if err := netconf.RunDhcp(&cfg.Rancher.Network, !userSetHostname, !userSetDNS); err != nil {
|
2016-04-15 04:58:07 +00:00
|
|
|
log.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := hostname.SyncHostname(); err != nil {
|
|
|
|
log.Error(err)
|
2015-12-10 15:56:15 +00:00
|
|
|
}
|
2015-03-02 23:03:21 +00:00
|
|
|
}
|