-
Notifications
You must be signed in to change notification settings - Fork 31
Expand file tree
/
Copy pathsimple.go
More file actions
103 lines (89 loc) · 3.03 KB
/
simple.go
File metadata and controls
103 lines (89 loc) · 3.03 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
// Copyright (c) Abstract Machines
// SPDX-License-Identifier: Apache-2.0
package simple
import (
"context"
"log/slog"
"github.com/absmach/mproxy/pkg/handler"
)
var _ handler.Handler = (*Handler)(nil)
// Handler is a simple example handler that logs all events.
type Handler struct {
logger *slog.Logger
}
// New creates a new example handler.
func New(logger *slog.Logger) *Handler {
if logger == nil {
logger = slog.Default()
}
return &Handler{
logger: logger,
}
}
// AuthConnect authorizes a client connection.
func (h *Handler) AuthConnect(ctx context.Context, hctx *handler.Context) error {
h.logger.Info("AuthConnect",
slog.String("session", hctx.SessionID),
slog.String("username", hctx.Username),
slog.String("client_id", hctx.ClientID),
slog.String("remote", hctx.RemoteAddr),
slog.String("protocol", hctx.Protocol))
return nil
}
// AuthPublish authorizes a publish operation.
func (h *Handler) AuthPublish(ctx context.Context, hctx *handler.Context, topic *string, payload *[]byte) error {
h.logger.Info("AuthPublish",
slog.String("session", hctx.SessionID),
slog.String("username", hctx.Username),
slog.String("topic", *topic),
slog.Int("payload_size", len(*payload)))
return nil
}
// AuthSubscribe authorizes a subscribe operation.
func (h *Handler) AuthSubscribe(ctx context.Context, hctx *handler.Context, topics *[]string) error {
h.logger.Info("AuthSubscribe",
slog.String("session", hctx.SessionID),
slog.String("username", hctx.Username),
slog.Any("topics", *topics))
return nil
}
// OnConnect is called after successful connection.
func (h *Handler) OnConnect(ctx context.Context, hctx *handler.Context) error {
h.logger.Info("OnConnect",
slog.String("session", hctx.SessionID),
slog.String("username", hctx.Username),
slog.String("client_id", hctx.ClientID))
return nil
}
// OnPublish is called after successful publish.
func (h *Handler) OnPublish(ctx context.Context, hctx *handler.Context, topic string, payload []byte) error {
h.logger.Info("OnPublish",
slog.String("session", hctx.SessionID),
slog.String("username", hctx.Username),
slog.String("topic", topic),
slog.Int("payload_size", len(payload)))
return nil
}
// OnSubscribe is called after successful subscription.
func (h *Handler) OnSubscribe(ctx context.Context, hctx *handler.Context, topics []string) error {
h.logger.Info("OnSubscribe",
slog.String("session", hctx.SessionID),
slog.String("username", hctx.Username),
slog.Any("topics", topics))
return nil
}
// OnUnsubscribe is called after unsubscription.
func (h *Handler) OnUnsubscribe(ctx context.Context, hctx *handler.Context, topics []string) error {
h.logger.Info("OnUnsubscribe",
slog.String("session", hctx.SessionID),
slog.String("username", hctx.Username),
slog.Any("topics", topics))
return nil
}
// OnDisconnect is called when a client disconnects.
func (h *Handler) OnDisconnect(ctx context.Context, hctx *handler.Context) error {
h.logger.Info("OnDisconnect",
slog.String("session", hctx.SessionID),
slog.String("username", hctx.Username))
return nil
}