main.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. package main
  2. import (
  3. "bufio"
  4. "encoding/hex"
  5. "fmt"
  6. "github.com/songgao/packets/ethernet"
  7. "github.com/songgao/water"
  8. "log"
  9. "net"
  10. "os"
  11. "os/exec"
  12. "strings"
  13. "time"
  14. )
  15. var (
  16. self = net.ParseIP(os.Args[2])
  17. mask = net.IPv4Mask(255, 255, 255, 0)
  18. )
  19. var ifce, _ = water.New(water.Config{
  20. DeviceType: water.TAP,
  21. })
  22. var RCV_B = 0
  23. var TXT_B = 0
  24. var RCV_T = 0
  25. var TXT_T = 0
  26. func main() {
  27. //for stat only
  28. go func() {
  29. for {
  30. log.Println("Total recived: ", ByteCountSI(RCV_B), ", Total transmited: ", ByteCountSI(TXT_B))
  31. log.Println("Total recived: ", RCV_T, ", Total transmited: ", TXT_T)
  32. time.Sleep(5 * time.Second)
  33. }
  34. }()
  35. //create http server
  36. go func() {
  37. fmt.Println("Launching server...")
  38. // listen on all interfaces
  39. ln, _ := net.Listen("tcp", ":8081")
  40. // accept connection on port
  41. conn, _ := ln.Accept()
  42. // run loop forever (or until ctrl-c)
  43. for {
  44. // will listen for message to process ending in newline (\n)
  45. message, _ := bufio.NewReader(conn).ReadString('\n')
  46. // output message received
  47. //fmt.Print("RECV<<", string(message))
  48. RCV_B += len(string(message))
  49. RCV_T++
  50. data, err := hex.DecodeString(strings.ReplaceAll("\n", "", string(message)))
  51. if err != nil {
  52. //log.Println(err)
  53. }
  54. //log.Println("RECV<<", data)
  55. ifce.Write(data)
  56. }
  57. }()
  58. //declare server
  59. // connect to server
  60. conns, _ := net.Dial("tcp", os.Args[1]+":8081")
  61. var frame ethernet.Frame
  62. setupIfce(net.IPNet{IP: self, Mask: mask}, ifce.Name())
  63. for {
  64. frame.Resize(1500)
  65. n, err := ifce.Read([]byte(frame))
  66. if err != nil {
  67. log.Fatal(err)
  68. }
  69. frame = frame[:n]
  70. //log.Println("TRSV>>", hex.EncodeToString(frame))
  71. TXT_B += len(hex.EncodeToString(frame))
  72. TXT_T++
  73. /*
  74. log.Printf("Dst: %s\n", frame.Destination())
  75. log.Printf("Src: %s\n", frame.Source())
  76. log.Printf("Ethertype: % x\n", frame.Ethertype())
  77. log.Printf("Payload: % x\n", frame.Payload())
  78. log.Printf("HEX: % x\n", frame)
  79. */
  80. fmt.Fprintf(conns, hex.EncodeToString(frame)+"\n")
  81. /*
  82. a := hex.EncodeToString(frame)
  83. resp, err := http.Get("http://" + os.Args[1] + "/rcv?packet=" + a)
  84. if err != nil {
  85. fmt.Println(err)
  86. } else {
  87. defer resp.Body.Close()
  88. }
  89. */
  90. }
  91. }
  92. func setupIfce(ipNet net.IPNet, dev string) {
  93. sargs := fmt.Sprintf("interface ip set address name=REPLACE_ME source=static addr=REPLACE_ME mask=REPLACE_ME gateway=none")
  94. args := strings.Split(sargs, " ")
  95. args[4] = fmt.Sprintf("name=%s", dev)
  96. args[6] = fmt.Sprintf("addr=%s", ipNet.IP)
  97. args[7] = fmt.Sprintf("mask=%d.%d.%d.%d", ipNet.Mask[0], ipNet.Mask[1], ipNet.Mask[2], ipNet.Mask[3])
  98. cmd := exec.Command("netsh", args...)
  99. if err := cmd.Run(); err != nil {
  100. log.Println(err)
  101. }
  102. }
  103. //https://yourbasic.org/golang/formatting-byte-size-to-human-readable-format/
  104. func ByteCountSI(b int) string {
  105. const unit = 1000
  106. if b < unit {
  107. return fmt.Sprintf("%d B", b)
  108. }
  109. div, exp := int(unit), 0
  110. for n := b / unit; n >= unit; n /= unit {
  111. div *= unit
  112. exp++
  113. }
  114. return fmt.Sprintf("%.1f %cB",
  115. float64(b)/float64(div), "kMGTPE"[exp])
  116. }