gradiwapp/gradiwapp-php-sdk 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

gradiwapp/gradiwapp-php-sdk

最新稳定版本:v1.0.0

Composer 安装命令:

composer require gradiwapp/gradiwapp-php-sdk

包简介

Official PHP SDK for GradiWapp External API - Multi-tenant WhatsApp SaaS Messaging Platform

README 文档

README

📘 Overview

The GradiWapp PHP SDK provides a clean, developer-friendly wrapper around the GradiWapp External API, powering multi-tenant WhatsApp messaging at scale.

It supports:

  • All message types (text, image, media, file, location…)
  • Webhooks
  • Timezone-aware scheduling
  • Multi-session messaging
  • Laravel 7–12 integration
  • Full HMAC authentication

This SDK is production-ready and built with Stripe/Twilio-level documentation quality.

📑 Table of Contents

🚀 Features

  • ✔ Framework-agnostic (PHP 7.4+)
  • ✔ First-class Laravel 7–12 integration
  • ✔ Fully typed methods + PHPDoc
  • ✔ Timezone-aware scheduling (ISO8601 + IANA)
  • ✔ Webhook creation + signature verification
  • ✔ All message types supported
  • ✔ Clean exceptions & error classes
  • ✔ Internal base URL (cannot be changed)
  • ✔ Production-ready architecture

🧩 Requirements

Component Version
PHP >= 7.4
Laravel 7 → 12
Extensions cURL + JSON

📥 Installation

Non-Laravel Installation

composer require gradiwapp/gradiwapp-php-sdk

Before publishing on Packagist:

{
  "repositories": [
    {
      "type": "vcs",
      "url": "https://github.com/ahmednaserdev/gradiwapp-php-sdk.git"
    }
  ],
  "require": {
    "gradiwapp/gradiwapp-php-sdk": "dev-main"
  }
}

Laravel Installation

composer require gradiwapp/gradiwapp-php-sdk

Publish config:

php artisan vendor:publish --provider="GradiWapp\Sdk\Laravel\GradiWappServiceProvider" --tag=config

This generates:

  • config/gradiwapp.php

Add environment variables:

GRADIWAPP_API_KEY=your_key
GRADIWAPP_API_SECRET=your_secret
GRADIWAPP_TIMEOUT=30
GRADIWAPP_MAX_RETRIES=1
GRADIWAPP_VERIFY_SSL=true

Note: Base URL is internal and cannot be changed.

⚡ Quick Start

Plain PHP Example

use GradiWapp\Sdk\Client;
use GradiWapp\Sdk\Config;

$config = new Config(
    apiKey: 'your_key',
    apiSecret: 'your_secret'
);

$client = new Client($config);

$response = $client->messages()->sendText(
    to: '+123456',
    body: 'Hello from GradiWapp!'
);

Laravel — Dependency Injection

public function send(GradiWapp\Sdk\Client $client)
{
    return $client->messages()->sendText(
        to: '+123456',
        body: 'Hello!'
    );
}

Laravel — Facade

use GradiWapp\Sdk\Laravel\Facades\GradiWapp;

GradiWapp::messages()->sendText('+123456', 'Hello!');

💬 Messaging

Text Messages

$client->messages()->sendText('+123', 'Hello!');

Image Messages

$client->messages()->sendImage(
    '+123',
    'https://example.com/image.jpg',
    caption: 'Check this out!'
);

Media Messages

$client->messages()->sendMedia('+123', 'https://example.com/video.mp4');

Location Messages

$client->messages()->sendLocation(
    '+123',
    40.7128,
    -74.0060,
    name: 'NYC',
    address: 'New York'
);

File Messages

$client->messages()->sendFile(
    '+123',
    fileUrl: 'https://example.com/doc.pdf',
    filename: 'Invoice.pdf'
);

Contact (vCard)

$client->messages()->sendContact(
    '+123',
    contactsId: 'whatsapp_contact_id'
);

Reply Messages

$client->messages()->sendReply(
    '+123',
    'This is a reply',
    replyToMessageId: '01ABC...'
);

Text + Media Combination

$client->messages()->sendBoth(
    '+123',
    'Hello!',
    mediaUrl: 'https://example.com/pic.jpg',
    caption: 'Nice image'
);

⏰ Timezone-Aware Scheduling

ISO8601 Example

ScheduleOptions::fromIso8601('2025-11-15T08:02:00+03:00');

IANA Timezone

ScheduleOptions::at(
    new DateTimeImmutable('2025-11-15 08:00'),
    'Africa/Cairo'
);

📡 Message Status

$client->messages()->getStatus('01ABC...');

🧩 Webhooks

Create Webhook

$client->webhooks()->create(
    'delivery',
    'https://yourdomain.com/webhooks',
    secret: 'secret'
);

Verify Signature

Webhooks::verifySignature($payload, $signature, $secret);

❗ Error Handling

Built-in typed exceptions:

  • AuthenticationException
  • ValidationException
  • HttpException
  • GradiWappException

Example:

try {
    $client->messages()->sendText('+123', 'Hi');
} catch (ValidationException $e) {
    print_r($e->getErrors());
}

🔧 Advanced Usage

Multiple Sessions

$client->messages()->sendText(
    '+123',
    'Hi',
    sessionId: 'session_01'
);

Priority

$client->messages()->sendText('+123', 'Hi', priority: 'high');

📦 Response Format

Your backend returns:

{
  "success": true,
  "message": "Message queued successfully",
  "data": {
    "id": "01ARZ3N...",
    "status": "queued"
  }
}

🧭 Versioning & SDK Stability

This SDK follows Semantic Versioning (SemVer):

  • MAJOR → Breaking changes
  • MINOR → New features
  • PATCH → Bug fixes

🤝 Contributing

Pull Requests are welcome!

📄 License

MIT License.

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-11-15