apsonex/laravel-stock-image

Stock Images

Maintainers

๐Ÿ‘ apsonex

Package info

github.com/apsonex/laravel-stock-image

pkg:composer/apsonex/laravel-stock-image

Statistics

Installs: 49

Dependents: 0

Suggesters: 0

Stars: 0

Open Issues: 0

1.0.3 2025-06-17 13:57 UTC

Requires

Requires (Dev)

Suggests

None

Provides

None

Conflicts

None

Replaces

None

MIT c3da8af3f7664154bc5d233b7a55517bdef40bd7

  • Apsonex Inc. <info.woop@apsonex.com>

laravelapsonexlaravel-stock-image

This package is auto-updated.

Last update: 2026-06-17 16:02:58 UTC


README

Laravel Stock Image is a pluggable image search API tool that allows you to query stock images from various providers like Unsplash, Pexels, Pixabay, and also generate placeholder images dynamically.

๐Ÿš€ Features

  • Supports multiple providers: Unsplash, Pexels, Pixabay, Placeholder
  • Custom API keys per request or config
  • Smart keyword fallback mechanism
  • Random image selection and provider rotation
  • Easy Laravel integration with route and controller
  • Fully testable and extendable architecture

๐Ÿ“ฆ Installation

composer require apsonex/laravel-stock-image

If you're using Laravel 10+, package auto-discovery will register everything automatically.

โš™๏ธ Configuration

Publish the configuration file if needed:

php artisan vendor:publish --tag=laravel-stock-image-config

This will create config/stock-image.php:

return [
 'route' => [
 'enable' => true,
 'path' => 'api/ai/tools/stock-images/search',
 'middleware' => [
 // middlewares
 ],
 ],
];

๐Ÿ”Œ Routing

The package automatically registers this route when enabled in the config:

POST /stock-image-search

Payload Parameters

Key Type Description
keywords string Comma-separated keywords to search images (required)
random_result boolean Whether to return a random image from results
random_provider boolean Whether to pick a random provider
page int Which page to fetch from provider
cache boolean Whether to cache the result (default: false)
result_limit int Limit number of images result
provider_api_keys array Optional - Override API keys per provider (optional)
placeholder_size string Used only when fallback placeholder is returned e.g. 600x400
placeholder_text string Text to show in placeholder image e.g. Sample Text
placeholder_text_color string Color for placeholder text e.g. #000000
placeholder_bg_color string Background color for placeholder e.g. #cccccc

โœ… Example Request (JSON)

POST to /api/ai/tools/stock-images/search

// result
{
 "keywords": "mountain, beach",
 "random_result": true,
 "random_provider": false,
 "page": 1,
 "cache": false,
 "result_limit": 10,
 "provider_api_keys": {
 "pexels": "<PEXELS_API_KEY>",
 "unsplash": "<UNSPLASH_API_KEY>",
 "pixabay": "<PIXABAY_API_KEY>"
 },
 "placeholder_text": "Placeholder Image",
 "placeholder_size": "600x400",
 "placeholder_bg_color": "cccccc",
 "placeholder_text_color": "333333"
}

๐Ÿ”„ Sample JSON Response

{
 "items": [
 {
 "image_url": "https://example.com/image.jpg",
 "image_description": "A stunning mountain landscape",
 "source": "unsplash"
 }
 ],
 "meta": {
 "page": 1,
 "per_page": 30,
 "count": 1
 },
 "status": "success"
}

๐Ÿงช Testing

You can run tests using Pest:

./vendor/bin/pest

Make sure to mock external APIs to avoid hitting rate limits.

๐Ÿง  License

MIT ยฉ Apsonex