a3e580d050
It was possible for `Session.mux` to return before an associated link. Due to an oversight during refactoring the detach logic did not account for this and the link could deadlock attempting to send the response Detach. |
||
---|---|---|
fuzz | ||
internal/testconn | ||
.gitattributes | ||
.gitignore | ||
.travis.yml | ||
CHANGELOG.md | ||
LICENSE | ||
Makefile | ||
README.md | ||
buffer.go | ||
client.go | ||
conn.go | ||
decode.go | ||
doc.go | ||
encode.go | ||
error_pkgerrors.go | ||
error_stdlib.go | ||
example_test.go | ||
fuzz.go | ||
fuzz_test.go | ||
integration_test.go | ||
log.go | ||
log_debug.go | ||
marshal_test.go | ||
sasl.go | ||
types.go |
README.md
pack.ag/amqp
pack.ag/amqp is an AMQP 1.0 client implementation for Go.
AMQP 1.0 is not compatible with AMQP 0-9-1 or 0-10, which are the most common AMQP protocols in use today. A list of AMQP 1.0 brokers and other AMQP 1.0 resources can be found at github.com/xinchen10/awesome-amqp.
This project is currently alpha status, though it is currently being used by my employer in a pre-production capacity.
API is subject to change until 1.0.0. If you choose to use this library, please vendor it.
Install
go get -u pack.ag/amqp
Contributing
I'm happy to accept contributions. A proper CONTRIBUTING.md
is in the works. In the interim please open an issue before beginning work so we can discuss it. I want to ensure there is no duplication of effort and that any new functionality fits with the goals of the project.
Example Usage
package main
import (
"context"
"fmt"
"log"
"pack.ag/amqp"
)
func main() {
// Create client
client, err := amqp.Dial("amqps://my-namespace.servicebus.windows.net",
amqp.ConnSASLPlain("access-key-name", "access-key"),
)
if err != nil {
log.Fatal("Dialing AMQP server:", err)
}
defer client.Close()
// Open a session
session, err := client.NewSession()
if err != nil {
log.Fatal("Creating AMQP session:", err)
}
ctx := context.Background()
// Send a message
{
// Create a sender
sender, err := session.NewSender(
amqp.LinkTargetAddress("/queue-name"),
)
if err != nil {
log.Fatal("Creating sender link:", err)
}
ctx, cancel := context.WithTimeout(ctx, 5*time.Second)
// Send message
err = sender.Send(ctx, &amqp.Message{
Data: []byte("Hello!"),
})
if err != nil {
log.Fatal("Sending message:", err)
}
cancel()
sender.Close()
}
// Continuously read messages
{
// Create a receiver
receiver, err := session.NewReceiver(
amqp.LinkSourceAddress("/queue-name"),
amqp.LinkCredit(10),
)
if err != nil {
log.Fatal("Creating receiver link:", err)
}
ctx, cancel := context.WithCancel(ctx)
defer cancel()
for {
// Receive next message
msg, err := receiver.Receive(ctx)
if err != nil {
log.Fatal("Reading message from AMQP:", err)
}
// Accept message
msg.Accept()
fmt.Printf("Message received: %s\n", msg.Data)
}
}
}
Notable Bugs/Shortcomings
- Closing a sessions does not send an end performative.
- Testing should be improved. Currently fuzz testing and basic Azure Service Bus integration testing is being performed.
Features - Short Term
- Set sender filters to support Azure Event Hubs. (Supported as of 0.3.0)
Features - Medium Term
- Support message producer operations. (Supported as of 0.2.0)
Other Notes
By default, this package depends only on the standard library. Building with the
pkgerrors
tag will cause errors to be created/wrapped by the github.com/pkg/errors
library. This can be useful for debugging and when used in a project using
github.com/pkg/errors.