darknautica/volta-php 问题修复 & 功能扩展

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

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

darknautica/volta-php

最新稳定版本:v1.0.0

Composer 安装命令:

composer require darknautica/volta-php

包简介

The official Laravel SDK for Volta — AI billing, handled.

README 文档

README

The official Laravel SDK for Volta — AI billing, handled.

Latest Version on Packagist License: MIT

Requirements

  • PHP 8.2+
  • Laravel 10, 11, or 12

Installation

composer require darknautica/volta-php

Publish the config:

php artisan vendor:publish --tag=volta-config

Add to your .env:

VOLTA_APP_KEY=your-app-key-here
VOLTA_BASE_URL=https://volta.test

Quick Start

Three lines to add billing to any AI endpoint:

use DarkNautica\Volta\Facades\Volta;

// Check before calling AI
if (!Volta::hasAccess($user->id)) {
    return response()->json(['error' => 'Insufficient credits'], 402);
}

// Make your AI call here...

// Deduct after success
Volta::charge($user->id, 1);

Middleware

Protect entire routes automatically:

// Requires 1 credit (default)
Route::post('/generate', [AIController::class, 'generate'])
    ->middleware('volta.gate');

// Requires 3 credits, specific model
Route::post('/analyze', [AIController::class, 'analyze'])
    ->middleware('volta.gate:3,gpt-4');

The middleware resolves the user automatically:

  1. $request->volta_user_id if set explicitly
  2. $request->user()->id if authenticated
  3. Falls back to request IP for anonymous users

Blade Directives

{{-- Show balance --}}
<span>@voltaBalance($user->id) credits remaining</span>

{{-- Conditional content --}}
@voltaHasAccess($user->id, 1)
    <button>Generate</button>
@endvoltaHasAccess

@voltaNoAccess($user->id, 1)
    <a href="/billing">Buy more credits</a>
@endvoltaNoAccess

{{-- Embed billing portal --}}
<iframe src="@voltaPortalUrl($user->id)" width="100%" height="600"></iframe>

Available Methods

Method Description
Volta::charge($userId, $credits, $model?) Deduct credits. Throws on failure.
Volta::hasAccess($userId, $credits?) Check access. Always returns bool.
Volta::balance($userId) Get credit balance.
Volta::topUp($userId, $credits) Add credits to a user.
Volta::usage($userId) Get usage history array.
Volta::portalUrl($userId, $options?) Get signed billing portal URL.

Testing Connection

php artisan volta:test

This will verify your API key, test connectivity, and display account info.

Error Handling

use DarkNautica\Volta\Exceptions\InsufficientCreditsException;
use DarkNautica\Volta\Exceptions\RateLimitExceededException;

try {
    Volta::charge($user->id, 1);
} catch (InsufficientCreditsException $e) {
    return response()->json(['error' => 'Not enough credits'], 402);
} catch (RateLimitExceededException $e) {
    return response()->json(['error' => 'Slow down', 'retry_after' => $e->retryAfter], 429);
}

Fail Silently Mode

Set VOLTA_FAIL_SILENTLY=true in .env to prevent Volta errors from crashing your app. When enabled:

  • hasAccess() returns false
  • balance() returns 0
  • charge() returns false

This is useful for apps that should degrade gracefully if Volta is unreachable.

Configuration

Env Variable Default Description
VOLTA_APP_KEY (required) Your Volta API key
VOLTA_BASE_URL https://volta.test Volta API base URL
VOLTA_TIMEOUT 10 HTTP timeout in seconds
VOLTA_FAIL_SILENTLY false Suppress exceptions, return safe defaults
VOLTA_CACHE_TTL 30 Balance cache duration in seconds (0 to disable)

License

MIT

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-04-09

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固