sharpapi / laravel-detect-ai-content
AI-Generated Content Detection for Laravel powered by SharpAPI.com
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/sharpapi/laravel-detect-ai-content
Requires
- php: ^8.1
- ext-json: *
- laravel/framework: ^9.0|^10.0|^11.0|^12.0
- sharpapi/php-core: ^1.0
Requires (Dev)
- laravel/pint: ^1.0
README
AI-Generated Content Detection for Laravel
Leverage AI API to detect AI-generated text content.
Check the details at SharpAPI's AI Content Detector API page.
Requirements
- PHP >= 8.1
- Laravel >= 9.0
Installation
Follow these steps to install and set up the SharpAPI Laravel AI Content Detection package.
- Install the package via
composer:
composer require sharpapi/laravel-detect-ai-content
-
Register at SharpAPI.com to obtain your API key.
-
Set the API key in your
.envfile:
SHARP_API_KEY=your_api_key_here
- [OPTIONAL] Publish the configuration file:
php artisan vendor:publish --tag=sharpapi-detect-ai-content
Key Features
- AI Content Detection: Identify text that may have been generated by AI models like ChatGPT, Claude, or other LLMs.
- Likelihood Score: Returns a 0-100 percentage score indicating how likely the text is AI-generated.
- Detailed Assessment: Provides a one-sentence overall statement about the text.
- Reasoning Explanation: Includes 2-3 sentences explaining the observable cues that support the conclusion.
- Flagged Parts: Highlights specific excerpts from the input text with detected AI patterns.
- Pattern Detection: Identifies AI-associated vocabulary, excessive transitional phrases, and stylistic markers.
- Robust Polling for Results: Polling-based API response handling with customizable intervals.
- API Availability and Quota Check: Check API availability and current usage quotas with SharpAPI's endpoints.
Usage
You can inject the DetectAiContentService class to access AI content detection functionality. For best results, especially with batch processing, use Laravel's queuing system to optimize job dispatch and result polling.
Basic Workflow
- Dispatch Job: Send text content to the API using
detectAi, which returns a status URL. - Poll for Results: Use
fetchResults($statusUrl)to poll until the job completes or fails. - Process Result: After completion, retrieve the results from the
SharpApiJobobject returned.
Note: Each job typically takes a few seconds to complete. Once completed successfully, the status will update to
success, and you can process the results as JSON, array, or object format.
Controller Example
Here is an example of how to use DetectAiContentService within a Laravel controller:
<?php namespace App\Http\Controllers; use GuzzleHttp\Exception\GuzzleException; use SharpAPI\ContentDetectAi\DetectAiContentService; class ContentController extends Controller { protected DetectAiContentService $aiDetectionService; public function __construct(DetectAiContentService $aiDetectionService) { $this->aiDetectionService = $aiDetectionService; } /** * @throws GuzzleException */ public function detectAiContent(string $text) { $statusUrl = $this->aiDetectionService->detectAi($text); $result = $this->aiDetectionService->fetchResults($statusUrl); return response()->json($result->getResultJson()); } }
Handling Guzzle Exceptions
All requests are managed by Guzzle, so it's helpful to be familiar with Guzzle Exceptions.
Example:
use GuzzleHttp\Exception\ClientException; try { $statusUrl = $this->aiDetectionService->detectAi('In conclusion, this comprehensive analysis delves into the multifaceted aspects of modern technology.'); } catch (ClientException $e) { echo $e->getMessage(); }
Optional Configuration
You can customize the configuration by setting the following environment variables in your .env file:
SHARP_API_KEY=your_api_key_here SHARP_API_JOB_STATUS_POLLING_WAIT=180 SHARP_API_JOB_STATUS_USE_POLLING_INTERVAL=true SHARP_API_JOB_STATUS_POLLING_INTERVAL=10 SHARP_API_BASE_URL=https://sharpapi.com/api/v1
AI Content Detection Data Format Example
{
"data": {
"id": "example-uuid",
"type": "api_job_result",
"attributes": {
"type": "content_detect_ai",
"status": "success",
"result": {
"ai_likelihood_percent": 85,
"assessment": "This text shows strong indicators of AI generation.",
"reasoning": "The text uses several AI-associated vocabulary words (comprehensive, delves, multifaceted, crucial, leverage, innovative, foster, streamline) and employs excessive transitional phrases (In conclusion, Furthermore). The formal register and promotional tone are also characteristic of LLM output.",
"flagged_parts": [
{
"text": "comprehensive analysis delves into the multifaceted aspects",
"reason": "AI-associated vocabulary cluster"
},
{
"text": "Furthermore, it is crucial to leverage",
"reason": "Excessive transitional phrase with AI vocabulary"
}
]
}
}
}
}
Support & Feedback
For issues or suggestions, please:
Changelog
Please see CHANGELOG for a detailed list of changes.
Credits
- A2Z WEB LTD
- Dawid Makowski
- Enhance your Laravel AI capabilities!
License
The MIT License (MIT). Please see License File for more information.
Follow Us
Stay updated with news, tutorials, and case studies: