2024-01-06 05:24:11 -06:00
|
|
|
// figures out if your hostname is valid
|
|
|
|
// then checks if your DNS is setup correctly
|
|
|
|
package linuxstatus
|
|
|
|
|
|
|
|
import (
|
2024-01-07 07:09:59 -06:00
|
|
|
"io/ioutil"
|
2024-01-06 05:24:11 -06:00
|
|
|
"go.wit.com/log"
|
|
|
|
|
|
|
|
// will try to get this hosts FQDN
|
|
|
|
"github.com/Showmax/go-fqdn"
|
|
|
|
)
|
|
|
|
|
|
|
|
func (ls *LinuxStatus) GetDomainName() string {
|
|
|
|
if ! me.Ready() {return ""}
|
|
|
|
return me.domainname.Get()
|
|
|
|
}
|
|
|
|
|
2024-01-06 14:23:19 -06:00
|
|
|
func (ls *LinuxStatus) setDomainName() {
|
2024-01-06 05:24:11 -06:00
|
|
|
if ! me.Ready() {return}
|
|
|
|
|
|
|
|
dn := run("domainname")
|
|
|
|
if (me.domainname.Get() != dn) {
|
|
|
|
log.Log(CHANGE, "domainname has changed from", me.GetDomainName(), "to", dn)
|
2024-01-06 14:23:19 -06:00
|
|
|
me.domainname.Set(dn)
|
2024-01-06 05:24:11 -06:00
|
|
|
me.changed = true
|
|
|
|
}
|
2024-01-06 14:23:19 -06:00
|
|
|
}
|
|
|
|
|
2024-01-06 16:36:34 -06:00
|
|
|
func (ls *LinuxStatus) GetHostname() string {
|
2024-01-06 14:23:19 -06:00
|
|
|
if ! me.Ready() {return ""}
|
2024-01-06 16:36:34 -06:00
|
|
|
return me.hostname.Get()
|
|
|
|
}
|
|
|
|
|
2024-01-06 16:59:33 -06:00
|
|
|
func (ls *LinuxStatus) ValidHostname() bool {
|
|
|
|
if ! me.Ready() {return false}
|
|
|
|
if me.hostnameStatus.Get() == "VALID" {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2024-01-06 16:36:34 -06:00
|
|
|
func (ls *LinuxStatus) setHostname(newname string) {
|
|
|
|
if ! me.Ready() {return}
|
|
|
|
if newname == me.hostname.Get() {
|
|
|
|
return
|
2024-01-06 14:23:19 -06:00
|
|
|
}
|
2024-01-06 16:36:34 -06:00
|
|
|
log.Log(CHANGE, "hostname has changed from", me.GetHostname(), "to", newname)
|
|
|
|
me.hostname.Set(newname)
|
|
|
|
me.changed = true
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ls *LinuxStatus) GetHostShort() string {
|
|
|
|
if ! me.Ready() {return ""}
|
2024-01-06 14:23:19 -06:00
|
|
|
return me.hostshort.Get()
|
|
|
|
}
|
2024-01-06 05:24:11 -06:00
|
|
|
|
2024-01-06 14:23:19 -06:00
|
|
|
func (ls *LinuxStatus) setHostShort() {
|
2024-01-06 14:57:51 -06:00
|
|
|
if ! me.Ready() {return}
|
2024-01-06 05:24:11 -06:00
|
|
|
hshort := run("hostname -s")
|
|
|
|
if (me.hostshort.Get() != hshort) {
|
|
|
|
log.Log(CHANGE, "hostname -s has changed from", me.hostshort.Get(), "to", hshort)
|
|
|
|
me.hostshort.Set(hshort)
|
|
|
|
me.changed = true
|
|
|
|
}
|
2024-01-06 14:23:19 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
func lookupHostname() {
|
|
|
|
if ! me.Ready() {return}
|
|
|
|
var err error
|
2024-01-06 16:36:34 -06:00
|
|
|
var hostfqdn string = "broken"
|
|
|
|
hostfqdn, err = fqdn.FqdnHostname()
|
2024-01-06 14:23:19 -06:00
|
|
|
if (err != nil) {
|
|
|
|
log.Error(err, "FQDN hostname error")
|
|
|
|
return
|
|
|
|
}
|
2024-01-06 16:36:34 -06:00
|
|
|
log.Log(NET, "full hostname should be: ", hostfqdn)
|
2024-01-06 14:23:19 -06:00
|
|
|
|
|
|
|
me.setDomainName()
|
2024-01-06 14:57:51 -06:00
|
|
|
me.setHostShort()
|
2024-01-06 05:24:11 -06:00
|
|
|
|
2024-01-06 16:36:34 -06:00
|
|
|
// these are authoritative
|
|
|
|
// if they work wrong, your linux configuration is wrong.
|
|
|
|
// Do not complain.
|
|
|
|
// Fix your distro if your box is otherwise not working this way
|
|
|
|
hshort := me.GetHostShort() // from `hostname -s`
|
|
|
|
dn := me.GetDomainName() // from `domanname`
|
|
|
|
hostname := me.GetHostname() // from `hostname -f`
|
|
|
|
|
|
|
|
if hostfqdn != hostname {
|
|
|
|
log.Log(WARN, "hostname", hostname, "does not equal fqdn.FqdnHostname()", hostfqdn)
|
|
|
|
// TODO: figure out what is wrong
|
|
|
|
}
|
|
|
|
|
2024-01-06 05:24:11 -06:00
|
|
|
var test string
|
|
|
|
test = hshort + "." + dn
|
2024-01-06 16:36:34 -06:00
|
|
|
|
|
|
|
me.setHostname(test)
|
|
|
|
|
|
|
|
if (hostname != test) {
|
|
|
|
log.Log(CHANGE, "hostname", hostname, "does not equal", test)
|
|
|
|
if (me.hostnameStatus.Get() != "BROKEN") {
|
|
|
|
log.Log(CHANGE, "hostname", hostname, "does not equal", test)
|
2024-01-06 05:24:11 -06:00
|
|
|
me.changed = true
|
2024-01-06 16:36:34 -06:00
|
|
|
me.hostnameStatus.Set("BROKEN")
|
2024-01-06 05:24:11 -06:00
|
|
|
}
|
|
|
|
} else {
|
2024-01-06 16:36:34 -06:00
|
|
|
if (me.hostnameStatus.Get() != "VALID") {
|
|
|
|
log.Log(CHANGE, "hostname", hostname, "is valid")
|
|
|
|
me.hostnameStatus.Set("VALID")
|
2024-01-06 05:24:11 -06:00
|
|
|
me.changed = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// returns true if the hostname is good
|
|
|
|
// check that all the OS settings are correct here
|
|
|
|
// On Linux, /etc/hosts, /etc/hostname
|
|
|
|
// and domainname and hostname
|
|
|
|
func goodHostname() bool {
|
2024-01-07 07:09:59 -06:00
|
|
|
content, err := ioutil.ReadFile("/etc/hostname")
|
|
|
|
if err != nil {
|
|
|
|
// this needs to be a fixWindow() error
|
|
|
|
log.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
hostname := string(content)
|
|
|
|
|
2024-01-06 05:24:11 -06:00
|
|
|
log.Log(NOW, "hostname =", hostname)
|
|
|
|
|
|
|
|
hs := run("hostname -s")
|
|
|
|
dn := run("domainname")
|
|
|
|
log.Log(NOW, "hostname short =", hs, "domainname =", dn)
|
|
|
|
|
|
|
|
tmp := hs + "." + dn
|
|
|
|
if (hostname == tmp) {
|
|
|
|
log.Log(NOW, "hostname seems to be good", hostname)
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
return false
|
|
|
|
}
|