-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathchannel.go
35 lines (30 loc) · 893 Bytes
/
channel.go
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
package rabbitmq
import (
"errors"
"fmt"
"github.com/xmapst/go-rabbitmq/internal/manager/channel"
)
type Channel struct {
*channel.Manager
}
// NewChannel returns a new channel to the cluster.
func NewChannel(conn *Conn, optionFuncs ...func(*ChannelOptions)) (*Channel, error) {
defaultOptions := getDefaultChannelOptions()
options := &defaultOptions
for _, optionFunc := range optionFuncs {
optionFunc(options)
}
if conn.connManager == nil {
return nil, errors.New("connection manager can't be nil")
}
chanManager, err := channel.New(conn.connManager, options.ConfirmMode, options.Logger, conn.connManager.ReconnectInterval)
if err != nil {
return nil, err
}
err = chanManager.QosSafe(options.QOSPrefetch, 0, options.QOSGlobal)
if err != nil {
_ = chanManager.Close()
return nil, fmt.Errorf("declare qos failed: %w", err)
}
return &Channel{chanManager}, nil
}