Documentação REST API completa para integrar a AILoft.
URL baseAutenticaçãoRespostas JSONTodos os pedidos requerem chave API no cabeçalho Authorization como Bearer token.
// Header Authorization: Bearer your-api-token
Mantenha a chave API secreta. Nunca a exponha em código cliente.
/api/agentsLista todos os agentes com metadados, avaliações e preços.categorystringFilter by category (Development, Analytics, Legal, ...)searchstringSearch in name, description and tagsbackendstringFilter by compatible backend (e.g. openai, claude, ollama)pricingstringFilter: "free" or "paid"sortstringSort: popular, newest, rating (default: newest)pagenumberPage number (default: 1)limitnumberResults per page (1–50, default: 12){ agents: Agent[], total: number, page: number }/api/agents/:slugInformação detalhada sobre um agente específico.slugstringUnique agent slug (URL param){ ...AgentDetail, author: { id, name, username }, reviews: Review[] }/api/agents/:slug/reviewsAvaliações paginadas de um agente.slugstringAgent slug (URL param)pagenumberPage number (default: 1)limitnumberResults per page (1–50, default: 10){ reviews: Review[], total: number, page: number }/api/agents/:slug/similarGet similar agents from the same category.slugstringAgent slug (URL param){ agents: Agent[] }/api/agents/:slug/installInstalar agente pago. Debita da carteira.slugstringAgent slug (URL param)backendstringTarget backend (default: "openai"){ success: boolean, message: string, config: InstallConfig }/api/agents/install-freeInstalar agente gratuito. Autenticação necessária.agentSlugstringAgent slug (body)emailstringEmail for delivery (body){ ok: boolean }/api/agents/:slug/reviews🔒Submeter avaliação para um agente instalado.ratingnumberRating 1–5 (required)commentstringReview text (optional){ id, rating, comment, agentId, userId, createdAt }/api/payments/wallet🔒Saldo da carteira e histórico de transações.{ balance, totalEarned, totalWithdrawn, available, stripeAccountStatus }id: stringslug: stringname: stringdescription: stringicon: string | nullcategory: stringagentType: "prompt_based" | "app_ui"compatible: string[]tags: string[]pricing: { type: "one_time", amount?: number }rating: numberinstalls: numberisFeatured: booleancreatedAt: string (ISO 8601)author: { id: string, name: string }
id: stringrating: number (1–5)comment: string | nullagentId: stringuserId: stringuser: { name, username, avatarUrl }createdAt: string (ISO 8601)