承接 feridev/avanak 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

feridev/avanak

Composer 安装命令:

composer require feridev/avanak

包简介

A modern, well-tested, PSR-compliant PHP SDK for Avanak SMS API.

README 文档

README

This package provides an interface to connect with the Avanak API and supports features like voice call sending, OTP delivery, text-to-speech (TTS) generation, managing voice messages, and reporting.

📦 Package Structure

Avanak/
├── Contracts/
│   ├── AvanakClientInterface.php      # Main interface for interacting with the Avanak API
│   └── HttpClientInterface.php        # Abstraction layer for the HTTP client (e.g., Guzzle)
│
├── Http/
│   └── AvanakClient.php               # Implementation of AvanakClientInterface
│
├── Services/
│   ├── AccountService.php             # Fetch account status
│   ├── AudioService.php               # Manage audio files (upload, delete, download, details)
│   ├── OtpService.php                 # Send OTP
│   └── TtsService.php                 # Send TTS call, generate TTS, quick send message
│
├── Support/
│   └── GuzzleHttpClient.php           # Guzzle-based implementation of HttpClientInterface

🧰 Installation

If installing locally:

composer require feridev/avanak

Or, add to your composer.json:

"repositories": [
  {
    "type": "path",
    "url": "./packages/avanak"
  }
],
"require": {
  "feridev/avanak": "*"
}

⚙️ Environment Setup

In your .env file, add the Avanak API token:

AVANAK_API_TOKEN=your_avanak_token

🧱 Usage

1. Define the client:

use Avanak\Support\GuzzleHttpClient;
use Avanak\Http\AvanakClient;

$httpClient = new GuzzleHttpClient(env('AVANAK_API_TOKEN'));
$client = new AvanakClient($httpClient, 'https://api.avanak.ir');

2. Use the services:

Get account status:

use Avanak\Services\AccountService;

$service = new AccountService($client);
$status = $service->getAccountStatus();

Send OTP:

use Avanak\Services\OtpService;

$service = new OtpService($client);
$response = $service->sendOtp('your_password', 5, '09123456789');

Generate TTS:

use Avanak\Services\TtsService;

$service = new TtsService($client);
$response = $service->generateTTS('your_password', 'Sample text', 'Message Title');

Quick send with TTS:

$response = $service->quickSendWithTTS('your_password', 'Sample text', 'Title', '09123456789');

Send voice call using existing message ID:

$response = $service->quickSend('your_password', 1234, '09123456789');

Get quick send details:

$response = $service->getQuickSend('your_password', 4567);

Upload audio file:

use Avanak\Services\AudioService;

$audioService = new AudioService($client);
$base64Audio = base64_encode(file_get_contents('file.mp3'));
$response = $audioService->uploadAudio($base64Audio, 'your_password', 'Message Title', true);

Download audio message:

$response = $audioService->downloadAudioMessage('message_id');

Get message details:

$response = $audioService->getMessageDetails('message_id');

Delete audio message:

$response = $audioService->deleteAudioMessage('message_id');

Get all messages:

$response = $audioService->getMessages();

Get quick send statistics:

$response = $audioService->getQuickSendStatistics('2024-01-01T00:00:00', '2024-12-31T23:59:59');

🧪 Testing

Automated tests have not been added yet. It is recommended to use Postman or curl for manual request validation.

🔒 Security

Ensure all sensitive data such as API tokens are stored in the .env file and never committed to version control.

🧑‍💻 Contributing

Contributions and pull requests to improve this package are welcome!

📜 License

This package is released under the MIT License.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-05-04