Files
tunnel-please/server/server.go
bagas 76d1202b8e
All checks were successful
Docker Build and Push / build-and-push (push) Successful in 5m34s
fix: correct logic when checking tcpip-forward request
2025-12-26 23:17:13 +07:00

53 lines
1002 B
Go

package server
import (
"fmt"
"log"
"net"
"net/http"
"tunnel_pls/utils"
"golang.org/x/crypto/ssh"
)
type Server struct {
Conn *net.Listener
Config *ssh.ServerConfig
HttpServer *http.Server
}
func NewServer(config *ssh.ServerConfig) *Server {
listener, err := net.Listen("tcp", fmt.Sprintf(":%s", utils.Getenv("PORT", "2200")))
if err != nil {
log.Fatalf("failed to listen on port 2200: %v", err)
return nil
}
if utils.Getenv("TLS_ENABLED", "false") == "true" {
err = NewHTTPSServer()
if err != nil {
log.Fatalf("failed to start https server: %v", err)
}
}
err = NewHTTPServer()
if err != nil {
log.Fatalf("failed to start http server: %v", err)
}
return &Server{
Conn: &listener,
Config: config,
}
}
func (s *Server) Start() {
log.Println("SSH server is starting on port 2200...")
for {
conn, err := (*s.Conn).Accept()
if err != nil {
log.Printf("failed to accept connection: %v", err)
continue
}
go s.handleConnection(conn)
}
}