stablehorde
v1.0.0
Published
Node.js API wrapper for Stable Horde.
Downloads
6
Maintainers
Readme
node-stablehorde
Unofficial Node.js API client for Stable Horde.
Getting Started
Install the module:
npm install stablehorde
# or
yarn add stablehorde
Instantiate the client:
const { Client } = require('stablehorde');
const stablehorde = new Client({
apiKey: 'your-api-key',
});
Async Mode
You can use the methods offered by the client object directly. When you do this, the polling logic is left to you.
// initiate a generation request
const request = await stablehorde.generateAsync({
prompt: 'Painting of a dachshund drinking water in the style of Van Gogh',
}); // initiate a generation request
// check the status of the request
const status = await stablehorde.check(request);
// get the resulting generations
// you should only call this if the status object says the request is complete
// you can only send this request twice every minute
const generations = await stablehorde.generations(request);
Event Emitter Mode
You can also let the library handle the polling logic for you in an event emitter style. This is the recommended way to use the library.
const handler = client.newRequestHandler(10000); // poll every 10 seconds
handler.on('created', (request) => {
console.log('request created', request);
});
handler.on('statusPolled', (status) => {
console.log('status polled', status);
});
handler.on('finished', (generations) => {
console.log('generations finished', generations);
});
handler.on('error', (err) => {
console.error('error', err);
});
handler.generate({
prompt: 'Painting of a dachshund drinking water in the style of Van Gogh',
});
Join The Horde!
Stable Horde is run by individuals all around the world. If you want to help out and reduce waiting times for everyone, consider joining the horde!
For Contributors
node-stablehorde
is written in TypeScript, therefore, you have to compile it
to JavaScript if you'd like to test your changes. You may do so using the
following command:
npm run build
The library does not currently employ any unit testing measures, however, if you would like to contribute to the library, please make sure that your changes pass linting. You can run the following command to check:
npm run lint
License
MIT. Please read the LICENSE file for more information.