vedanshi-shethia/ai-banner-generator

Laravel package to generate website banners using Gemini AI

Maintainers

Package info

github.com/vedanshi-shethia/ai-banner-generator

pkg:composer/vedanshi-shethia/ai-banner-generator

Statistics

Installs: 1

Dependents: 0

Suggesters: 0

Stars: 0

Open Issues: 0

v1.0.0 2025-12-31 14:23 UTC

This package is auto-updated.

Last update: 2026-03-29 01:14:10 UTC


README

A driver-based, extensible Laravel package for generating high-quality website banners using AI image models (Gemini, OpenAI, or custom providers).

This package abstracts AI image generation, prompt building, image handling, and storage, while allowing developers to plug in their own AI drivers without touching core logic.

โœจ Features

  • ๐Ÿ”Œ Driver-based architecture (Gemini, OpenAI, Null, Custom)
  • ๐Ÿง  Centralized AI model management
  • ๐Ÿ–ผ๏ธ Supports image-to-image generation
  • ๐Ÿงฉ Fully extensible with custom drivers
  • ๐Ÿงผ Automatic temporary file cleanup
  • ๐Ÿ“ฆ Clean separation of concerns (Service, Drivers, Helpers)
  • ๐Ÿ›ก๏ธ Safe base64 image validation before storage

๐Ÿ“ฆ Installation

1๏ธโƒฃ Install via Composer

composer require vedanshi/ai-banner-generator

2๏ธโƒฃ Publish Configuration

php artisan vendor:publish --tag=ai-banner-generator

This will create:

config/ai-banner-generator.php

3๏ธโƒฃ Configure Storage

Ensure your output disk is publicly accessible.

php artisan storage:link

๐Ÿ”‘ Environment variables

AI_BANNER_DRIVER = 'driver_name'

# Storage
GEMINI_INPUT_DISK=local
GEMINI_OUTPUT_DISK=public

๐Ÿง  Storage Design (Important)

This package follows industry best practices:

Type Disk Visibility
Input images local ๐Ÿ”’ Private
Generated banners public ๐ŸŒ Public
storage/
โ”œโ”€โ”€ app/
โ”‚   โ”œโ”€โ”€ private/
โ”‚   โ”‚   โ””โ”€โ”€ banner/input/
โ”‚   โ””โ”€โ”€ public/
โ”‚       โ””โ”€โ”€ banner/output/

โš™๏ธ Configuration (config/ai-banner-generator.php)

return [

    /*
    |--------------------------------------------------------------------------
    | Driver Configuration
    |--------------------------------------------------------------------------
    */

    'driver' => env('AI_BANNER_DRIVER', 'gemini'),

    'drivers' => [

        'gemini' => [
            'model'   => env('GEMINI_MODEL', 'gemini-2.5-flash-image'),
            'api_key' => env('GEMINI_API_KEY'),
        ],

        'openai' => [
            'model'   => env('OPENAI_MODEL', 'gpt-4o-mini'),
            'api_key' => env('OPENAI_API_KEY'),
        ],

    ],

    /*
    |--------------------------------------------------------------------------
    | Storage Configuration
    |--------------------------------------------------------------------------
    */

    'disks' => [
        'input'  => env('BANNER_INPUT_IMAGE_DISK', 'local'),   // private
        'output' => env('BANNER_OUTPUT_IMAGE_DISK', 'public'), // public
    ],

    'paths' => [

        // Input uploads
        'front' => 'banner/front',
        'back' => 'banner/back',
        'reference' => 'banner/ref',

        // Output (generated banners)
        'output' => 'banner/output',
    ],

    'cleanup' => [
        'enabled' => true,
    ],

    /*
    |--------------------------------------------------------------------------
    | Output Configuration
    |--------------------------------------------------------------------------
    */
    'output' => [
        'format' => 'png',
        'allowed_mime_types' => ['image/png', 'image/jpeg'],
    ],

];

๐Ÿ“Œ Important

  • Users switch models only via config
  • No runtime config injection
  • Drivers stay clean and predictable

๐Ÿง  Architecture Overview

Controller / App
     โ†“
