main.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. // Copyright (C) 2014 Jakob Borg and other contributors. All rights reserved.
  2. // Use of this source code is governed by an MIT-style license that can be
  3. // found in the LICENSE file.
  4. package main
  5. import (
  6. "crypto/tls"
  7. "flag"
  8. "io"
  9. "log"
  10. "os"
  11. "path/filepath"
  12. "github.com/calmh/syncthing/protocol"
  13. )
  14. var (
  15. exit bool
  16. cmd string
  17. confDir string
  18. target string
  19. get string
  20. pc protocol.Connection
  21. )
  22. func main() {
  23. log.SetFlags(0)
  24. log.SetOutput(os.Stdout)
  25. flag.StringVar(&cmd, "cmd", "idx", "Command")
  26. flag.StringVar(&confDir, "home", ".", "Certificates directory")
  27. flag.StringVar(&target, "target", "127.0.0.1:22000", "Target node")
  28. flag.StringVar(&get, "get", "", "Get file")
  29. flag.BoolVar(&exit, "exit", false, "Exit after command")
  30. flag.Parse()
  31. connect(target)
  32. select {}
  33. }
  34. func connect(target string) {
  35. cert, err := loadCert(confDir)
  36. if err != nil {
  37. log.Fatal(err)
  38. }
  39. myID := protocol.NewNodeID(cert.Certificate[0])
  40. tlsCfg := &tls.Config{
  41. Certificates: []tls.Certificate{cert},
  42. NextProtos: []string{"bep/1.0"},
  43. ServerName: myID.String(),
  44. ClientAuth: tls.RequestClientCert,
  45. SessionTicketsDisabled: true,
  46. InsecureSkipVerify: true,
  47. MinVersion: tls.VersionTLS12,
  48. }
  49. conn, err := tls.Dial("tcp", target, tlsCfg)
  50. if err != nil {
  51. log.Fatal(err)
  52. }
  53. remoteID := protocol.NewNodeID(conn.ConnectionState().PeerCertificates[0].Raw)
  54. pc = protocol.NewConnection(remoteID, conn, conn, Model{})
  55. select {}
  56. }
  57. type Model struct {
  58. }
  59. func prtIndex(files []protocol.FileInfo) {
  60. for _, f := range files {
  61. log.Printf("%q (v:%d mod:%d flags:0%o nblocks:%d)", f.Name, f.Version, f.Modified, f.Flags, len(f.Blocks))
  62. for _, b := range f.Blocks {
  63. log.Printf(" %6d %x", b.Size, b.Hash)
  64. }
  65. }
  66. }
  67. func (m Model) Index(nodeID protocol.NodeID, repo string, files []protocol.FileInfo) {
  68. log.Printf("Received index for repo %q", repo)
  69. if cmd == "idx" {
  70. prtIndex(files)
  71. if get != "" {
  72. for _, f := range files {
  73. if f.Name == get {
  74. go getFile(f)
  75. break
  76. }
  77. }
  78. } else if exit {
  79. os.Exit(0)
  80. }
  81. }
  82. }
  83. func getFile(f protocol.FileInfo) {
  84. fn := filepath.Base(f.Name)
  85. fd, err := os.Create(fn)
  86. if err != nil {
  87. log.Fatal(err)
  88. }
  89. var offset int64
  90. for _, b := range f.Blocks {
  91. log.Printf("Request %q %d - %d", f.Name, offset, offset+int64(b.Size))
  92. bs, err := pc.Request("default", f.Name, offset, int(b.Size))
  93. log.Printf(" - got %d bytes", len(bs))
  94. if err != nil {
  95. log.Fatal(err)
  96. }
  97. offset += int64(b.Size)
  98. fd.Write(bs)
  99. }
  100. fd.Close()
  101. }
  102. func (m Model) IndexUpdate(nodeID protocol.NodeID, repo string, files []protocol.FileInfo) {
  103. log.Printf("Received index update for repo %q", repo)
  104. if cmd == "idx" {
  105. prtIndex(files)
  106. if exit {
  107. os.Exit(0)
  108. }
  109. }
  110. }
  111. func (m Model) ClusterConfig(nodeID protocol.NodeID, config protocol.ClusterConfigMessage) {
  112. log.Println("Received cluster config")
  113. log.Printf("%#v", config)
  114. }
  115. func (m Model) Request(nodeID protocol.NodeID, repo string, name string, offset int64, size int) ([]byte, error) {
  116. log.Println("Received request")
  117. return nil, io.EOF
  118. }
  119. func (m Model) Close(nodeID protocol.NodeID, err error) {
  120. log.Println("Received close")
  121. }