Compare commits

..

9 Commits

Author SHA1 Message Date
4a9ff7b4f5 Merge pull request 'master' (#3) from master into main
All checks were successful
release-tag / release-image (push) Successful in 44s
Reviewed-on: #3
2025-01-14 07:12:43 +00:00
2d95e92f93 Dockerfile aktualisiert
All checks were successful
release-tag / release-image (push) Successful in 44s
2025-01-13 20:52:18 +00:00
353a525b0c Dockerfile aktualisiert
All checks were successful
release-tag / release-image (push) Successful in 44s
2025-01-13 20:50:04 +00:00
21ec339b2d main.go aktualisiert
All checks were successful
release-tag / release-image (push) Successful in 1m30s
2025-01-13 20:44:41 +00:00
81fff6b9ac Dockerfile aktualisiert
All checks were successful
release-tag / release-image (push) Successful in 44s
2025-01-13 20:40:47 +00:00
f60e808281 Dockerfile aktualisiert
All checks were successful
release-tag / release-image (push) Successful in 42s
2025-01-13 20:21:49 +00:00
2e42bf6e20 Merge pull request 'added dyndns dns function' (#2) from master into main
Some checks failed
release-tag / release-image (push) Failing after 29s
Reviewed-on: #2
2025-01-13 20:19:17 +00:00
2359ff4bd2 Dockerfile aktualisiert
All checks were successful
release-tag / release-image (push) Successful in 1m29s
2025-01-12 18:49:27 +00:00
b8f8c3d0ce Merge pull request 'master' (#1) from master into main
Some checks failed
release-tag / release-image (push) Failing after 59s
Reviewed-on: #1
2025-01-12 18:46:52 +00:00
2 changed files with 42 additions and 75 deletions

View File

@@ -1,4 +1,6 @@
FROM golang:1.23.3 FROM golang:1.23.3
RUN mkdir /data
COPY data/* /data
WORKDIR /app WORKDIR /app
COPY go.mod go.sum ./ COPY go.mod go.sum ./
RUN go mod download RUN go mod download

115
main.go
View File

@@ -21,8 +21,6 @@ type DB map[string]dns_entry
var D map[string]dns_entry var D map[string]dns_entry
var DEBUG bool = false
type dns_entry struct { type dns_entry struct {
Dns string `json:"dns"` Dns string `json:"dns"`
Ipv4 string `json:"ipv4"` Ipv4 string `json:"ipv4"`
@@ -37,14 +35,14 @@ func writeToFile(filename string, data DB) error {
// JSON konvertieren // JSON konvertieren
jsonData, err := json.MarshalIndent(data, "", " ") jsonData, err := json.MarshalIndent(data, "", " ")
if err != nil { if err != nil {
fmt.Println("!", "Fehler beim Serialisieren: ", err) fmt.Println("Fehler beim Serialisieren: ", err)
return err return err
} }
// Datei öffnen/erstellen // Datei öffnen/erstellen
err = os.WriteFile(filename, jsonData, 0644) err = os.WriteFile(filename, jsonData, 0644)
if err != nil { if err != nil {
fmt.Println("!", "Fehler beim Schreiben der Datei: ", err) fmt.Println("Fehler beim Schreiben der Datei: ", err)
return err return err
} }
@@ -56,7 +54,7 @@ func readFromFile(filename string) (DB, error) {
// Datei lesen // Datei lesen
jsonData, err := os.ReadFile(filename) jsonData, err := os.ReadFile(filename)
if err != nil { if err != nil {
fmt.Println("!", "Fehler beim Lesen der Datei: ", err) fmt.Println("Fehler beim Lesen der Datei: ", err)
return nil, err return nil, err
} }
@@ -64,7 +62,7 @@ func readFromFile(filename string) (DB, error) {
var data DB var data DB
err = json.Unmarshal(jsonData, &data) err = json.Unmarshal(jsonData, &data)
if err != nil { if err != nil {
fmt.Println("!", "Fehler beim Parsen von JSON: ", err) fmt.Println("Fehler beim Parsen von JSON: ", err)
return nil, err return nil, err
} }
@@ -130,7 +128,7 @@ func handler(w http.ResponseWriter, r *http.Request) {
if strings.EqualFold(Dns, "") || strings.EqualFold(Ip, "") || strings.EqualFold(User, "") || strings.EqualFold(Token, "") { if strings.EqualFold(Dns, "") || strings.EqualFold(Ip, "") || strings.EqualFold(User, "") || strings.EqualFold(Token, "") {
/* strings.ToLower(Dns) != strings.ToLower("") && strings.ToLower(Ip) != strings.ToLower("") && strings.ToLower(User) != strings.ToLower("") && strings.ToLower(Token) != strings.ToLower("")*/ /* strings.ToLower(Dns) != strings.ToLower("") && strings.ToLower(Ip) != strings.ToLower("") && strings.ToLower(User) != strings.ToLower("") && strings.ToLower(Token) != strings.ToLower("")*/
fmt.Println("!", "Eintrag unvollständig: ", D[Dns]) fmt.Println("Eintrag unvollständig: ", D[Dns])
w.WriteHeader(200) w.WriteHeader(200)
w.Write([]byte("nochg")) w.Write([]byte("nochg"))
@@ -139,33 +137,33 @@ func handler(w http.ResponseWriter, r *http.Request) {
if entry, exists := D[Dns+"."]; exists { if entry, exists := D[Dns+"."]; exists {
if User == entry.User && VerifyToken(Token, entry.Token) { if User == entry.User && VerifyToken(Token, entry.Token) {
D[Dns+"."] = dns_entry{Dns: Dns, Ipv4: Ip, Ipv6: Ip6, User: User, Token: entry.Token, LastSeen: time.Now().String()} D[Dns+"."] = dns_entry{Dns: Dns, Ipv4: Ip, Ipv6: Ip6, User: User, Token: entry.Token, LastSeen: time.Now().String()}
fmt.Println("~", "Eintrag aktualisiert: ", entry, D[Dns+"."]) fmt.Println("Eintrag aktualisiert: ", entry, D[Dns+"."])
// Datei speichern // Datei speichern
filename := "data/data.json" filename := "/data/data.json"
err := writeToFile(filename, D) err := writeToFile(filename, D)
if err != nil { if err != nil {
fmt.Println("!", "Fehler beim Schreiben:", err) fmt.Println("Fehler beim Schreiben:", err)
return return
} }
fmt.Println("~", "Daten erfolgreich in Datei geschrieben.") fmt.Println("Daten erfolgreich in Datei geschrieben.")
w.WriteHeader(200) w.WriteHeader(200)
w.Write([]byte("good")) w.Write([]byte("good"))
} else { } else {
fmt.Println("!", "Eintrag aktualisieren abgelehnt (Benutzer/Passwort ungültig): ", entry, D[Dns]) fmt.Println("Eintrag aktualisieren abgelehnt (Benutzer/Passwort ungültig): ", entry, D[Dns])
w.WriteHeader(200) w.WriteHeader(200)
w.Write([]byte("nochg")) w.Write([]byte("nochg"))
} }
} else { } else {
D[Dns+"."] = dns_entry{Dns: Dns, Ipv4: Ip, Ipv6: Ip6, User: User, Token: HashToken(Token), LastSeen: time.Now().String()} D[Dns+"."] = dns_entry{Dns: Dns, Ipv4: Ip, Ipv6: Ip6, User: User, Token: HashToken(Token), LastSeen: time.Now().String()}
fmt.Println("~", "Eintrag erstellt: ", entry, D[Dns+"."]) fmt.Println("Eintrag erstellt: ", entry, D[Dns+"."])
// Datei speichern // Datei speichern
filename := "data/data.json" filename := "/data/data.json"
err := writeToFile(filename, D) err := writeToFile(filename, D)
if err != nil { if err != nil {
fmt.Println("!", "Fehler beim Schreiben:", err) fmt.Println("Fehler beim Schreiben:", err)
return return
} }
fmt.Println("~", "Daten erfolgreich in Datei geschrieben.") fmt.Println("Daten erfolgreich in Datei geschrieben.")
w.WriteHeader(200) w.WriteHeader(200)
w.Write([]byte("good")) w.Write([]byte("good"))
} }
@@ -174,15 +172,7 @@ func handler(w http.ResponseWriter, r *http.Request) {
} }
func handlerIP(w http.ResponseWriter, r *http.Request) { func handlerIP(w http.ResponseWriter, r *http.Request) {
remoteIP := r.Header.Get("X-Forwarded-For")
if remoteIP == "" {
remoteIP = r.RemoteAddr // Fallback, wenn kein Header gesetzt ist
}
if DEBUG {
fmt.Println("~", "Remote-IP:", remoteIP)
}
w.WriteHeader(200)
w.Write([]byte(remoteIP))
} }
func handleDNSRequest(w dns.ResponseWriter, r *dns.Msg) { func handleDNSRequest(w dns.ResponseWriter, r *dns.Msg) {
@@ -193,20 +183,17 @@ func handleDNSRequest(w dns.ResponseWriter, r *dns.Msg) {
// Durchlaufe alle Fragen in der Anfrage // Durchlaufe alle Fragen in der Anfrage
for _, q := range r.Question { for _, q := range r.Question {
fmt.Println(q.Qtype)
switch q.Qtype { switch q.Qtype {
case dns.TypeA: // IPv4-Anfrage case dns.TypeA: // IPv4-Anfrage
ip, exists := D[q.Name] ip, exists := D[q.Name]
if exists { if exists {
rr, err := dns.NewRR(q.Name + " A " + ip.Ipv4) rr, err := dns.NewRR(q.Name + " A " + ip.Ipv4)
if err == nil { if err == nil {
if DEBUG { fmt.Println("Antwort (IPv4):", rr, q.Name)
fmt.Println("~", "handleDNSRequest", "case dns.TypeA", "D[q.Name]", D[q.Name], "q.Name", q.Name)
}
msg.Answer = append(msg.Answer, rr) msg.Answer = append(msg.Answer, rr)
} else { } else {
if DEBUG { fmt.Println("Fehler beim Erstellen der Antwort (4):", err)
fmt.Println("!", "handleDNSRequest", "case dns.TypeA", "IPv4", "error", err)
}
} }
} }
case dns.TypeAAAA: // IPv6-Anfrage case dns.TypeAAAA: // IPv6-Anfrage
@@ -215,53 +202,35 @@ func handleDNSRequest(w dns.ResponseWriter, r *dns.Msg) {
if exists && !strings.EqualFold(ip.Ipv6, "") { if exists && !strings.EqualFold(ip.Ipv6, "") {
rr, err := dns.NewRR(q.Name + " AAAA " + ip.Ipv6) rr, err := dns.NewRR(q.Name + " AAAA " + ip.Ipv6)
if err == nil { if err == nil {
if DEBUG { fmt.Println("Antwort (IPv6):", rr, q.Name)
fmt.Println("~", "handleDNSRequest", "case dns.TypeAAAA", "D[q.Name]", D[q.Name], "q.Name", q.Name)
}
msg.Answer = append(msg.Answer, rr) msg.Answer = append(msg.Answer, rr)
} else { } else {
if DEBUG { fmt.Println("Fehler beim Erstellen der Antwort (6):", err)
fmt.Println("!", "handleDNSRequest", "case dns.TypeAAAA", "IPv6", "error", err)
}
} }
} }
case dns.TypePTR: case dns.TypePTR:
for a, b := range D { for a, b := range D {
iptocheck := reverseString(b.Ipv4) iptocheck := reverseString(b.Ipv4)
fmt.Println(iptocheck, q.Name)
if iptocheck+".in-addr.arpa." == q.Name { if iptocheck+".in-addr.arpa." == q.Name {
rr, err := dns.NewRR(q.Name + " PTR " + a) rr, err := dns.NewRR(q.Name + " PTR " + a)
if err == nil { if err == nil {
if DEBUG {
fmt.Println("~", "handleDNSRequest", "case dns.TypePTR", "IPv4", "found match", a, b)
}
msg.Answer = append(msg.Answer, rr) msg.Answer = append(msg.Answer, rr)
} else {
if DEBUG {
fmt.Println("!", "handleDNSRequest", "case dns.TypePTR", "IPv4", "error", err)
}
} }
} }
ip6tocheck, _ := IPv6ToPTR(b.Ipv6) ip6tocheck, _ := IPv6ToPTR(b.Ipv6)
fmt.Println(ip6tocheck, q.Name)
if ip6tocheck == q.Name { if ip6tocheck == q.Name {
rr, err := dns.NewRR(q.Name + " PTR " + a) rr, err := dns.NewRR(q.Name + " PTR " + a)
if err == nil { if err == nil {
if DEBUG {
fmt.Println("~", "handleDNSRequest", "case dns.TypePTR", "IPv6", "found match", a, b)
}
msg.Answer = append(msg.Answer, rr) msg.Answer = append(msg.Answer, rr)
} else {
if DEBUG {
fmt.Println("!", "handleDNSRequest", "case dns.TypePTR", "IPv6", "error", err)
}
} }
} }
} }
default: default:
if DEBUG { // Ignoriere nicht unterstützte Typen
fmt.Println("+", "unhandledDNSRequest", r.Question, q.Name, q.Qclass, q.Qtype)
}
} }
} }
@@ -270,15 +239,15 @@ func handleDNSRequest(w dns.ResponseWriter, r *dns.Msg) {
} }
func prepareExit() { func prepareExit() {
fmt.Println("~", "Running exit tasks...") fmt.Println("Running exit tasks...")
fmt.Println("~", "Exit completed.") fmt.Println("Exit completed.")
} }
func StopServer(e error) { func StopServer(e error) {
fmt.Println("~", "Stopping server...") fmt.Println("Stopping server...")
prepareExit() prepareExit()
fmt.Println("~", "Server stopped!") fmt.Println("Server stopped!")
} }
func main() { func main() {
@@ -288,20 +257,16 @@ func main() {
HTTP_TLS_PRIVATEKEY := os.Getenv("HTTP_TLS_PRIVATEKEY") HTTP_TLS_PRIVATEKEY := os.Getenv("HTTP_TLS_PRIVATEKEY")
HTTP_TLS_CERTIFICATE := os.Getenv("HTTP_TLS_CERTIFICATE") HTTP_TLS_CERTIFICATE := os.Getenv("HTTP_TLS_CERTIFICATE")
if os.Getenv("DEBUG") == "1" {
DEBUG = true
}
if strings.EqualFold(HTTP_TLS, "") || strings.EqualFold(HTTP_PORT, "") || strings.EqualFold(HTTP_TLS_PRIVATEKEY, "") || strings.EqualFold(HTTP_TLS_CERTIFICATE, "") { if strings.EqualFold(HTTP_TLS, "") || strings.EqualFold(HTTP_PORT, "") || strings.EqualFold(HTTP_TLS_PRIVATEKEY, "") || strings.EqualFold(HTTP_TLS_CERTIFICATE, "") {
fmt.Println("~", "No port or mode defined. Fallback to TLS=0 & Port=8080") fmt.Println("No port or mode defined. Fallback to TLS=0 & Port=8080")
fmt.Println("~", "ENV's: [HTTP_PORT=8080|443], [HTTP_TLS=0|1],[HTTP_TLS_PRIVATEKEY=#],[HTTP_TLS_CERTIFICATE=#]") fmt.Println("ENV's: [HTTP_PORT=8080|443], [HTTP_TLS=0|1],[HTTP_TLS_PRIVATEKEY=#],[HTTP_TLS_CERTIFICATE=#]")
fmt.Println("~", "Remember to set unused ENVs like [HTTP_TLS_PRIVATEKEY] or [HTTP_TLS_CERTIFICATE] to '#'") fmt.Println("Remember to set unused ENVs like [HTTP_TLS_PRIVATEKEY] or [HTTP_TLS_CERTIFICATE] to '#'")
HTTP_PORT = "8080" HTTP_PORT = "8080"
HTTP_TLS = "0" HTTP_TLS = "0"
HTTP_TLS_CERTIFICATE = "" HTTP_TLS_CERTIFICATE = ""
HTTP_TLS_PRIVATEKEY = "" HTTP_TLS_PRIVATEKEY = ""
} else { } else {
fmt.Println("~", "Port and mode defined.") fmt.Println("Port and mode defined.")
} }
// Signal-Kanal einrichten // Signal-Kanal einrichten
@@ -311,19 +276,19 @@ func main() {
// Goroutine, die auf Signale wartet // Goroutine, die auf Signale wartet
go func() { go func() {
<-stop <-stop
fmt.Println("~", "Received stop signal") fmt.Println("Received stop signal")
prepareExit() prepareExit()
os.Exit(0) os.Exit(0)
}() }()
D = make(map[string]dns_entry) D = make(map[string]dns_entry)
// Datei lesen // Datei lesen
filename := "data/data.json" filename := "/data/data.json"
readData, err := readFromFile(filename) readData, err := readFromFile(filename)
if err != nil { if err != nil {
fmt.Println("!", "Fehler beim Lesen:", err) fmt.Println("Fehler beim Lesen:", err)
} else { } else {
fmt.Println("~", "Daten erfolgreich aus Datei gelesen.") fmt.Println("Daten erfolgreich aus Datei gelesen.")
D = readData D = readData
} }
@@ -336,7 +301,7 @@ func main() {
serverUDP := &dns.Server{Addr: ":53", Net: "udp"} serverUDP := &dns.Server{Addr: ":53", Net: "udp"}
go func() { go func() {
log.Println("~", "Starting DNS server on UDP :53") log.Println("Starting DNS server on UDP :53")
if err := serverUDP.ListenAndServe(); err != nil { if err := serverUDP.ListenAndServe(); err != nil {
log.Fatalf("Failed to start UDP server: %v", err) log.Fatalf("Failed to start UDP server: %v", err)
} }
@@ -344,7 +309,7 @@ func main() {
serverTCP := &dns.Server{Addr: ":53", Net: "tcp"} serverTCP := &dns.Server{Addr: ":53", Net: "tcp"}
go func() { go func() {
log.Println("~", "Starting DNS server on TCP :53") log.Println("Starting DNS server on TCP :53")
if err := serverTCP.ListenAndServe(); err != nil { if err := serverTCP.ListenAndServe(); err != nil {
log.Fatalf("Failed to start TCP server: %v", err) log.Fatalf("Failed to start TCP server: %v", err)
} }
@@ -352,13 +317,13 @@ func main() {
/* HTTP-PART */ /* HTTP-PART */
fmt.Println("~", "Server listening on port :"+HTTP_PORT) fmt.Println("Server listening on port :" + HTTP_PORT)
if HTTP_TLS == "0" { if HTTP_TLS == "0" {
fmt.Println("~", "Protocol is http (insecure)") fmt.Println("Protocol is http (insecure)")
StopServer(http.ListenAndServe(":"+HTTP_PORT, nil)) StopServer(http.ListenAndServe(":"+HTTP_PORT, nil))
} }
if HTTP_TLS == "1" { if HTTP_TLS == "1" {
fmt.Println("~", "Protocol is https (secure)") fmt.Println("Protocol is https (secure)")
StopServer(http.ListenAndServeTLS(":"+HTTP_PORT, HTTP_TLS_CERTIFICATE, HTTP_TLS_PRIVATEKEY, nil)) StopServer(http.ListenAndServeTLS(":"+HTTP_PORT, HTTP_TLS_CERTIFICATE, HTTP_TLS_PRIVATEKEY, nil))
} }