izaghar / xivapi-laravel
Laravel integration for XIVAPI PHP client
Installs: 228
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/izaghar/xivapi-laravel
Requires
- php: ^8.3
- illuminate/http: ^11.0|^12.0
- illuminate/support: ^11.0|^12.0
- izaghar/xivapi-php: ^2.0
Requires (Dev)
- laravel/pint: ^1.0
- spatie/laravel-data: ^4.18
Suggests
- spatie/laravel-data: Use the XivApiNormalizer to convert XIVAPI responses to Laravel Data DTOs
This package is auto-updated.
Last update: 2025-12-12 18:03:50 UTC
README
Laravel integration for the XIVAPI PHP client.
Installation
composer require izaghar/xivapi-laravel
The service provider will be auto-discovered.
Configuration
Publish the config file:
php artisan vendor:publish --tag=xivapi-config
Environment Variables
XIVAPI_LANGUAGE=en XIVAPI_GAME_VERSION=7.0 XIVAPI_SCHEMA=exdschema@latest XIVAPI_LOCALIZATIONS=en,de,fr,ja
Config File
// config/xivapi.php return [ 'language' => env('XIVAPI_LANGUAGE'), 'game_version' => env('XIVAPI_GAME_VERSION'), 'schema' => env('XIVAPI_SCHEMA'), 'localizations' => env('XIVAPI_LOCALIZATIONS'), ];
Usage
Via Facade
use XivApi\Laravel\Facades\XivApi; // Fetch an item $item = XivApi::sheet('Item')->row(4)->get(); // Search with query string $results = XivApi::search() ->query('+Name~"Potion" +LevelItem>=10') ->sheets(['Item']) ->get(); // Search with SearchQuery builder use XivApi\Query\SearchQuery; $results = XivApi::search() ->query(SearchQuery::where('Name')->contains('Potion')) ->sheets(['Item']) ->get(); // Override global settings per-request $item = XivApi::sheet('Item') ->row(4) ->language(Language::German) ->get();
Via Dependency Injection
use XivApi\XivApi; class ItemController extends Controller { public function show(XivApi $api, int $id) { return $api->sheet('Item')->row($id)->get(); } }
Via Service Container
$api = app(XivApi::class); $item = $api->sheet('Item')->row(4)->get(); // Or using the alias $api = app('xivapi');
Laravel Data Integration
This package provides a normalizer for spatie/laravel-data to convert XIVAPI responses directly into Data DTOs.
Installation
composer require spatie/laravel-data
Usage
Register the normalizer in your Data class:
use Spatie\LaravelData\Data; use XivApi\Laravel\Normalizers\XivApiNormalizer; class ItemData extends Data { public function __construct( public int $rowId, public array $fields, ) {} public static function normalizers(): array { return [ XivApiNormalizer::class, ]; } }
Then create Data objects directly from XIVAPI responses:
use XivApi\Laravel\Facades\XivApi; $response = XivApi::sheet('Item')->row(4)->get(); $item = ItemData::from($response);
Global Configuration
To use the normalizer globally for all Data classes, add it to your config/data.php:
// config/data.php return [ 'normalizers' => [ \XivApi\Laravel\Normalizers\XivApiNormalizer::class, \Spatie\LaravelData\Normalizers\ModelNormalizer::class, \Spatie\LaravelData\Normalizers\ArrayableNormalizer::class, \Spatie\LaravelData\Normalizers\ObjectNormalizer::class, \Spatie\LaravelData\Normalizers\ArrayNormalizer::class, \Spatie\LaravelData\Normalizers\JsonNormalizer::class, ], ];
License
MIT