Skip to content

The search box in the website knows all the secrets—try it!

For any queries, join our Discord Channel to reach us faster.

JasperFx Logo

JasperFx provides formal support for Wolverine and other JasperFx libraries. Please check our Support Plans for more details.

Dead Lettering

By default, Wolverine dead lettering is disabled for GCP Pub/Sub transport and Wolverine uses any persistent envelope storage for dead lettering. You can opt in to Wolverine dead lettering through GCP Pub/Sub globally as shown below.

cs
var host = await Host.CreateDefaultBuilder()
    .UseWolverine(opts =>
    {
        opts.UsePubsub("your-project-id")

            // Enable dead lettering for all Wolverine endpoints
            .EnableDeadLettering(
                // Optionally configure how the GCP Pub/Sub dead letter itself
                // is created by Wolverine
                options =>
                {
                    options.Topic.MessageRetentionDuration =
                        Duration.FromTimeSpan(TimeSpan.FromDays(14));

                    options.Subscription.MessageRetentionDuration =
                        Duration.FromTimeSpan(TimeSpan.FromDays(14));
                }
            );
    }).StartAsync();

snippet source | anchor

When enabled, Wolverine will try to move dead letter messages in GCP Pub/Sub to a single, global topic named "wlvrn.dead-letter".

That can be overridden on a single endpoint at a time (or by conventions too of course) like:

cs
var host = await Host.CreateDefaultBuilder()
    .UseWolverine(opts =>
    {
        opts.UsePubsub("your-project-id")
            .EnableDeadLettering();

        // No dead letter queueing
        opts.ListenToPubsubTopic("incoming")
            .DisableDeadLettering();

        // Use a different dead letter queue
        opts.ListenToPubsubTopic("important")
            .ConfigureDeadLettering(
                "important_errors",

                // Optionally configure how the dead letter itself
                // is built by Wolverine
                e => { e.TelemetryEnabled = true; }
            );
    }).StartAsync();

snippet source | anchor

Released under the MIT License.