SeaGOAT-server
The seagoat-server is an integral component of the Seagoat command-line tool designed to analyze your codebase and create vector embeddings for it.
While it serves as a backend for the command-line tool, also allows you to use it through HTTP to build your own SeaGOAT-based applications.
Starting the server
To boot up the server for a specific repository, use:
repo_path
: Path to your Git repository--port
: (Optional) Run the server on a specific port
If you don't specify a custom port, a random port will be assigned to your server. Don't worry, SeaGOAT will still be able to automatically find the server corresponding to a specific repository.
Developing with SeaGOAT-server
SeaGOAT-server not only serves as a backend for the SeaGOAT command-line tool but also offers developers the capability to integrate its functions to build custom applications.
Retrieving server information
As SeaGOAT servers only run on one repository at a time, there is a command provided in order to gather information about all running servers, including how to access them through HTTP.
To get detailed information about all active SeaGOAT servers in JSON format,
you can utilize the server-info
command:
You will receive a response similar to this:
{
"version": "0.5.3",
"globalCache": "/home/myuser/.cache/seagoat",
"globalConfigFile": "/home/myuser/.config/seagoat/config.yml",
"servers": {
"/path/to/repository/1": {
"cacheLocation": {
"chroma": "/home/myuser/.cache/seagoat/bfe8133b9e871ea1c8498a0"
},
"isRunning": true,
"host": "127.0.0.1",
"port": "8080",
"address": "http://127.0.0.1:8080"
},
"/path/to/repository/2": {
"cacheLocation": {
"chroma": "/home/myuser/.cache/seagoat/fbee39c83bd47a75e2f839"
},
"isRunning": false,
"host": "127.0.0.1",
"port": "8081",
"address": "http://127.0.0.1:8081"
}
}
}
In this output, you can also see information about where databases/caches
related to your projects are stored. globalCache
is the parent folder of
all the cache directories, and withing each server, you can find an attribute
called cacheLocation
which contains the path to the cache directory for
each different type of cache associated with that project.
If you want to create a configuration file, you can see the path for it
in the globalConfigFile
attribute. This depends on your operating system.
You can also create a configuration file for your project. See
the configuration documentation for more information.
Making queries using the API
If you want to build an application using SeaGOAT-server, first you need to figure out the address of the server you want to connect to.
Once you have the address, you can start making queries to it. For instance,
this is how you'd make a query using curl
to the server running on
http://localhost:32835
:
You will receive a response similar to this one:
{
"results": [
{
"path": "tests/conftest.py",
"fullPath": "/home/user/repos/SeaGOAT/tests/conftest.py",
"score": 0.6,
"blocks": [
{
"lines": [
{
"score": 0.21,
"line": 100,
"lineText": "def very_relevant_function():",
"resultTypes": [
"result"
]
}
],
"lineTypeCount": {
"result": 1
}
}
{
"lines": [
{
"score": 0.6,
"line": 489,
"lineText": " contents=(\"hello()\\n\" * (i % 50)),",
"resultTypes": [
"result"
]
},
{
"score": 0.84,
"line": 490,
"lineText": " return foo * bar",
"resultTypes": [
"result"
]
}
],
"lineTypeCount": {
"result": 1
}
}
]
},
{
"path": "tests/test_cli.py",
"fullPath": "/home/user/repos/SeaGOAT/tests/test_cli.py",
"score": 0.87,
"blocks": [... etc ... ]
},
... etc ...
],
"version": "0.26.0"
}
Understanding the response
The response contains the following information:
version
- This is the version of SeaGOAT being usedresults
- This is an array containing your results
Each result inside results has the following data:
path
- The (relative) path of the file within the repository.fullPath
- The absolute path to the file in your filesystem.score
- A number indicating how relevant a result is, smaller is better.blocks
- An array of relevant code blocks from this file.
Within each block you will find:
lines
- An array of line objects containing:score
- Relevance score for this line. Seescore
above.line
- The line number in the file where the result was found.lineText
- The actual text content of that line.resultTypes
- An array indicating all types of result on this line"result"
Means that the line is directly relevant to the query"context"
Means that the line was added as a context line
lineTypeCount
- An object containing a count of all line types within the code block. SeeresultTypes
for more.