udio
@elizaos/plugin-udio
A Udio AI music generation plugin for ElizaOS that enables AI-powered music creation and audio manipulation.
OVERVIEW
The Udio plugin integrates Udio AI's powerful music generation capabilities into ElizaOS, providing a seamless way to:
- Generate music from text prompts with fine-tuned parameters
- Create custom music with advanced control over style and lyrics
- Extend existing audio tracks with AI-powered continuation
INSTALLATION
npm install @elizaos/plugin-udio
QUICK START
- Register the plugin with ElizaOS:
import { udioPlugin } from '@elizaos/plugin-udio';
import { Eliza } from '@elizaos/core';
const eliza = new Eliza();
eliza.registerPlugin(udioPlugin);
-
Configure your Udio authentication token in your environment:
UDIO_AUTH_TOKEN=your-udio-auth-token
FEATURES
-
Generate Music (udio.generate) Generate music using a text prompt with basic control parameters. This is ideal for quick music generation:
- Simple text-to-music generation
- Optional seed for reproducible results
- Support for custom lyrics
await eliza.execute('udio.generate', {
prompt: 'An upbeat electronic dance track with energetic beats',
seed: 12345,
customLyrics: 'Your custom lyrics here',
});
-
Extend Audio (udio.extend) Extend existing audio tracks to create longer compositions. Useful for:
- Lengthening existing music pieces
- Creating variations of existing tracks
- Seamless continuation of melodies
await eliza.execute('udio.extend', {
prompt: 'Continue with similar style',
audioConditioningPath: 'path/to/audio.mp3',
audioConditioningSongId: 'original-song-id',
cropStartTime: 30,
seed: 12345,
customLyrics: 'Additional lyrics for the extension',
});
Generation Parameters Explained:
-
seed: Controls the randomness of generation
- Same seed will produce similar results
- Different seeds create variations
- Defaults to -1 if not specified
-
cropStartTime: Controls where the extension begins (for extend action)
- Specified in seconds
- Optional parameter for precise control over continuation point
API REFERENCE
Action Parameters:
- Generate Music (udio.generate)
interface UdioGenerateOptions {
prompt: string; // Required: Text description of desired music
seed?: number; // Optional: Seed for reproducibility
customLyrics?: string; // Optional: Custom lyrics
}
- Extend Audio (udio.extend)
interface UdioExtendOptions {
prompt: string; // Required: Description for continuation
audioConditioningPath: string; // Required: Path to original audio
audioConditioningSongId: string; // Required: ID of original song
cropStartTime?: number; // Optional: Start time in seconds
seed?: number; // Optional: Seed for reproducibility
customLyrics?: string; // Optional: Lyrics for extension
}
Response Types:
interface UdioSong {
id: string; // Generated song ID
title: string; // Song title
song_path: string; // Path to download the song
finished: boolean; // Generation status
}
interface UdioResponse {
songs: UdioSong[]; // Array of generated songs
}
ERROR HANDLING
The plugin includes built-in error handling for common scenarios:
try {
await eliza.execute('udio.generate', params);
} catch (error) {
// Handle errors
console.error(error.message);
}
EXAMPLES
Creating a Pop Song:
const result = await eliza.execute('udio.generate', {
prompt: 'Create a pop song with vocals, drums, and guitar',
seed: 12345,
customLyrics: 'Verse 1: Your custom lyrics here...',
});
Extending an Existing Track:
const extended = await eliza.execute('udio.extend', {
prompt: 'Continue with the same energy and mood',
audioConditioningPath: '/path/to/original.mp3',
audioConditioningSongId: 'original-123',
cropStartTime: 60, // Start continuation from 1 minute mark
customLyrics: 'Verse 2: Continuing the story...',
});
LICENSE
MIT
SUPPORT
For issues and feature requests, please open an issue on our GitHub repository.
Built with ❤️ for ElizaOS