Skip to main content

A library for getting events throughout the system

Project description

Eventbus

A library for dealing with getting arbitrary events moving throughout the system

Changelog

3.11

Don’t use release 3.10, it will never ack messages. This is fixed in 3.11

3.10

Add require_ack parameter to async subscribe.

I need this for windows so that we can test how to not loose messages

3.9

Remove ConnectionClosed error from async and never raise it. Instead we want to just loop and attempt to reconnect as normal. If your code is expecting ConnectionClosed in ebosia.async, it will no longer be present, don’t use it

3.8

Now when connecting to RabbitMQ the process will loop indefinitely allowing RabbitMQ to come up. This is for our containerized environments where all containers start at the same time and we don’t want containers to fail just because they started first and faster

Also this bumps up our dependency on aioamqp to the lates (0.8.2) to get some fixes around heartbeats

3.7

Be less dramatic about failure to sync.publish. Instead of an exception-like error log we emit a warning. If we fail all the way we’ll emit a proper exception

3.6

3.5 is a bad tag, don’t use it, don’t download it. It has a pdb.set_trace in the setup.py…

3.5

Add async publishing and a bridge to allow async code to correct call ebosia.sync.publish. It’s wild and wacky, but it should work

3.4

Fix bug with nesting event publishes inside event subscriptions when testing

3.3

Automatically serialize UUIDs and datetimes. This means that you can be less careful about what you push through ebosia. No I don’t currently support a custom formatter, sorry, send me a PR

3.2

Allow more control when subscribing like specifying the durability and exclusivity. This can be useful for making exchanges and queues that last longer than the connection to the client

3.1

Allow eventbus fixture’s published() function to not specify the payload. This is nice if your code emits very large or very complex events and you don’t want to have to fully check that payload in every test

3.0

Rename the package to ebosia so that I can publish on PyPI

2.3

Fix synchronous subscription. I had broken it in some previous update

2.2

Allow publishing enums as event topics. This modifies the default JSON serializer a bit so that it attempts to convert anything passed through to a string which is nice for items coming out of a database

2.1

Automatically retry on connection failure when synchronously publishing. Also fix the sync-emitter script. And include it on installation

2.0

Update kombo package to 3.0.34

1.9

Make heartbeat default to 60 seconds but configurable to whatever you want

1.8

Add default heartbeat for async connections of 60 seconds.

1.7

Add reconnect logic for async subscribers. Subscribers now need to supply on_reconnect when calling connect. on_reconnect should be a coroutine that sets up the subscriptions whenever a reconnection is made

1.6

Make the connection stateful in the global state. Whenever a connection is made we’ll keep it in a global location so that clients can get it via ebosia.get(). This means a client doesn’t need to pass the connection around everywhere

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ebosia-3.11.tar.gz (8.4 kB view hashes)

Uploaded Source

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page