luinuxscl/laravel-api-key-manager

There is no license information available for the latest version (dev-main) of this package.

Package para gestionar API Keys de servicios externos en Laravel.

dev-main 2025-03-11 23:35 UTC

This package is auto-updated.

Last update: 2025-06-12 00:09:48 UTC


README

Un package para Laravel que facilita la gestión de API Keys de servicios externos. Permite almacenar, encriptar y asociar API keys a diferentes modelos de tu aplicación mediante relaciones polimórficas.

Características

  • Almacenamiento seguro de API keys con encriptación opcional
  • Relaciones polimórficas para asociar API keys a cualquier modelo de tu aplicación
  • Comandos Artisan para la gestión de API keys
  • Facade para un acceso simplificado a las funcionalidades del package
  • Configuración personalizable

Instalación

Puedes instalar el package a través de Composer:

composer require luinuxscl/laravel-api-key-manager

Publicación de archivos

Después de instalar el package, publica los archivos de configuración y migraciones:

php artisan vendor:publish --provider="Luinuxscl\LaravelApiKeyManager\Providers\APIKeyManagerServiceProvider"

O publica solo lo que necesites:

# Solo configuración
php artisan vendor:publish --provider="Luinuxscl\LaravelApiKeyManager\Providers\APIKeyManagerServiceProvider" --tag="config"

# Solo migraciones
php artisan vendor:publish --provider="Luinuxscl\LaravelApiKeyManager\Providers\APIKeyManagerServiceProvider" --tag="migrations"

Finalmente, ejecuta las migraciones:

php artisan migrate

Configuración

El archivo de configuración config/api_keys.php te permite personalizar el comportamiento del package:

return [
    // Define si las API keys deben ser encriptadas al guardarse en la base de datos
    'encrypt' => true,
    
    // Servicio por defecto
    'default_service' => null,
];

Uso básico

Usando la Facade

use Luinuxscl\LaravelApiKeyManager\Facades\APIKeyManager;

// Generar una nueva API key
$apiKey = APIKeyManager::generate('Mi API Key', 'google-maps', 32, ['environment' => 'production']);

// Obtener el valor de la key (desencriptado si corresponde)
$keyValue = $apiKey->getDecryptedKey();

// Obtener todas las API keys para un servicio específico
$googleKeys = APIKeyManager::getByService('google-maps');

Asociar API keys a modelos

Para asociar API keys a tus modelos, utiliza el trait HasApiKeys:

use Illuminate\Database\Eloquent\Model;
use Luinuxscl\LaravelApiKeyManager\Traits\HasApiKeys;

class User extends Model
{
    use HasApiKeys;
    
    // ...
}

Ahora puedes generar y gestionar API keys asociadas a tus modelos:

$user = User::find(1);

// Generar una API key asociada al usuario
$apiKey = $user->generateApiKey('API Key de Juan', 'stripe', ['role' => 'admin']);

// Obtener todas las API keys del usuario
$allKeys = $user->apiKeys;

// Obtener las API keys del usuario para un servicio específico
$stripeKeys = $user->getApiKeysForService('stripe');

Comandos Artisan

El package incluye comandos Artisan para gestionar API keys desde la consola:

# Generar una nueva API key
php artisan api-key:generate "API Key de Producción" google-maps

# Listar todas las API keys
php artisan api-key:list

# Listar API keys para un servicio específico
php artisan api-key:list --service=google-maps

# Almacenar una API key existente
php artisan api-key:store "API Key de Producción" google-maps "<API_KEY>"

Seguridad

Las API keys se encriptan por defecto utilizando el mecanismo de encriptación de Laravel. Puedes desactivar esta característica en el archivo de configuración.

Licencia

Este package es software de código abierto licenciado bajo la licencia MIT.