lucianotonet / cartesia-php
Cartesia PHP SDK
Installs: 179
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 1
Forks: 0
Open Issues: 0
Type:package
Requires
- php: ^8.1.0
- guzzlehttp/guzzle: ^7.9
- vlucas/phpdotenv: ^5.6
Requires (Dev)
- phpunit/phpunit: ^9.6
README
Description
This PHP library provides a robust interface to interact with the Cartesia REST API, allowing you to seamlessly integrate Cartesia's advanced voice cloning and speech synthesis capabilities into your PHP applications. Please note that this library is not officially affiliated with Cartesia AI.
Key Features
- High-Quality Speech Synthesis: Convert text into natural and expressive speech using Cartesia's state-of-the-art models.
- Custom Voice Cloning: Create personalized synthetic voices that capture the unique essence and tone of your desired speakers.
- Simplified Voice Management: Easily manage your cloned voices, including listing, retrieving, updating, and deleting.
- Intuitive and User-Friendly Interface: The library offers a straightforward and well-documented interface, making integration with your PHP projects quick and easy.
Getting Started
Installation
The recommended way to install the Cartesia PHP library is via Composer:
composer require lucianotonet/cartesia-php
Usage
Here's a basic example of how to use the library to generate speech from text:
require 'vendor/autoload.php'; use LucianoTonet\CartesiaPHP\CartesiaClient; // Initialize the Cartesia client with your API key $client = new CartesiaClient('your_api_key'); // Define the speech synthesis parameters $modelId = 'sonic-english'; // Voice model ID $transcript = 'Hello, world!'; // Text to be converted to speech $voiceId = 'a0e99841-438c-4a64-b679-ae501e7d6091'; // Cloned voice ID // Make a speech synthesis request try { $response = $client->streamSpeechBytes([ 'context_id' => 'happy-monkeys-fly', 'model_id' => $modelId, 'transcript' => $transcript, 'voice' => [ 'mode' => 'id', 'id' => $voiceId ], 'output_format' => [ 'container' => 'raw', 'encoding' => 'pcm_f32le', 'sample_rate' => 44100 ] ]); // Save the generated audio to a file file_put_contents('hello_world.wav', $response->getBody()); echo "Audio successfully generated at hello_world.wav\n"; } catch (Exception $e) { echo 'Error: ' . $e->getMessage() . "\n"; }
Roadmap
- API Status and Version
- Create Voice
- Delete Voice
- Update Voice
- Get Voice
- List Voices
- Clone Voice (Clip)
- Mix Voices
- Stream Speech (Bytes)
- Stream Speech (Server-Sent Events)
- Stream Speech (WebSocket)
- Localize Voice
Running the examples
To run the examples provided in the examples
directory, copy the .env.example
file to .env
and update the CARTESIA_API_KEY
constant with your Cartesia API key:
# .env
CARTESIA_API_KEY=your_api_key
Then, start the PHP server in the package root directory:
php -S 127.0.0.1:80
Now you can access the examples in your browser at http://127.0.0.1/examples/
.
Complete Documentation
For detailed information on all available features and options, please refer to the original REST API documentation: https://docs.cartesia.ai.
For the full source code and examples, visit the GitHub repository: https://github.com/lucianotonet/cartesia-php
Support
If you encounter any issues or have any questions about the library, please feel free to open an issue on GitHub. Contributions to the project are also welcome!