wip
This commit is contained in:
116
main.go
116
main.go
@@ -1,14 +1,46 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"log"
|
||||
"net"
|
||||
"net/http"
|
||||
"strconv"
|
||||
|
||||
"github.com/gorilla/websocket"
|
||||
)
|
||||
|
||||
// LoggingHandler is a custom http.Handler that logs requests and delegates them to the underlying handler.
|
||||
var upgrader = websocket.Upgrader{
|
||||
CheckOrigin: func(r *http.Request) bool {
|
||||
return true // Note: In production, you'd want to check the origin.
|
||||
},
|
||||
}
|
||||
|
||||
// handleWebSocket handles WebSocket requests from the peer.
|
||||
func handleWebSocket(w http.ResponseWriter, r *http.Request) {
|
||||
log.Println("Websocket connection!", r.RemoteAddr)
|
||||
|
||||
conn, err := upgrader.Upgrade(w, r, nil)
|
||||
if err != nil {
|
||||
log.Println("Upgrade error:", err)
|
||||
return
|
||||
}
|
||||
defer conn.Close()
|
||||
|
||||
for {
|
||||
mt, message, err := conn.ReadMessage()
|
||||
if err != nil {
|
||||
log.Println("Read error:", err)
|
||||
break
|
||||
}
|
||||
log.Printf("recv: %s", message)
|
||||
err = conn.WriteMessage(mt, message)
|
||||
if err != nil {
|
||||
log.Println("Write error:", err)
|
||||
break
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// LoggingHandler logs requests and delegates them to the underlying handler.
|
||||
type LoggingHandler struct {
|
||||
handler http.Handler
|
||||
}
|
||||
@@ -18,75 +50,25 @@ func (lh *LoggingHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||
lh.handler.ServeHTTP(w, r)
|
||||
}
|
||||
|
||||
func getAddressString(portNumber int) string {
|
||||
return (":" + strconv.Itoa(portNumber))
|
||||
}
|
||||
|
||||
func portIsInUse(port int) bool {
|
||||
addr := fmt.Sprintf(":%d", port)
|
||||
conn, err := net.Listen("tcp", addr)
|
||||
if err != nil {
|
||||
return true
|
||||
}
|
||||
conn.Close()
|
||||
return false
|
||||
}
|
||||
|
||||
func main() {
|
||||
dir := "./"
|
||||
startPort := 8000
|
||||
const maxAttempts = 10
|
||||
port := 9000
|
||||
|
||||
fmt.Println("Starting...")
|
||||
addr := ":" + strconv.Itoa(port)
|
||||
log.Printf("Starting server on %s", addr)
|
||||
|
||||
// Configure TLS with the self-signed certificate and private key
|
||||
// tlsConfig := &tls.Config{
|
||||
// MinVersion: tls.VersionTLS12,
|
||||
// PreferServerCipherSuites: true,
|
||||
// InsecureSkipVerify: true,
|
||||
// Certificates: make([]tls.Certificate, 1),
|
||||
// }
|
||||
|
||||
// Load the certificate and private key
|
||||
// cert, err := tls.LoadX509KeyPair("cert.pem", "key.pem")
|
||||
// if err != nil {
|
||||
// log.Fatalf("Failed to load certificate and key: %v", err)
|
||||
// }
|
||||
// tlsConfig.Certificates[0] = cert
|
||||
|
||||
port := startPort
|
||||
for attempts := 0; attempts < maxAttempts; attempts++ {
|
||||
fmt.Printf("Trying port %d", port)
|
||||
|
||||
if portIsInUse(port) {
|
||||
fmt.Println("...port in use!")
|
||||
port++
|
||||
continue
|
||||
}
|
||||
|
||||
// If the port is not in use, bind your server here
|
||||
// For example:
|
||||
addr := ":" + strconv.Itoa(port)
|
||||
log.Printf("\nServing %s on %s using HTTP/2...", dir, addr)
|
||||
|
||||
// Configure the HTTP/2 server
|
||||
server := &http.Server{
|
||||
Addr: addr,
|
||||
Handler: &LoggingHandler{http.FileServer(http.Dir(dir))},
|
||||
// TLSConfig: tlsConfig,
|
||||
}
|
||||
fmt.Println("Configured...")
|
||||
|
||||
fmt.Println("Serving...")
|
||||
// Start the server
|
||||
server.ListenAndServe()
|
||||
if err := server.ListenAndServeTLS("", ""); err != nil {
|
||||
log.Fatalf("Server failed: %v", err)
|
||||
}
|
||||
|
||||
fmt.Println("Server started on port:", port)
|
||||
// Set up file server and WebSocket endpoint
|
||||
fs := http.FileServer(http.Dir(dir))
|
||||
loggingHandler := &LoggingHandler{handler: fs}
|
||||
http.Handle("/", loggingHandler)
|
||||
http.HandleFunc("/ws", handleWebSocket)
|
||||
|
||||
// Configure and start the HTTP server
|
||||
server := &http.Server{
|
||||
Addr: addr,
|
||||
Handler: nil, // nil uses the default ServeMux, which we configured above
|
||||
}
|
||||
log.Fatalf("Could not find an open port after %d attempts", maxAttempts)
|
||||
|
||||
log.Printf("Server is configured and serving on port %d...", port)
|
||||
log.Fatal(server.ListenAndServe())
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user