Build AI Agents able to interact with other Agents and the Nevermined Network.
This repository contains a template to build AI Agents able to interact with other Agents and the Nevermined Network. Using this template, you get out of the box the following features:
- Standard HTTP API interface to expose your AI agent logic to others
- Generic model normalizing tasks and steps in such a way external users can interface with your agent in a standard way
- Automatic OpenAPI documentation generation
- Generic boilerplate code allowing to keep track and retrieve the tasks and steps executed by the agent
- HTTP Authorization to protect the API endpoints
- Integration with Nevermined ecosystem
Just clone this repository and run the following commands:
# Install all the dependencies
$ yarn
# Configure the database where we are gonna store the tasks and steps info
$ yarn database:run-migrations
# Start the api server
$ yarn start:api
# Start the backend transactions processor
$ yarn start:proc
By default the server will start at http://localhost:4100
. You can change the port by setting the API_PORT
environment variable.
The agent can be configured using environment variables. The following variables are available:
API_HOST
: The host where the server will listen to. Default islocalhost
.API_PORT
: The port where the server will listen to. Default is4100
.API_AUTH_TOKEN
: If given the server will require this token to be passed in theAuthorization
header to access the API. Example: IfAUTH_TOKEN=my-secret-token
the client will need to send the following header in the request:Authorization: Bearer my-secret-token
.API_ENABLE_HTTPS_REDIRECT
: Enable the automatic redirection to HTTPS. Default isfalse
.NVM_ENVIRONMENT
: The Nevermined environment where the agent is registered. Default isappTesting
. You can find the full list here: https://docs.nevermined.app/docs/environments/NVM_AGENT_DID
: The DID of the agent. This is used to identify the agent in the Nevermined network. Example:did:nv:123456789abcdefghi
.NVM_SUBSCRIPTION_DID
: The DID of the subscription. This is used to identify the subscription in the Nevermined network. Example:did:nv:123456789abcdefghi
.
The template is designed to be as simple as possible to allow you to focus on the AI logic of your agent. The main files you need to modify are:
processor.controller.ts
: This file contains the main logic of your agent. You can implement your AI logic here.
Copyright 2024 Nevermined AG
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.