cidekar/laravel-tenantmagic

A multitenancy package for Laravel Passport.

v1.0.1 2022-05-26 19:00 UTC

This package is auto-updated.

Last update: 2024-04-26 23:07:43 UTC


README

93266709-776d2800-f778-11ea-91a3-a48651b89882.png

Introduction

Laravel Passport makes password grant client authentication dead-simple for your API. Laravel Multitenancy makes a Laravel application tenant aware in minutes - feels like cheating. Tenantmagic, provides one approach to a making your Passport password grant client tenant aware. Before going through the rest of this documentation, take time to read Laravel Multitenancy and Laravel Passport, if your unfamiliar. Tenantmagic is built on top of Laravel Passport and Laravel Multitenancy.

Motivation

Multitenancy typically requires a user provide their authentication credentials and subdomain to get a token. Tenantmagic removes the need for a subdomain when logging into your multi-tenant application; provide a user name and password and the package will do the rest!

Installation

This package can be installed with Composer:

$ composer require "cidekar/tenantmagic:^1.0"

Publish the configuration:

php artisan vendor:publish --provider="Cidekar\Tenantmagic\TenantmagicServiceProvider" --tag="config"

The configuration will be published to config/tenantmagic.php

The User model must use UsesPassportModelMagic:

    use Cidekar\Tenantmagic\Models\Concerns\UsesPassportModelMagic;

    class User extends Authenticatable
    {
        use UsesPassportModelMagic;
        ...

Please keep in mind this package assumes the grant client is stored in the landlord database. Users are stored in the tenant database.

Add the TenantmagicDomainTenantFinder to the multitenancy config:

    return [
        /*
        * This class is responsible for determining which tenant should be current
        * for the given request.
        *
        * This class should extend `Spatie\Multitenancy\TenantFinder\TenantFinder`
        *
        */
        'tenant_finder' => TenantmagicDomainTenantFinder::class,

        ...

Add the TenantmagicPassportTask to the switch_tenant_tasks array:

    return [
        /*
        * These tasks will be performed when switching tenants.
        *
        * A valid task is any class that implements Spatie\Multitenancy\Tasks\SwitchTenantTask
        */
        'switch_tenant_tasks' => [
            SwitchTenantDatabaseTask::class,
            TenantmagicPassportTask::class
        ],

        ...

Configure your tenant and landlord database connections:

    return [
        /*
        * The connection name to reach the tenant database.
        *
        * Set to `null` to use the default connection.
        */
        'tenant_database_connection_name' => 'tenant',

        /*
        * The connection name to reach the landlord database
        */
        'landlord_database_connection_name' => 'landlord',

        ...

X-Magictenant Header

Out of the box, Tenantmagic will return the x-magictenant header when responding to a successful authorization request. To reveal the domain and tenant name, the x-magictenant header value (i.e., non-extended notation, using "quoted-string") needs to be decoded:

    $response = $this->post($route);

    json_decode($response->headers->get('x-magictenant'));

    array:2 [
    0 => {
        "domain": "foo.com"
        "name": "Foo Dot Com"
    }
    1 => {
        "domain": "bar.net"
        "name": "Bar Dot Net"
    }];

Requirements

Testing

To get started, create the following MySql databases:

  • laravel_tenantmagic_landlord
  • laravel_tenantmagic_tenant_1
  • laravel_tenantmagic_tenant_2

Now, you may run the package's tests:

   $ composer test

    # Runtime:       PHP 7.4.0
    # Configuration: /var/www/packages/cidekar/laravel-tenantmagic/phpunit.xml
    # Warning:       Your XML configuration validates against a deprecated schema.
    # Suggestion:    Migrate your XML configuration using "--migrate-configuration"!
    # ...

Security

Please do not publicly disclose security-related issues, email packages@cidekar.com. Security vulnerabilities will be promptly addressed.

License

Copyright 2020 Cidekar, LLC. All rights reserved.

Apache License 2.0