moshipp/mosend-sdk
Composer 安装命令:
composer require moshipp/mosend-sdk
包简介
SDK oficial de PHP para la API de Mosend (WhatsApp Business, Web Chat, Bot, Billing, Webhooks).
README 文档
README
SDK oficial de PHP para la API REST de Mosend — WhatsApp Business, Web Chat, Bot, Billing y Webhooks.
- Cero dependencias — solo
ext-curlyext-json(ideal para WooCommerce / hosting compartido). - PHP 7.4+.
- Auth automática (API key
X-Api-Keyo Bearer JWT), errores tipados, paginación por cursor y verificación de webhooks HMAC.
Cobertura completa: los 57 resources de la API (mismo mapa que el SDK de TypeScript, verificado 1:1 contra el OpenAPI del backend). Pendiente solo la publicación a Packagist (próxima fase).
Instalación
composer require moshipp/mosend-sdk
Uso
use Mosend\MosendClient; $mosend = new MosendClient([ 'apiKey' => getenv('MOSEND_API_KEY'), // mk_live_<prefix>.<secret> 'orgId' => getenv('MOSEND_ORG_ID'), // UUID de tu organización ]); // Enviar una plantilla $msg = $mosend->messages->send([ 'phoneNumberId' => '<phone-uuid>', 'to' => '573001234567', // E.164 sin '+' 'type' => 'template', 'templateId' => '<uuid-de-la-plantilla>', 'variables' => ['Juan', 'FAC-2026-0042'], ]); echo $msg['id'], ' ', $msg['metaMessageId'], PHP_EOL; // Paginar conversaciones (maneja el cursor por vos) foreach ($mosend->conversations->iterate(['status' => 'open']) as $conv) { echo $conv['id'], PHP_EOL; }
Errores
use Mosend\Exception\MosendRateLimitException; use Mosend\Exception\MosendApiException; try { $mosend->messages->send([...]); } catch (MosendRateLimitException $e) { error_log('rate limit; reintentar en ' . $e->getRetryAfterSec() . 's'); } catch (MosendApiException $e) { error_log($e->getStatus() . ' ' . $e->getMessage() . ' meta=' . $e->getMetaCode()); }
Webhooks
use Mosend\Webhooks\WebhookVerifier; use Mosend\Exception\MosendWebhookSignatureException; $raw = file_get_contents('php://input'); // body CRUDO $sig = $_SERVER['HTTP_X_MOSEND_SIGNATURE'] ?? null; try { $event = WebhookVerifier::parseEvent($raw, $sig, getenv('MOSEND_WEBHOOK_SECRET')); // $event['event'] => 'message.new' | 'message.status' | ... // deduplicá por $event['deliveryId'] } catch (MosendWebhookSignatureException $e) { http_response_code(401); exit; }
Idempotencia y reintentos
$mosend->messages->send([...], ['idempotencyKey' => 'order-42-greeting']); $mosend = new MosendClient([ 'apiKey' => '...', 'orgId' => '...', 'retries' => ['max' => 3, 'on' => [429, 502, 503]], // opt-in, con backoff ]);
Desarrollo
composer install composer test # PHPUnit php scripts/smoke.php # verificación rápida sin composer
Licencia
MIT © Moshipp SAS
统计信息
- 总下载量: 0
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 4
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2026-06-17