Custom Providers
Want to add support for a new AI provider in Prism? This guide will walk you through creating and registering your own custom provider implementation.
Provider Interface
All providers must implement the EchoLabs\Prism\Contracts\Provider
interface:
php
namespace EchoLabs\Prism\Contracts;
use EchoLabs\Prism\Embeddings\Request as EmbeddingsRequest;
use EchoLabs\Prism\Embeddings\Response as EmbeddingsResponse;
use EchoLabs\Prism\Providers\ProviderResponse;
use EchoLabs\Prism\Structured\Request as StructuredRequest;
use EchoLabs\Prism\Text\Request as TextRequest;
interface Provider
{
public function text(TextRequest $request): ProviderResponse;
public function structured(StructuredRequest $request): ProviderResponse;
public function embeddings(EmbeddingsRequest $request): EmbeddingsResponse;
}
The interface is intentionally simple, requiring just one method to handle text generation requests.
Registration Process
Once you've created your provider, register it with Prism in a service provider:
php
namespace App\Providers;
use App\Prism\Providers\MyCustomProvider;
use Illuminate\Support\ServiceProvider;
class AppServiceProvider extends ServiceProvider
{
public function boot(): void
{
$this->app['prism-manager']->extend('my-custom-provider', function ($app, $config) {
return new MyCustomProvider(
apiKey: $config['api_key'] ?? '',
);
});
}
}
Then add your provider configuration to config/prism.php
:
php
return [
'providers' => [
// ... other providers ...
'my-custom-provider' => [
'api_key' => env('MY_CUSTOM_PROVIDER_API_KEY'),
],
],
];
Now you can use your custom provider:
php
use EchoLabs\Prism\Facades\Prism;
$response = Prism::text()
->using('my-custom-provider', 'model-name')
->withPrompt('Hello, custom AI!')
->generate();