Skip to main content

MQ Connector for Neon Modules

Project description

Neon MQ Connector

The Neon MQ Connector is an MQ interface for microservices.

Configuration

By default, this package will use ovos-config to read default configuration. In general, configuration should be passed to the MQConnector object at init.

Legacy Configuration

A global configuration for the MQ Connector may be specified at ~/.config/neon/mq_config.json. This configuration file may contain the following keys:

  • server: The hostname or IP address of the MQ server to connect to. If left blank, this defaults to "localhost"
  • port: The port used by the MQ server. If left blank, this defaults to 5672
  • users: A mapping of service names to credentials. Note that not all users will have permissions required to access each service.
{
  "server": "localhost",
  "port": 5672,
  "users": {
    "<service_name>": {
      "username": "<username>",
      "password": "<password>"
    }
  }
}

Services

The MQConnector class should be extended by a class providing some specific service. Service classes will specify the following parameters.

  • service_name: Name of the service, used to identify credentials in configuration
  • vhost: Virtual host to connect to; messages are all constrained to this namespace.
  • consumers: Dict of names to ConsumerThread objects. A ConsumerThread will accept a connection to a particular connection, a queue, and a callback_func
    • connection: MQ connection to the vhost specified above.
    • queue: Queue to monitor within the vhost. A vhost may handle multiple queues.
    • callback_func: Function to call when a message arrives in the queue

Callback Functions

A callback function should have the following signature:

def handle_api_input(self,
                     channel: pika.channel.Channel,
                     method: pika.spec.Basic.Return,
                     properties: pika.spec.BasicProperties,
                     body: bytes):
    """
        Handles input requests from MQ to Neon API

        :param channel: MQ channel object (pika.channel.Channel)
        :param method: MQ return method (pika.spec.Basic.Return)
        :param properties: MQ properties (pika.spec.BasicProperties)
        :param body: request body (bytes)
    """

Generally, body should be decoded into a dict, and that dict should contain message_id. The message_id should be included in the body of any response to associate the response to the request. A response may be sent via:

 channel.queue_declare(queue='<queue>')

 channel.basic_publish(exchange='',
                       routing_key='<queue>',
                       body=<data>,
                       properties=pika.BasicProperties(expiration='1000')
                       )

Where <queue> is the queue to which the response will be published, and data is a bytes response (generally a base64-encoded dict).

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

neon_mq_connector-0.7.2a1.tar.gz (18.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

neon_mq_connector-0.7.2a1-py3-none-any.whl (26.8 kB view details)

Uploaded Python 3

File details

Details for the file neon_mq_connector-0.7.2a1.tar.gz.

File metadata

  • Download URL: neon_mq_connector-0.7.2a1.tar.gz
  • Upload date:
  • Size: 18.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for neon_mq_connector-0.7.2a1.tar.gz
Algorithm Hash digest
SHA256 00e916bbec8a9ee1034a15627391c15344adb32ec963f5325a37aa4f99808a5c
MD5 b077e9ff7c351f72ec29c5cc90e1a24c
BLAKE2b-256 1519a4f8dcf35a0d780066c0e62a2eda881dd1cc6e999b7dc30c25bdd37ccb8a

See more details on using hashes here.

File details

Details for the file neon_mq_connector-0.7.2a1-py3-none-any.whl.

File metadata

File hashes

Hashes for neon_mq_connector-0.7.2a1-py3-none-any.whl
Algorithm Hash digest
SHA256 4afb19ebb7daae31bee8230fb6795efea4bd7c40f86173554d87f2ff25e086e0
MD5 9fd8fb09316f34da4a0c3d68044c3cc2
BLAKE2b-256 ca2e96c97c5fa7f3ca4c3c42a39fa95f2a3396e5fed0626f4b5add281adf6184

See more details on using hashes here.

Supported by

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