use logging
This commit is contained in:
parent
890a3f527b
commit
059c3514b4
|
@ -1,6 +1,6 @@
|
|||
chacha_key: example123
|
||||
|
||||
destinations:
|
||||
5170:
|
||||
5171:
|
||||
address: 192.168.1.200
|
||||
port: 8080
|
||||
port: 5171
|
|
@ -1,4 +1,4 @@
|
|||
#!/bin/bash
|
||||
|
||||
echo "Key: $(openssl rand -hex 32)"
|
||||
openssl rand -hex 32
|
||||
|
||||
|
|
|
@ -3,6 +3,7 @@ module server
|
|||
go 1.22.2
|
||||
|
||||
require (
|
||||
github.com/sirupsen/logrus v1.9.3
|
||||
golang.org/x/crypto v0.24.0
|
||||
gopkg.in/yaml.v2 v2.4.0
|
||||
)
|
||||
|
|
|
@ -1,8 +1,21 @@
|
|||
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
|
||||
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
||||
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
||||
github.com/sirupsen/logrus v1.9.3 h1:dueUQJ1C2q9oE3F7wvmSGAaVtTmUizReu6fjN8uqzbQ=
|
||||
github.com/sirupsen/logrus v1.9.3/go.mod h1:naHLuLoDiP4jHNo9R0sCBMtWGeIprob74mVsIT4qYEQ=
|
||||
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
||||
github.com/stretchr/testify v1.7.0 h1:nwc3DEeHmmLAfoZucVR881uASk0Mfjw8xYJ99tb5CcY=
|
||||
github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
||||
golang.org/x/crypto v0.24.0 h1:mnl8DM0o513X8fdIkmyFE/5hTYxbwYOjDS/+rK6qpRI=
|
||||
golang.org/x/crypto v0.24.0/go.mod h1:Z1PMYSOR5nyMcyAVAIQSKCDwalqy85Aqn1x3Ws4L5DM=
|
||||
golang.org/x/sys v0.0.0-20220715151400-c0bba94af5f8/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||
golang.org/x/sys v0.21.0 h1:rF+pYz3DAGSQAxAu1CbC7catZg4ebC4UIeIhKxBZvws=
|
||||
golang.org/x/sys v0.21.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
|
||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405 h1:yhCVgyC4o1eVCa2tZl7eS0r+SDo693bJlVdllGtEeKM=
|
||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||
gopkg.in/yaml.v2 v2.4.0 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY=
|
||||
gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ=
|
||||
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c h1:dUUwHk2QECo/6vqA44rthZ8ie2QXMNeKRTHCNY2nXvo=
|
||||
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||
|
|
|
@ -0,0 +1,27 @@
|
|||
package logging
|
||||
|
||||
import (
|
||||
"github.com/sirupsen/logrus"
|
||||
)
|
||||
|
||||
var log *logrus.Logger
|
||||
|
||||
func init() {
|
||||
log = logrus.New()
|
||||
|
||||
// Set log output format
|
||||
customFormatter := new(logrus.TextFormatter)
|
||||
customFormatter.TimestampFormat = "2006-01-02 15:04:05"
|
||||
customFormatter.FullTimestamp = true
|
||||
log.SetFormatter(customFormatter)
|
||||
}
|
||||
|
||||
// InitLogger initializes the global logger with the specified log level
|
||||
func InitLogger(logLevel logrus.Level) {
|
||||
log.SetLevel(logLevel)
|
||||
}
|
||||
|
||||
// GetLogger returns the global logger instance
|
||||
func GetLogger() *logrus.Logger {
|
||||
return log
|
||||
}
|
|
@ -4,10 +4,12 @@ import (
|
|||
"encoding/hex"
|
||||
"flag"
|
||||
"fmt"
|
||||
"github.com/sirupsen/logrus"
|
||||
"gopkg.in/yaml.v2"
|
||||
"net"
|
||||
"os"
|
||||
"server/encryption"
|
||||
"server/logging"
|
||||
)
|
||||
|
||||
type Config struct {
|
||||
|
@ -24,35 +26,33 @@ func main() {
|
|||
configFile := flag.String("config", "", "Path to the configuration file")
|
||||
flag.Parse()
|
||||
|
||||
logging.InitLogger(logrus.InfoLevel)
|
||||
logger := logging.GetLogger()
|
||||
|
||||
if *configFile == "" {
|
||||
fmt.Println("Please provide a configuration file")
|
||||
os.Exit(1)
|
||||
logger.Fatalln("Please provide a configuration file")
|
||||
}
|
||||
|
||||
data, err := os.ReadFile(*configFile)
|
||||
if err != nil {
|
||||
fmt.Println("Error reading the configuration file:", err)
|
||||
os.Exit(1)
|
||||
logger.Fatalln("Error reading the configuration file:", err)
|
||||
}
|
||||
|
||||
var config Config
|
||||
err = yaml.Unmarshal(data, &config)
|
||||
if err != nil {
|
||||
fmt.Println("Error parsing the configuration file:", err)
|
||||
os.Exit(1)
|
||||
logger.Fatalln("Error parsing the configuration file:", err)
|
||||
}
|
||||
|
||||
// Validate chacha key
|
||||
if len(config.ChachaKey) != 64 {
|
||||
fmt.Println("Invalid chacha_key. Should be 64 characters long")
|
||||
os.Exit(1)
|
||||
logger.Fatalln("Invalid chacha_key. Should be 64 characters long")
|
||||
}
|
||||
|
||||
// Validate destinations
|
||||
for port, dest := range config.Destinations {
|
||||
if dest.Address == "" || dest.Port == 0 {
|
||||
fmt.Printf("Invalid destination for port %s\n", port)
|
||||
os.Exit(1)
|
||||
logger.Fatalln("Invalid destination for port %s\n", port)
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -62,13 +62,13 @@ func main() {
|
|||
go func(port string, dest Destination) {
|
||||
addr, err := net.ResolveUDPAddr("udp", ":"+port)
|
||||
if err != nil {
|
||||
fmt.Println("Error resolving address:", err)
|
||||
logger.Fatalln("Error resolving address:", err)
|
||||
return
|
||||
}
|
||||
|
||||
conn, err := net.ListenUDP("udp", addr)
|
||||
if err != nil {
|
||||
fmt.Println("Error listening on UDP:", err)
|
||||
logger.Fatalln("Error listening on UDP:", err)
|
||||
return
|
||||
}
|
||||
defer conn.Close()
|
||||
|
@ -76,39 +76,42 @@ func main() {
|
|||
// Address to forward the decrypted messages
|
||||
forwardAddr, err := net.ResolveUDPAddr("udp", fmt.Sprintf("%s:%d", dest.Address, dest.Port))
|
||||
if err != nil {
|
||||
fmt.Println("Error resolving forward address:", err)
|
||||
logger.Fatalln("Error resolving forward address:", err)
|
||||
return
|
||||
}
|
||||
|
||||
forwardConn, err := net.DialUDP("udp", nil, forwardAddr)
|
||||
if err != nil {
|
||||
fmt.Println("Error dialing to forward address:", err)
|
||||
logger.Errorln("Error dialing to forward address:", err)
|
||||
return
|
||||
}
|
||||
defer forwardConn.Close()
|
||||
|
||||
logger.Infof("Listening on 0.0.0.0:%s\n", port)
|
||||
|
||||
for {
|
||||
buf := make([]byte, 1500) // 1500 is the standard internet MTU
|
||||
n, addr, err := conn.ReadFromUDP(buf)
|
||||
if err != nil {
|
||||
fmt.Println("Error reading from UDP:", err)
|
||||
logger.Errorln("Error reading from UDP:", err)
|
||||
return
|
||||
}
|
||||
|
||||
plaintext, err := encryption.Decrypt(key, buf[:n]) // Use only the part of the buffer that has data
|
||||
if err != nil {
|
||||
fmt.Println("Error decrypting message:", err)
|
||||
return
|
||||
}
|
||||
|
||||
fmt.Printf("%s -- %s\n", addr.IP, string(plaintext))
|
||||
|
||||
// Forward the decrypted message
|
||||
_, err = forwardConn.Write(plaintext)
|
||||
if err != nil {
|
||||
fmt.Println("Error forwarding message:", err)
|
||||
return
|
||||
}
|
||||
go func(addr *net.UDPAddr, buf []byte, n int) {
|
||||
plaintext, err := encryption.Decrypt(key, buf[:n]) // Use only the part of the buffer that has data
|
||||
if err != nil {
|
||||
fmt.Println("Error decrypting message:", err)
|
||||
return
|
||||
}
|
||||
|
||||
_, err = forwardConn.Write(plaintext)
|
||||
if err != nil {
|
||||
fmt.Println("Error forwarding message:", err)
|
||||
return
|
||||
}
|
||||
logger.Infof("%s -> %s:%d -- %s\n", addr.IP, dest.Address, dest.Port, string(plaintext))
|
||||
}(addr, buf, n)
|
||||
}
|
||||
}(port, dest)
|
||||
}
|
||||
|
|
|
@ -4,7 +4,7 @@ import time
|
|||
from Crypto.Cipher import ChaCha20_Poly1305
|
||||
|
||||
# The server's address and port
|
||||
server_address = ('localhost', 5170)
|
||||
server_address = ('localhost', 5171)
|
||||
|
||||
# Create a UDP socket
|
||||
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
|
||||
|
|
Loading…
Reference in New Issue