cloudstudio / token-usage
This is my package token-usage
Requires
- php: ^8.1
- illuminate/contracts: ^10.0
- spatie/laravel-package-tools: ^1.14.0
Requires (Dev)
- laravel/pint: ^1.0
- nunomaduro/collision: ^7.8
- orchestra/testbench: ^8.8
- pestphp/pest: ^2.20
- pestphp/pest-plugin-arch: ^2.0
- pestphp/pest-plugin-laravel: ^2.0
This package is auto-updated.
Last update: 2025-01-10 10:43:48 UTC
README
Token-Usage is a Laravel package that provides advanced token management functionalities for Laravel applications. It offers features for tracking token usage, setting token limits based on different time periods, and integrating these checks easily into Laravel applications. This package is ideal for developers looking to efficiently manage and monitor token consumption in their Laravel projects.
The main idea is to track and manage token usage for AI services. For example, if a SaaS platform charges $10 for 1000 tokens, this package can efficiently monitor and manage the token consumption. It is perfect to work with OpenAI, ollama for enhanced functionality, etc.
Installation
composer require cloudstudio/token-usage
Configuration
Publish the package configuration file:
php artisan vendor:publish --tag="token-usage-config"
This will publish a config file with the following structure:
return [ 'model_mappings' => [ 'user' => \App\Models\User::class, // Add more model mappings here ], 'plans' => [ 'basic' => [ 'model_limits' => [ 'user' => [ 'daily' => 1, 'weekly' => 5, 'monthly' => 10, 'yearly' => 100, ], // Define more model limits here ], ], 'premium' => [ // Define premium plan limits... ], ], ];
Additionally, publish the package's migrations:
php artisan vendor:publish --tag="token-usage-migrations"
These migrations will create tables in your database to store token usage data. The migrations are compatible with UUIDs. If your application doesn't use UUIDs, you can modify the migration files accordingly.
User Setup
For the package to work correctly, your users
table needs to have a plan
field. You can add this field by creating a new migration or creating a new accesor in your User
model. For example, to create a new migration, run the following command:
php artisan make:migration add_plan_to_users_table
If you prefer using a model accesor, add the following method to your User
model:
public function getPlanAttribute() { return 'basic'; }
In the migration file, add the plan
field, like so:
Schema::table('users', function (Blueprint $table) { $table->string('plan')->default('basic'); });
This field is used to determine the token limit plan associated with each user. This setup is optional but recommended for full functionality.
Usage
Basic Usage
First, remember to add the HasTokenUsage
trait to your model. This trait can be used with any model.
namespace App\Models; use Cloudstudio\TokenUsage\Traits\TokenUsageTrait; class User extends Authenticatable { use TokenUsageTrait; // Other model methods and properties }
With this setup, you are ready to work with tokens. Here are some examples:
// Access a model record $project = Project::first(); // Add tokens $project->addTokens(3); // Remove tokens $project->removeTokens(3); // Reset tokens $project->resetTokens(); // Show token records $tokensToday = $project->dailyTokens(); $tokensThisWeek = $project->weeklyTokens(); $tokensThisMonth = $project->monthlyTokens(); $tokensThisYear = $project->yearlyTokens(); // Show token usage sum $tokensUsedToday = $project->dailyTokens()->sum("tokens_used"); // Show token usage per model $tokensPerModel = Project::getDailyTokens();
For blade directives, middleware and form you can use 2 parameters.
1º Parameter: The name of the model. (video, user). 2º Parameter: The name of the plan. (daily, weekly, monthly, yearly).
This information is stored in the config file.
All records have user_id assigned, so if you use directly user as model, you can get all records of the user for all models, so you can know how many tokens have been used by the user, globally.
Blade Directive
Easily check for token availability in Blade templates:
@hasTokenUsage('video', 'daily') I have tokens @endHasTokenUsage
Route Middleware
Protect routes using token usage middleware:
Route::get('/test-token-usage', function () { return response()->json(['message' => 'You have tokens available!']); })->middleware('check-token-usage:video,daily');
Form Request Validation
Validate token usage in form requests:
$request->validate([ 'field' => [new \Cloudstudio\TokenUsage\Rules\TokenUsageRule('video', 'daily')], ]);
Testing
Run tests using Pest PHP:
pest
Changelog, Contributing, and Security
Credits
License
This package is open-sourced software licensed under the MIT License.