This project provides an example of a very basic agent connected to Semantic Workbench.
The agent doesn't do anything real, it simply echoes back messages sent by the user. The code here is only meant to show the basics, to familiarize with code structure and integration with Semantic Workbench.
The sample project utilizes the WorkbenchConnector
library, enabling you to focus on agent development and testing.
The connector provides a base AgentBase
class for your agents, and takes care of connecting your agent with the workbench backend service.
Semantic Workbench allows mixing agents from different frameworks and multiple instances of the same agent. The connector can manage multiple agent instances if needed, or you can work with a single instance if preferred. To integrate agents developed with other frameworks, we recommend isolating each agent type with a dedicated web service, ie a dedicated project.
Project Structure
appsettings.json
:- Purpose: standard .NET configuration file.
- Key Points:
- Contains default values, in particular the ports used.
- Optionally create
appsettings.development.json
for custom settings.
MyAgentConfig.cs
:- Purpose: contains your agent settings.
- Key Points:
- Extend
AgentConfig
to integrate with the workbench connector. - Describe the configuration properties using
[AgentConfigProperty(...)]
attributes.
- Extend
MyAgent.cs
:- Purpose: contains your agent logic.
- Key Points:
- Extend
AgentBase
. - Implement essential methods:
ReceiveMessageAsync()
: handles incoming messages using intent detection, plugins, RAG, etc.- You can override default implementation for additional customization.
- Extend
MyWorkbenchConnector.cs
:- Purpose: custom instance of WorkbenchConnector.
- Key Points:
- Contains code to create an instance of your agent class.
- You can override default implementation for additional customization.
Program.cs
:- Purpose: sets up configuration, dependencies using .NET Dependency Injection and starts services.
- Key Points:
- Starts a web service to enable communication with Semantic Workbench.
- Starts an instance of WorkbenchConnector for agent communication.