2024-02-23 14:28:59 +01:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2024-02-23 17:48:25 +01:00
|
|
|
"bufio"
|
|
|
|
"crypto/tls"
|
2024-02-23 14:28:59 +01:00
|
|
|
"fmt"
|
|
|
|
"log"
|
2024-02-23 17:48:25 +01:00
|
|
|
"net"
|
2024-02-23 15:32:08 +01:00
|
|
|
"net/http"
|
2024-02-23 17:48:25 +01:00
|
|
|
"os"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"git.qowevisa.me/Qowevisa/gotell/env"
|
2024-02-23 14:28:59 +01:00
|
|
|
)
|
|
|
|
|
2024-02-23 17:48:25 +01:00
|
|
|
func handle(w http.ResponseWriter, r *http.Request) {
|
|
|
|
fmt.Fprintf(w, "Hello, you've connected to the server!")
|
|
|
|
log.Printf("w: %#v", w)
|
|
|
|
log.Printf("r: %#v", r)
|
|
|
|
}
|
2024-02-23 14:28:59 +01:00
|
|
|
|
2024-02-23 17:48:25 +01:00
|
|
|
func main() {
|
|
|
|
// Listen on TCP port 8080 on all available unicast and anycast IP addresses of the local system.
|
|
|
|
cert, err := tls.LoadX509KeyPair("tls.crt", "tls.key")
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalf("server: loadkeys: %s", err)
|
|
|
|
}
|
|
|
|
config := tls.Config{Certificates: []tls.Certificate{cert}}
|
2024-02-23 18:02:43 +01:00
|
|
|
host, err := env.GetHost()
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
port, err := env.GetPort()
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2024-02-23 17:48:25 +01:00
|
|
|
srv := http.Server{
|
2024-02-23 18:02:43 +01:00
|
|
|
Addr: fmt.Sprintf("%s:%d", host, port),
|
2024-02-23 17:48:25 +01:00
|
|
|
TLSConfig: &config,
|
|
|
|
ReadTimeout: time.Minute,
|
|
|
|
WriteTimeout: time.Minute,
|
2024-02-23 18:02:43 +01:00
|
|
|
Handler: http.HandlerFunc(handle),
|
2024-02-23 17:48:25 +01:00
|
|
|
}
|
2024-02-23 18:02:43 +01:00
|
|
|
log.Printf("Start http server on %s:%d\n", host, port)
|
2024-02-23 17:48:25 +01:00
|
|
|
err = srv.ListenAndServe()
|
2024-02-23 15:32:08 +01:00
|
|
|
if err != nil {
|
|
|
|
log.Fatalf("Failed to start server: %v", err)
|
2024-02-23 17:48:25 +01:00
|
|
|
os.Exit(1)
|
2024-02-23 14:28:59 +01:00
|
|
|
}
|
2024-02-23 17:48:25 +01:00
|
|
|
defer srv.Close()
|
2024-02-23 14:28:59 +01:00
|
|
|
}
|
|
|
|
|
2024-02-23 17:48:25 +01:00
|
|
|
func handleConnection(conn net.Conn) {
|
|
|
|
defer conn.Close()
|
|
|
|
|
|
|
|
fmt.Printf("Client connected: %v\n", conn.RemoteAddr())
|
|
|
|
|
|
|
|
// Create a new reader for each client.
|
|
|
|
scanner := bufio.NewScanner(conn)
|
|
|
|
for scanner.Scan() {
|
|
|
|
// Read the incoming connection into the buffer.
|
|
|
|
text := scanner.Text()
|
|
|
|
fmt.Printf("Received: %s\n", text)
|
|
|
|
|
|
|
|
// Send a response back to client.
|
|
|
|
_, err := conn.Write([]byte("Message received: " + text + "\n"))
|
|
|
|
if err != nil {
|
|
|
|
log.Printf("Failed to write to connection: %v", err)
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := scanner.Err(); err != nil {
|
|
|
|
fmt.Fprintf(os.Stderr, "Error reading from connection: %s\n", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
fmt.Printf("Client disconnected: %v\n", conn.RemoteAddr())
|
|
|
|
}
|