frontend: move redirect logic to HTML
This commit is contained in:
parent
72946e1113
commit
1baf325149
@ -41,7 +41,7 @@
|
|||||||
{{ if .IsWhois }}
|
{{ if .IsWhois }}
|
||||||
{{ $target = .WhoisTarget }}
|
{{ $target = .WhoisTarget }}
|
||||||
{{ end }}
|
{{ end }}
|
||||||
<form class="form-inline" action="/redir" method="GET">
|
<form name="goto" class="form-inline" action="javascript:goto();">
|
||||||
<div class="input-group">
|
<div class="input-group">
|
||||||
<select name="action" class="form-control">
|
<select name="action" class="form-control">
|
||||||
{{ range $k, $v := .Options }}
|
{{ range $k, $v := .Options }}
|
||||||
@ -64,5 +64,24 @@
|
|||||||
|
|
||||||
<script src="https://cdn.jsdelivr.net/npm/jquery@3.5.1/dist/jquery.min.js" integrity="sha256-9/aliU8dGd2tb6OSsuzixeV4y/faTqgFtohetphbbj0=" crossorigin="anonymous"></script>
|
<script src="https://cdn.jsdelivr.net/npm/jquery@3.5.1/dist/jquery.min.js" integrity="sha256-9/aliU8dGd2tb6OSsuzixeV4y/faTqgFtohetphbbj0=" crossorigin="anonymous"></script>
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@4.5.1/dist/js/bootstrap.min.js" integrity="sha256-0IiaoZCI++9oAAvmCb5Y0r93XkuhvJpRalZLffQXLok=" crossorigin="anonymous"></script>
|
<script src="https://cdn.jsdelivr.net/npm/bootstrap@4.5.1/dist/js/bootstrap.min.js" integrity="sha256-0IiaoZCI++9oAAvmCb5Y0r93XkuhvJpRalZLffQXLok=" crossorigin="anonymous"></script>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
function goto() {
|
||||||
|
let action = encodeURIComponent($('[name="action"]').val());
|
||||||
|
let server = encodeURIComponent($('[name="server"]').val());
|
||||||
|
let target = encodeURIComponent($('[name="target"]').val());
|
||||||
|
let url = "";
|
||||||
|
|
||||||
|
if (action == "whois") {
|
||||||
|
url = "/" + action + "/" + target;
|
||||||
|
} else if (action == "summary") {
|
||||||
|
url = "/" + action + "/" + server + "/";
|
||||||
|
} else {
|
||||||
|
url = "/" + action + "/" + server + "/" + target;
|
||||||
|
}
|
||||||
|
|
||||||
|
window.location.href = url;
|
||||||
|
}
|
||||||
|
</script>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
@ -177,26 +177,6 @@ func webHandlerBGPMap(endpoint string, command string) func(w http.ResponseWrite
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// redirect from the form input to a path style query
|
|
||||||
func webHandlerNavbarFormRedirect(w http.ResponseWriter, r *http.Request) {
|
|
||||||
query := r.URL.Query()
|
|
||||||
|
|
||||||
action := query.Get("action")
|
|
||||||
|
|
||||||
switch action {
|
|
||||||
case "whois":
|
|
||||||
target := url.PathEscape(query.Get("target"))
|
|
||||||
http.Redirect(w, r, "/"+action+"/"+target, 302)
|
|
||||||
case "summary":
|
|
||||||
server := url.PathEscape(query.Get("server"))
|
|
||||||
http.Redirect(w, r, "/"+action+"/"+server+"/", 302)
|
|
||||||
default:
|
|
||||||
server := url.PathEscape(query.Get("server"))
|
|
||||||
target := url.PathEscape(query.Get("target"))
|
|
||||||
http.Redirect(w, r, "/"+action+"/"+server+"/"+target, 302)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// set up routing paths and start webserver
|
// set up routing paths and start webserver
|
||||||
func webServerStart() {
|
func webServerStart() {
|
||||||
|
|
||||||
@ -230,7 +210,6 @@ func webServerStart() {
|
|||||||
http.HandleFunc("/generic/", webBackendCommunicator("bird", "generic"))
|
http.HandleFunc("/generic/", webBackendCommunicator("bird", "generic"))
|
||||||
http.HandleFunc("/traceroute/", webBackendCommunicator("traceroute", "traceroute"))
|
http.HandleFunc("/traceroute/", webBackendCommunicator("traceroute", "traceroute"))
|
||||||
http.HandleFunc("/whois/", webHandlerWhois)
|
http.HandleFunc("/whois/", webHandlerWhois)
|
||||||
http.HandleFunc("/redir", webHandlerNavbarFormRedirect)
|
|
||||||
http.HandleFunc("/telegram/", webHandlerTelegramBot)
|
http.HandleFunc("/telegram/", webHandlerTelegramBot)
|
||||||
|
|
||||||
// Start HTTP server
|
// Start HTTP server
|
||||||
|
Loading…
x
Reference in New Issue
Block a user