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.

50 lines
1.2 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. "github.com/bboozzoo/mconnect/discovery"
  18. "github.com/bboozzoo/mconnect/logger"
  19. )
  20. var Stderr = os.Stderr
  21. func main() {
  22. ctx := context.Background()
  23. ctx = logger.WithContext(ctx, logger.New())
  24. log := logger.FromContext(ctx)
  25. log.Printf("setting up listener")
  26. l, err := discovery.NewListener()
  27. if err != nil {
  28. fmt.Fprintf(Stderr, "error: failed to setup listener: %v\n",
  29. err)
  30. os.Exit(1)
  31. }
  32. for {
  33. log.Printf("receive wait")
  34. d, err := l.Receive(ctx)
  35. if err != nil {
  36. log.Warning("failed to receive identity packet: %v", err)
  37. continue
  38. }
  39. log.Infof("discovered a device at %s packet: %v",
  40. d.From, d.Identity)
  41. }
  42. }