BannerService
     โ†“
BannerDriverFactory
     โ†“
Driver (Gemini / OpenAI / Custom)
     โ†“
AI Model

Key Components

Layer Responsibility
Service Business flow
Factory Driver resolution
Driver AI interaction
Helpers Image / prompt handling
Storage File persistence

๐Ÿงฉ Banner Generation Flow

  1. Input images are uploaded
  2. Images are loaded & converted to Base64
  3. Prompt is generated
  4. Driver is resolved
  5. AI generates banner
  6. Image is validated & stored
  7. Temporary files are cleaned
  8. Public URL is returned

๐Ÿš€ Usage

1๏ธโƒฃ Sync Generation (Facade)

use Vedanshi\Banner\Facades\Banner;
use Vedanshi\Banner\Http\Requests\BannerGenerationRequest;

function (BannerGenerationRequest $request) {
    $result = Banner::generate($request->payload());
}

Returns a public URL of the generated banner.

2๏ธโƒฃ Async Generation (Queue)

use Vedanshi\Banner\Jobs\BannerGenerationJob;
use Vedanshi\Banner\Http\Requests\BannerGenerationRequest;

function (BannerGenerationRequest $request) {
    BannerGenerationJob::dispatch($request->payload());
}

โœ… Ideal for:

  • Heavy image processing
  • High-traffic systems
  • Background workflows

๐Ÿงพ Expected Payload Structure

[
    'front_image' => string,        // path on input disk
    'back_image' => string,         // path on input disk
    'transparent_image' => string,  // path on input disk
    'product_name' => string,
]

โš ๏ธ Do NOT pass temp paths (php/tmp). Files must be stored first using Laravel storage.

๐Ÿงน Automatic Cleanup

  • Input images are deleted immediately after successful generation
  • Cleanup is retry-safe
  • Cleanup can be disabled via config
'cleanup' => [
    'enabled' => false,
],

๐Ÿ–ผ๏ธ Image Handling & Safety

Before storing the generated image:

  • data:image/*;base64,... is handled
  • Strict Base64 decoding
  • Image validity is verified
  • MIME type is validated
ImageStorage::store($base64);

This prevents:

  • Invalid data storage
  • Corrupt images
  • Security risks

๐Ÿ”Œ Built-in Drivers

Gemini Driver

new GeminiDriver($config);

Uses Prism internally for image generation.

OpenAI Driver

new OpenAIDriver($config);

Abstracted behind the same interface.

Null Driver

new NullDriver($config);

Useful for:

  • Testing
  • CI pipelines
  • Fallback mode

๐Ÿงฉ Creating a Custom Driver (User Extensible)

1๏ธโƒฃ Implement the Contract

use Vedanshi\Banner\Contracts\BannerDriver;

class MyDriver implements BannerDriver
{
    public function __construct(protected array $config) {}

    public function generate(string $prompt, array $images): string
    {
        // Custom AI logic
        return $base64;
    }
}

2๏ธโƒฃ Register the Driver

use Vedanshi\Banner\Factory\BannerDriverFactory;

BannerDriverFactory::extend('my-driver', function ($config) {
    return new MyDriver($config);
});

3๏ธโƒฃ Add Key in .env

AI_BANNER_DRIVER = 'my-driver'

๐ŸŽ‰ Done โ€” no core code touched.

๐Ÿง  Why This Design Works

  • โœ” Manager-controlled configuration
  • โœ” No runtime config injection
  • โœ” Clean SOLID design
  • โœ” Laravel-style driver extension
  • โœ” Production-ready

This is the same architecture Laravel uses for Cache, Queue, Mail, and Filesystems.

๐Ÿงช Testing

Use the null driver:

AI_BANNER_DRIVER = 'null'

This avoids API calls and allows fast testing.

๐Ÿ“Œ Summary

  • AI-agnostic banner generation
  • Driver-based extensibility
  • Safe image handling
  • Clean separation of concerns
  • Enterprise-grade Laravel architecture

๐Ÿ“„ License

MIT License

๐Ÿ™Œ Credits

Developed by Vedanshi Shethia

๐Ÿค Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss improvements.