bytefederal / byteauth-laravel
Byte Federal's fast authentication system built on bitcoin cryptographic standards for Laravel applications.
Installs: 40
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 0
Forks: 0
Open Issues: 0
Language:Blade
Requires
- php: ^7.3|^8.0
- laravel/framework: ^8.0 || ^9.0 || ^10.0 || ^11.0
- livewire/livewire: ^2.12 || ^3.0
- simplesoftwareio/simple-qrcode: ^4.0
This package is auto-updated.
Last update: 2024-12-06 14:26:17 UTC
README
ByteAuth-Laravel
Description
ByteAuth-Laravel is a plug and play Laravel package that integrates Byte Federal's fast authentication system into your Laravel application, leveraging bitcoin cryptographic (ECDSA/SHA256) standards. This advanced package not only offers a seamless way to onboard users and enable secure sign-in functionalities, akin to the Webauthn standard, but it also introduces several groundbreaking features:
- It ensures that cryptographic keys are backed up for added security,
- Operates independently of the user's operating system and instead uses a smart-phone as universal access key,
- Incorporates a user identity check to thwart fraudulent users including a liveness check to verify the presence of real human beings during authentication.
- Additionally, it furnishes users with a wallet that supports lightning and bitcoin transactions, enhancing the overall user experience (LNUrl, micropayments, etc).
By integrating ByteAuth-Laravel, you can easily implement a state-of-the-art, comprehensive authentication system in your Laravel projects, harnessing the robustness and security of bitcoin's cryptographic infrastructure.
Learn more about ByteAut / Fast Login.
Features
- Fast Authentication: Utilize Byte Federal's rapid authentication process to enhance user experience.
- Bitcoin Cryptographic Standards: Benefit from the high security of bitcoin cryptographic practices.
- Easy Integration: Seamlessly integrate with Laravel applications, providing a Livewire component for both front-end and back-end operations.
- Sample Login Page: Get started quickly with a sample login landing page tailored for Laravel applications.
- Webhook Support: Includes a
WebhookController
for handling authentication callbacks.
Installation
This package requires simplesoftwareio/simple-qrcode
. If it's not already installed, you can install it by running:
composer require simplesoftwareio/simple-qrcode
To install ByteAuth-Laravel, run the following command in your Laravel project:
composer require bytefederal/byteauth-laravel
After installing the byteauth-laravel package, you may publish the QR Code's configuration file using:
php artisan vendor:publish --provider="SimpleSoftwareIO\QrCode\QrCodeServiceProvider"
Configuration
After installation, publish the package's configuration file by running:
php artisan vendor:publish --provider="ByteFederal\\ByteAuthLaravel\\ByteAuthServiceProvider"
This will publish the ByteAuth-Laravel configuration file to your project's config directory. Edit this file as needed to match your application's requirements.
Additionally, to customize the domain used by the QR code generation process:
Publish the Configuration:
php artisan vendor:publish --tag=byteauth-config
This command publishes the ByteAuth-Laravel configuration file to your Laravel project's config directory.
Edit the Configuration File:
Open the published config/byteauth.php in your project and set the domain value to your website's domain, your api key and your website's dashboard path for the redirect after successful login.
return [ 'domain' => env('BYTEAUTH_DOMAIN_REGISTERED', 'my.example.com'), 'api_key' => env('BYTEAUTH_API_KEY', 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'), 'home' => env("BYTEAUTH_HOME_REDIRECT", "/home"), ];
Make sure to register your domain in the API section on ByteFederal.
Utilize Configuration in Your Component:
Update your Livewire component or other parts of your application to use this configuration value when generating QR codes or making related API calls.
php artisan vendor:publish --tag=byteauth-views
This setup enables your application to use and potentially customize the included sample login page.
Make sure to add the following three routes to your routes/api.php
file:
use ByteFederal\ByteAuthLaravel\Controllers\WebhookController; ... //backend webhook endpoints Route::post('/webhook/registration', [WebhookController::class, 'handleRegistration']); Route::post('/webhook/login', [WebhookController::class, 'handleLogin']);
While the above routes do not require session information and will be called from the relay server, the following endpoints DO need session information and should thus be set up in your routes/web.php
file:
use ByteFederal\ByteAuthLaravel\Controllers\WebhookController; ... //frontend session handling endpoints Route::get('/api/check', [WebhookController::class, 'check']); Route::get('/api/bwauth', [WebhookController::class, 'bwauth']); //sample login page Route::get('/byte', [WebhookController::class, 'sample']);
or guest Route section. Make sure CORS rules allow the WebhookController to receive incoming posts.
Troubleshooting
You may have to install imagick
to enable the QR code generation on your server. Look out for messages like this:
[previous exception] [object] (BaconQrCode\\Exception\\RuntimeException(code: 0): You need to install the imagick extension to use this back end at /var/www/laravel/vendor/bacon/bacon-qr-code/src/Renderer/Image/ImagickImageBackEnd.php:64)
Simply install imagick and add its php module:
sudo apt-get install php8.2-imagick sudo phpenmod imagick sudo systemctl restart apache2
Usage
To use ByteAuth-Laravel in your application, follow these steps:
- Route Setup: Import the package routes in your routes/api.php file.
- Use the sample landing page at a route of your convenience. It will offer your users a way to log into your site or register using ByteWallet
- To register your domain for free for this service go to wallet.bytefederal.com/web/login and register your domain, webhook url and API key.
- Enjoy a biometrically secured passwordless authentication system
Refer to the documentation for detailed usage instructions.
Happy coding!
Contributing
Contributions to ByteAuth-Laravel are welcome.
License ByteAuth-Laravel is open-sourced software licensed under the MIT license.