nawasara / core
Core package for Nawasara: authentication via Laravel Fortify, role/permission via Spatie, branding settings, and shared helpers.
Requires
- php: ^8.1
- illuminate/support: ^10.0|^12.0
- laravel/fortify: ^1.0
- laravel/socialite: ^5.0
- livewire/livewire: ^3.0
- nawasara/ui: *
- nawasara/vault: *
- socialiteproviders/keycloak: ^5.0
- spatie/laravel-permission: ^6.0
Requires (Dev)
- pestphp/pest: ^2.0
This package is auto-updated.
Last update: 2026-05-12 15:27:57 UTC
README
The core package of the Nawasara superapp framework. Provides authentication, role-based access control, branding configuration, and a RespectsActiveRole trait that scopes permission checks to the user's currently active role.
Features
- Authentication via Laravel Fortify — login, password reset, two-factor, and email verification, configurable through
nawasara.use_fortify - Role & permission via Spatie — auto-publishes the Spatie permission migration and registers seeders
- Active role enforcement — when a multi-role user "switches" to a specific role from the topbar, all permission checks are scoped to that single role's grants instead of the union of every role they hold
- Branding settings — application name, subtitle, logo (light & dark), and favicon, manageable from
/admin/branding - User & role management UI — Livewire pages for managing users and roles
- Helpers — small global helpers in
src/Helpers/functions.php
Installation
composer require nawasara/core php artisan vendor:publish --provider="Spatie\Permission\PermissionServiceProvider" php artisan migrate php artisan db:seed --class="Nawasara\Core\Database\Seeders\PermissionSeeder" --force
RespectsActiveRole — applying the trait
Apply the trait on top of Spatie's HasRoles in your App\Models\User:
use Nawasara\Core\Traits\RespectsActiveRole; use Spatie\Permission\Traits\HasRoles; class User extends Authenticatable { use HasRoles, RespectsActiveRole { RespectsActiveRole::hasPermissionTo insteadof HasRoles; } }
After this, calling $user->switchRole('operator') (or setting session('active_role', 'operator')) limits all subsequent permission checks to the operator role's permissions for the rest of the session. Direct user-grant permissions still apply.
Pages
| Route | Permission |
|---|---|
/nawasara-core/users |
core.user.view |
/nawasara-core/roles |
core.role.view |
/nawasara-core/branding |
core.branding.manage |
/nawasara-core/settings/auth |
core.auth.manage |
/nawasara-core/settings/email-link |
core.email-link.manage |
Author
Pringgo J. Saputro <odyinggo@gmail.com>
License
MIT