定制 offline-agency/laravel-aruba-sms 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

offline-agency/laravel-aruba-sms

最新稳定版本:1.1.0

Composer 安装命令:

composer require offline-agency/laravel-aruba-sms

包简介

Laravel notification channel and API client for Aruba SMS Panel

README 文档

README

Latest Version on Packagist Tests PHPStan codecov Total Downloads License

Laravel notification channel and API client for the Aruba SMS API Service. See the official API documentation.

Laravel Aruba SMS

Requirements

  • PHP ^8.4
  • Laravel ^12.0 or ^13.0

Installation

From Packagist (when published)

composer require offline-agency/laravel-aruba-sms

Local development (path repository)

Add to your project's composer.json:

{
    "repositories": [
        {
            "type": "path",
            "url": "packages/offline-agency/laravel-aruba-sms",
            "options": {
                "symlink": true
            }
        }
    ]
}

Then:

composer require offline-agency/laravel-aruba-sms

Publish config

php artisan vendor:publish --tag=aruba-sms-config

Configuration

Copy .env.example or add these to your .env:

# Required
ARUBA_SMS_ID=your_username
ARUBA_SMS_PASSWORD=your_password

# Optional
ARUBA_SMS_SENDER=YourBrand              # Default: YourBrand
ARUBA_SMS_SANDBOX=true                  # Default: false (set true for dev/test)
ARUBA_SMS_MINIMUM_SMS=50                # Low credit threshold
ARUBA_SMS_LOW_CREDIT_RECIPIENTS=admin@example.com,dev@example.com
Variable Description Default
ARUBA_SMS_ID Aruba SMS Panel username (required)
ARUBA_SMS_PASSWORD Aruba SMS Panel password (required)
ARUBA_SMS_BASE_URL API base URL https://smspanel.aruba.it/API/v1.0/REST/
ARUBA_SMS_SENDER Sender name on recipient's device YourBrand
ARUBA_SMS_MESSAGE_TYPE SMS type N (Normal)
ARUBA_SMS_SANDBOX Log instead of sending false
ARUBA_SMS_MINIMUM_SMS Low credit alert threshold 50
ARUBA_SMS_LOW_CREDIT_RECIPIENTS Comma-separated admin emails (empty)

Usage

Via Notification Channel

Create a notification that uses the aruba-sms channel:

use Illuminate\Notifications\Notification;
use OfflineAgency\ArubaSms\ArubaSmsMessage;

class OrderShippedNotification extends Notification
{
    public function via($notifiable): array
    {
        return ['aruba-sms'];
    }

    public function toArubaSms($notifiable): ArubaSmsMessage
    {
        return (new ArubaSmsMessage())
            ->content("Your order #{$this->order->id} has been shipped")
            ->to($notifiable->phone_number);
    }
}

Using the Built-in Generic Notification

use OfflineAgency\ArubaSms\Notifications\SendSmsNotification;
use Illuminate\Support\Facades\Notification;

// Send to an on-demand notifiable (no User model needed)
Notification::route('aruba-sms', null)
    ->notify(new SendSmsNotification('Your message', '+393331234567'));

// Or send via a notifiable model
$user->notify(new SendSmsNotification('Your message', '+393331234567'));

Direct Client Usage

use OfflineAgency\ArubaSms\ArubaSmsClient;
use OfflineAgency\ArubaSms\ArubaSmsMessage;

$client = app(ArubaSmsClient::class);
$message = new ArubaSmsMessage('Hello!', '+393331234567');
$response = $client->sendMessage($message);

Via Facade

use OfflineAgency\ArubaSms\Facades\ArubaSms;
use OfflineAgency\ArubaSms\ArubaSmsMessage;

// Send a message
$message = new ArubaSmsMessage('Hello!', '+393331234567');
ArubaSms::sendMessage($message);

// Check remaining credits
$response = ArubaSms::checkSmsStatus();

// Get sending history
$response = ArubaSms::getSmsHistory('20260101000001');

Backward Compatibility (Legacy Pattern)

Notifications with public $message, $recipient, $message_type properties work without implementing toArubaSms():

class LegacyNotification extends Notification
{
    public string $message = 'Hello';
    public string $recipient = '+393331234567';
    public string $message_type = 'N';

    public function via($notifiable): array
    {
        return ['aruba-sms'];
    }
}

Artisan Commands

aruba:sms

Manage the Aruba SMS Panel from the command line:

# Check remaining SMS credits
php artisan aruba:sms status

# View sending history
php artisan aruba:sms history --from=20260101000001 --to=20260201000001

# View history for a specific recipient
php artisan aruba:sms recipient-history --recipient=+393331234567 --from=20260101000001

# Send a test SMS
php artisan aruba:sms notification --phoneNumber=+393331234567

# Get raw remaining credit count (for scripting)
php artisan aruba:sms remaining-credit-raw

aruba:check-remaining-sms

Check remaining credits and send email alerts if below threshold:

php artisan aruba:check-remaining-sms

Configure alert recipients via ARUBA_SMS_LOW_CREDIT_RECIPIENTS env variable.

Phone Number Formatting

The package provides a PhoneNumberFormatter utility for Italian phone numbers:

use OfflineAgency\ArubaSms\Support\PhoneNumberFormatter;

// Add +39 prefix and strip spaces
PhoneNumberFormatter::format('333 123 4567');    // '+393331234567'
PhoneNumberFormatter::format('+393331234567');   // '+393331234567' (unchanged)
PhoneNumberFormatter::format('+447911123456');   // '+447911123456' (non-IT preserved)

// Strip spaces only
PhoneNumberFormatter::stripSpaces('+39 333 123 4567'); // '+393331234567'

Sandbox Mode

When ARUBA_SMS_SANDBOX=true, SMS messages are logged to the Laravel log instead of being sent to the Aruba API. This is useful for development and testing:

[2026-02-19 10:30:00] local.INFO: *** Aruba SMS DEBUG ***
[2026-02-19 10:30:00] local.INFO: Notification sent successfully!
[2026-02-19 10:30:00] local.INFO: Recipient: +393331234567
[2026-02-19 10:30:00] local.INFO: Message: Your code is 123456
[2026-02-19 10:30:00] local.INFO: Message Type: N
[2026-02-19 10:30:00] local.INFO: *** *** ***

Testing

composer test              # Run tests
composer test:coverage     # Run with coverage (100% minimum)
composer analyse           # PHPStan level 6
composer format            # Fix code style (Pint)
composer format:check      # Check code style without fixing

All tests use Pest with Http::fake() and never call the real Aruba API.

License

MIT

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-02-20

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固