diff --git a/frontend/templateHelper.go b/frontend/templateHelper.go index 7854ff9..b832d70 100644 --- a/frontend/templateHelper.go +++ b/frontend/templateHelper.go @@ -1,24 +1,12 @@ package main import ( - "net" "net/http" + "regexp" "sort" - "strconv" "strings" ) -// Helper to check if the IP is valid -func isIP(s string) bool { - return nil != net.ParseIP(s) -} - -// Helper to check if the number is valid -func isNumber(s string) bool { - _, err := strconv.Atoi(s) - return nil == err -} - func renderTemplate(w http.ResponseWriter, r *http.Request, title string, content string) { path := r.URL.Path[1:] split := strings.SplitN(path, "/", 4) @@ -75,51 +63,16 @@ func smartFormatter(s string) string { var result string result += "
" for _, line := range strings.Split(s, "\n") { - var isASes bool = false - var lineFormatted string - words := strings.Split(line, " ") - - for wordID, word := range words { - if len(word) == 0 { - continue - } - if wordID > 0 && (len(words[wordID-1]) == 0 || words[wordID-1][len(words[wordID-1])-1] == ':') { - // Insert TAB if there are multiple spaces before this word - lineFormatted += "\t" - } else { - lineFormatted += " " - } - - if isIP(word) { - // Add whois link to the IP, handles IPv4 and IPv6 - lineFormatted += "" + word + "" - } else if len(strings.Split(word, "%")) == 2 && isIP(strings.Split(word, "%")[0]) { - // IPv6 link-local with interface name, like fd00::1%eth0 - // Add whois link to address part - lineFormatted += "" + strings.Split(word, "%")[0] + "" - lineFormatted += "%" + strings.Split(word, "%")[1] - } else if len(strings.Split(word, "/")) == 2 && isIP(strings.Split(word, "/")[0]) { - // IP with a CIDR range, like 192.168.0.1/24 - // Add whois link to first part - lineFormatted += "" + strings.Split(word, "/")[0] + "" - lineFormatted += "/" + strings.Split(word, "/")[1] - } else if word == "AS:" || word == "\tBGP.as_path:" { - // Bird will output ASNs later - isASes = true - lineFormatted += word - } else if isASes && isNumber(strings.Trim(word, "()")) { - // Remove brackets in path caused by confederation - wordNum := strings.Trim(word, "()") - // Bird is outputing ASNs, add whois for them - lineFormatted += "" + word + "" - } else { - // Just an ordinary word, print it and done - lineFormatted += word - } + if strings.HasPrefix(strings.TrimSpace(line), "BGP.as_path:") || strings.HasPrefix(strings.TrimSpace(line), "Neighbor AS:") || strings.HasPrefix(strings.TrimSpace(line), "Local AS:") { + lineFormatted = regexp.MustCompile(`(\d+)`).ReplaceAllString(line, `${1}`) + } else { + lineFormatted = regexp.MustCompile(`([a-zA-Z0-9\-]*\.([a-zA-Z]{2,3}){1,2})(\s|$)`).ReplaceAllString(line, `${1}${3}`) + lineFormatted = regexp.MustCompile(`\[AS(\d+)`).ReplaceAllString(lineFormatted, `[AS${1}`) + lineFormatted = regexp.MustCompile(`(\d+\.\d+\.\d+\.\d+)`).ReplaceAllString(lineFormatted, `${1}`) + lineFormatted = regexp.MustCompile(`(?i)(([a-f\d]{0,4}:){3,10}[a-f\d]{0,4})`).ReplaceAllString(lineFormatted, `${1}`) } - lineFormatted += "\n" - result += lineFormatted + result += lineFormatted + "\n" } result += "" return result