This guide will help you get started with the Solace AI Event Connector.
- Python 3.10 or later
- A Solace PubSub+ event broker
- A chat model to connect to (optional)
To get started with creating a solace PubSub+ event broker follow the instructions on Try PubSub+ Event Brokers page.
(Optional) Create a virtual environment:
python3 -m venv env
source env/bin/activate
Set up the connector package
pip install solace-ai-connector
Download an example configuration file:
curl https://raw.githubusercontent.com/SolaceLabs/solace-ai-connector/main/config.yaml > config.yaml
Set the environment variables that the config file needs. In this example:
export SOLACE_BROKER_URL=tcp://<hostname>:<port>
export SOLACE_BROKER_USERNAME=<username>
export SOLACE_BROKER_PASSWORD=<password>
export SOLACE_BROKER_VPN=<vpn>
If running the local version of the broker with default values, the environment variables would be:
export SOLACE_BROKER_URL=ws://localhost:8008
export SOLACE_BROKER_USERNAME=default
export SOLACE_BROKER_PASSWORD=default
export SOLACE_BROKER_VPN=default
(Optional) Store the environment variables permanently in ~/.profile file and activate them by:
source ~/.profile
Run the connector:
solace-ai-connector config.yaml
This very basic connector simply creates a queue on the broker called my_queue
and adds the subscription my/topic1
to it.
Any events published to the broker with a topic my/topic1
will be delivered to the connector and then sent back to the
broker on the topic response/my/topic1
.
To test this, connect to the Solace Broker's browser management UI and select the "Try Me!". Subscribe to "my/>" and "response/>".
Publish a message with the topic my/topic1
and you should see both the request and the reply message in the received messages
area in the Subscriber side of the "Try me!" page.
Download the OpenAI connector example configuration file:
curl https://raw.githubusercontent.com/SolaceLabs/solace-ai-connector/refs/heads/main/examples/llm/langchain_openai_with_history_chat.yaml > langchain_openai_with_history_chat.yaml
For this one, you need to also define the following additional environment variables:
export OPENAI_API_KEY=<your OpenAI key>
export OPENAI_API_ENDPOINT=<base url of your OpenAI endpoint>
export MODEL_NAME=<model name>
Note that if you want to use the default OpenAI endpoint, just delete that line from the langchain_openai_with_history_chat.yaml file.
Install the langchain openai dependencies:
pip install langchain_openai openai
Run the connector:
solace-ai-connector langchain_openai_with_history_chat.yaml
Use the "Try Me!" function on the broker's browser UI (or some other means) to publish an event like this:
Topic: demo/joke/subject
Payload:
{
"joke": {
"subject": "<subject for the joke>"
}
}
In the "Try Me!" also subscribe to demo/joke/subject/response
to see the response
-
Clone the repository and enter its directory:
git clone [email protected]:SolaceLabs/solace-ai-connector.git cd solace-ai-connector
-
(Optional) Create a virtual environment:
python -m venv .venv source .venv/bin/activate
-
Install the required Python packages:
pip install -r requirements.txt
-
(Optional) Edit the example configuration file at the root of the repository:
config.yaml
-
Set up the environment variables that you need for the config.yaml file. The default one requires the following variables:
export SOLACE_BROKER_URL=tcp://<hostname>:<port> export SOLACE_BROKER_USERNAME=<username> export SOLACE_BROKER_PASSWORD=<password> export SOLACE_BROKER_VPN=<vpn>
-
Start the AI Event Connector:
cd src python3 -m solace_ai_connector.main ../config.yaml
-
Use the Solace PubSub+ event broker "Try Me" function to send a message to the AI Event Connector. Make sure that the topic matches the subscription in the configuration file.
-
The AI Event Connector will send the message to the chat model and return the response to the Solace PubSub+ event broker.
To build a Docker image, run the following command:
make build
Checkout configuration or overview next