tricrypt/cmd/server/main.go

91 lines
2.1 KiB
Go
Raw Normal View History

2024-02-23 14:28:59 +01:00
package main
import (
2024-02-23 17:48:25 +01:00
"bufio"
// "crypto/rand"
"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}}
srv := http.Server{
Addr: fmt.Sprintf("127.0.0.1:%d", env.Port),
TLSConfig: &config,
ReadTimeout: time.Minute,
WriteTimeout: time.Minute,
}
srv.Handler = http.HandlerFunc(handle)
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()
// listener, err := tls.Listen("tcp", url, &config)
// if err != nil {
// log.Fatal(err)
// }
// defer listener.Close()
// fmt.Println("Server is listening on port 8080")
//
// for {
// // Wait for a connection.
// conn, err := srv.Accept()
// if err != nil {
// log.Print(err)
// continue
// }
// // Handle the connection in a new goroutine.
// // The loop then returns to accepting, so that
// // multiple connections may be served concurrently.
// go handleConnection(conn)
// }
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())
}