mconnect - KDE Connect protocol implementation in Vala/C
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

75 lines
1.8 KiB

  1. // Licensed under the Apache License, Version 2.0 (the "License");
  2. // you may not use this file except in compliance with the License.
  3. // You may obtain a copy of the License at
  4. //
  5. // http://www.apache.org/licenses/LICENSE-2.0
  6. //
  7. // Unless required by applicable law or agreed to in writing, software
  8. // distributed under the License is distributed on an "AS IS" BASIS,
  9. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. // See the License for the specific language governing permissions and
  11. // limitations under the License.
  12. package main
  13. import (
  14. "context"
  15. "fmt"
  16. "os"
  17. "time"
  18. "github.com/bboozzoo/mconnect/discovery"
  19. "github.com/bboozzoo/mconnect/logger"
  20. "github.com/bboozzoo/mconnect/protocol/packet"
  21. )
  22. var Stderr = os.Stderr
  23. func main() {
  24. ctx := context.Background()
  25. ctx = logger.WithContext(ctx, logger.New())
  26. log := logger.FromContext(ctx)
  27. log.Printf("setting up listener")
  28. l, err := discovery.NewListener()
  29. if err != nil {
  30. fmt.Fprintf(Stderr, "error: failed to setup listener: %v\n",
  31. err)
  32. os.Exit(1)
  33. }
  34. hostname, err := os.Hostname()
  35. if err != nil {
  36. fmt.Fprintf(Stderr, "error: failed to obtain hostname: %v\n",
  37. err)
  38. os.Exit(1)
  39. }
  40. go func() {
  41. for {
  42. err := discovery.Announce(ctx, packet.Identity{
  43. DeviceId: "mconnect-" + hostname,
  44. DeviceName: hostname,
  45. DeviceType: "computer",
  46. ProtocolVersion: 7,
  47. TcpPort: 1716,
  48. })
  49. if err != nil {
  50. log.Errorf("failed to self announce: %v", err)
  51. }
  52. time.Sleep(5 * time.Second)
  53. }
  54. }()
  55. for {
  56. log.Printf("receive wait")
  57. d, err := l.Receive(ctx)
  58. if err != nil {
  59. log.Warning("failed to receive identity packet: %v", err)
  60. continue
  61. }
  62. log.Infof("discovered a device at %s packet: %v",
  63. d.From, d.Identity)
  64. }
  65. }