Skip to main content

Easily LISTEN to PostgreSQL NOTIFY notifications

Project description

pgnotify: Easily LISTEN to PostgreSQL NOTIFY notifications

LISTEN to and process NOTIFY events with a simple for loop, like so:

from pgnotify import await_pg_notifications

for notification in await_pg_notifications(
        'postgresql:///nameofdatabase',
        ['channel1', 'channel2']):

    print(notification.channel)
    print(notification.payload)

You can also handle timeouts and signals, as in this more fully-fleshed example:

import signal

from pgnotify import await_pg_notifications, get_dbapi_connection

CONNECT = "postgresql:///example"
e = get_dbapi_connection(CONNECT)

SIGNALS_TO_HANDLE = [signal.SIGINT, signal.SIGTERM]

  for n in await_pg_notifications(
      e,
      ["hello", "hello2"],
      timeout=10,
      yield_on_timeout=True,
      handle_signals=SIGNALS_TO_HANDLE,
  ):
      # when n is an integer, a signal has been has been caught for further handling.
      if isinstance(n, int):
          sig = signal.Signals(n)
          if n in SIGNALS_TO_HANDLE:
              print(f"handling {sig.name}")
          print("interrupted, stopping")
          break

      # if `yield_on_timeout` has been set to True, the loop returns None after the timeout has been reached
      elif n is None:
          print("timeout, continuing")

      # handle the actual notify occurrences here
      else:
          print((n.pid, n.channel, n.payload))

Further documentation to come.

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

pgnotify-0.1.1541159130.tar.gz (3.9 kB view hashes)

Uploaded Source

Built Distribution

pgnotify-0.1.1541159130-py2.py3-none-any.whl (7.6 kB view hashes)

Uploaded Python 2 Python 3

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