Publicamos SDKs oficiales para los lenguajes habituales, que gestionan por usted la firma HMAC, la lógica de reintentos y el manejo del Idempotency-Key. El contrato de la API (OpenAPI 3.1) es independiente del lenguaje: también puede escribir su propio cliente sin problemas.
PHP
// composer require kernelhost/reseller-api-php (in development)
use KernelHost\ResellerApi\Client;
$kh = new Client(getenv('KH_KEY'), getenv('KH_SECRET'));
$products = $kh->get('/products');
$order = $kh->post('/orders', ['product_id' => 42, 'billing_cycle' => 'monthly']);
Node.js
// npm install @kernelhost/reseller-api (in development)
import { Client } from '@kernelhost/reseller-api';
const kh = new Client({ key: process.env.KH_KEY, secret: process.env.KH_SECRET });
const products = await kh.get('/products');
const order = await kh.post('/orders', { product_id: 42, billing_cycle: 'monthly' });
Python
# pip install kernelhost-reseller-api (in development)
from kernelhost_reseller_api import Client
kh = Client(key=os.environ['KH_KEY'], secret=os.environ['KH_SECRET'])
products = kh.get('/products')
order = kh.post('/orders', product_id=42, billing_cycle='monthly')
Go
// go get github.com/kernelhost/reseller-api-go (in development)
import "github.com/kernelhost/reseller-api-go"
kh := resellerapi.New(os.Getenv("KH_KEY"), os.Getenv("KH_SECRET"))
products, _ := kh.Get("/products")
order, _ := kh.Post("/orders", map[string]any{"product_id": 42, "billing_cycle": "monthly"})
¿Su lenguaje no figura en la lista? La API sigue el estándar abierto OpenAPI 3.1 y un ejemplo cURL de unas 20 líneas en shell puro basta para cualquier endpoint. Consulte la página de autenticación para la lógica de firma.

