From df14bc9d088b3043991c3d54142fdf8f94011e8b Mon Sep 17 00:00:00 2001 From: Reza Behzadan Date: Mon, 26 Feb 2024 05:56:36 +0330 Subject: [PATCH] Fix GetDomainName() --- VERSION | 2 +- functions/common.go | 40 ---------------------------------------- functions/getdomain.go | 18 ++++++++++++++++++ 3 files changed, 19 insertions(+), 41 deletions(-) create mode 100644 functions/getdomain.go diff --git a/VERSION b/VERSION index 347f583..9df886c 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -1.4.1 +1.4.2 diff --git a/functions/common.go b/functions/common.go index aded538..733283f 100644 --- a/functions/common.go +++ b/functions/common.go @@ -1,9 +1,6 @@ package functions import ( - "fmt" - "net" - "os" "strings" "golang.org/x/text/cases" @@ -18,40 +15,3 @@ func Title(s string) string { func Split(sep, s string) []string { return strings.Split(s, sep) } - -// getDomainName attempts to find the domain name of the host. -// It returns the domain name if found, otherwise an error. -func getDomainName() (string, error) { - // Get the hostname - hostname, err := os.Hostname() - if err != nil { - return "", fmt.Errorf("error getting hostname: %v", err) - } - - // Lookup IP addresses associated with the hostname - ips, err := net.LookupIP(hostname) - if err != nil { - return "", fmt.Errorf("error looking up IP addresses for hostname %s: %v", hostname, err) - } - - for _, ip := range ips { - // Perform a reverse lookup to find the FQDN - names, err := net.LookupAddr(ip.String()) - if err != nil { - // If there's an error, continue to the next IP - continue - } - - for _, name := range names { - cleanName := strings.TrimSuffix(name, ".") - return cleanName, nil - } - } - - return "", fmt.Errorf("domain name not found for host: %s", hostname) -} - -func GetDomainName() string { - domain, _ := getDomainName() - return domain -} diff --git a/functions/getdomain.go b/functions/getdomain.go new file mode 100644 index 0000000..406cff9 --- /dev/null +++ b/functions/getdomain.go @@ -0,0 +1,18 @@ +package functions + +import ( + "os" + "strings" +) + +func GetDomainName() string { + hostname, err := os.Hostname() + if err != nil { + return "exmaple.ir" + } + parts := strings.Split(hostname, ".") + if len(parts) < 2 { + return "exmaple.ir" + } + return strings.Join(parts[1:], ".") +}