summaryrefslogtreecommitdiffstats
path: root/src/go/collectors/go.d.plugin/modules/chrony/client.go
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-05 12:08:03 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-05 12:08:18 +0000
commit5da14042f70711ea5cf66e034699730335462f66 (patch)
tree0f6354ccac934ed87a2d555f45be4c831cf92f4a /src/go/collectors/go.d.plugin/modules/chrony/client.go
parentReleasing debian version 1.44.3-2. (diff)
downloadnetdata-5da14042f70711ea5cf66e034699730335462f66.tar.xz
netdata-5da14042f70711ea5cf66e034699730335462f66.zip
Merging upstream version 1.45.3+dfsg.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--src/go/collectors/go.d.plugin/modules/chrony/client.go61
1 files changed, 61 insertions, 0 deletions
diff --git a/src/go/collectors/go.d.plugin/modules/chrony/client.go b/src/go/collectors/go.d.plugin/modules/chrony/client.go
new file mode 100644
index 000000000..e850ff239
--- /dev/null
+++ b/src/go/collectors/go.d.plugin/modules/chrony/client.go
@@ -0,0 +1,61 @@
+// SPDX-License-Identifier: GPL-3.0-or-later
+
+package chrony
+
+import (
+ "fmt"
+ "net"
+
+ "github.com/facebook/time/ntp/chrony"
+)
+
+func newChronyClient(c Config) (chronyClient, error) {
+ conn, err := net.DialTimeout("udp", c.Address, c.Timeout.Duration())
+ if err != nil {
+ return nil, err
+ }
+
+ client := &simpleClient{
+ conn: conn,
+ client: &chrony.Client{Connection: conn},
+ }
+ return client, nil
+}
+
+type simpleClient struct {
+ conn net.Conn
+ client *chrony.Client
+}
+
+func (sc *simpleClient) Tracking() (*chrony.ReplyTracking, error) {
+ reply, err := sc.client.Communicate(chrony.NewTrackingPacket())
+ if err != nil {
+ return nil, err
+ }
+
+ tracking, ok := reply.(*chrony.ReplyTracking)
+ if !ok {
+ return nil, fmt.Errorf("unexpected reply type, want=%T, got=%T", &chrony.ReplyTracking{}, reply)
+ }
+ return tracking, nil
+}
+
+func (sc *simpleClient) Activity() (*chrony.ReplyActivity, error) {
+ reply, err := sc.client.Communicate(chrony.NewActivityPacket())
+ if err != nil {
+ return nil, err
+ }
+
+ activity, ok := reply.(*chrony.ReplyActivity)
+ if !ok {
+ return nil, fmt.Errorf("unexpected reply type, want=%T, got=%T", &chrony.ReplyActivity{}, reply)
+ }
+ return activity, nil
+}
+
+func (sc *simpleClient) Close() {
+ if sc.conn != nil {
+ _ = sc.conn.Close()
+ sc.conn = nil
+ }
+}