luminovang / luminova
Luminova is a fast, modular PHP framework designed for simplicity, performance, and modern web application development.
Installs: 49
Dependents: 0
Suggesters: 1
Security: 0
Stars: 6
Watchers: 1
Forks: 0
Open Issues: 2
Type:project
pkg:composer/luminovang/luminova
Requires
- php: ^8.0
- ext-json: *
- ext-mbstring: *
- luminovang/framework: ^3.0
- psr/http-client: ^1.0
- psr/log: ^1.1
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.64
- nikic/php-parser: ^4.17.1
- phpstan/extension-installer: ^1.3
- phpstan/phpstan: ^1.10.2
- phpunit/phpunit: ^9.1
- psr/cache: ^3.0
- psr/http-client: ^1.0
- psr/simple-cache: ^3.0
- rector/rector: 0.18.3
Suggests
- ext-curl: Required if using the CURLRequest class.
- ext-exif: Required for image handling with the Image class.
- ext-fileinfo: Improves MIME type detection for file uploads.
- ext-gd: Required for image manipulation using GDHandler.
- ext-imagick: Required for image manipulation using ImageMagickHandler.
- ext-intl: Required for locale and internationalization features.
- ext-memcached: Required if using Memcached with the MemcachedHandler.
- ext-mysqli: Required for MySQL database support.
- endroid/qr-code: Generates inline Base64 or SVG QRcodes when using TOTP class.
- guzzlehttp/guzzle: Required for using Guzzle as an HTTP client.
- league/flysystem: Required for using cloud storage drivers via Flysystem.
- luminovang/array-functions: Backports PHP 8.4 array_* functions for older versions.
- nanoblocktech/psr-cache: Enables support for PSR-6 and PSR-16 caching.
- opis/closure: Required for storing closures in the BackgroundTaskQueue system.
- peterujah/nano-image: Required for image resizing when using the FileDelivery::outputImage() method.
- peterujah/php-search-controller: Provides support for model search with BaseModel::doSearch().
- phpmailer/phpmailer: Required for sending emails using PHPMailer.
- psr/http-client: Required when using HTTP clients like Guzzle or cURL.
- psr/log: Needed for applications using PSR-compatible logging.
- smarty/smarty: Required to enable Smarty as a template engine.
- swiftmailer/swiftmailer: Required for sending emails using SwiftMailer.
- twig/twig: Required to enable Twig as a template engine.
- dev-main
- 2.3.5
- 2.3.4
- 2.3.3
- 2.3.2
- 2.3.1
- 2.3.0
- 2.2.9
- 2.2.8
- 2.2.7
- 2.2.6
- 2.2.5
- 2.2.4
- 2.2.3
- 2.2.2
- 2.2.1
- 2.2.0
- 2.1.9
- 2.1.8
- 2.1.7
- 2.1.6
- 2.1.5
- 2.1.4
- 2.1.3
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.9
- 2.0.8
- 2.0.7
- 2.0.6
- 2.0.5
- 2.0.4
- 2.0.3
- 2.0.2
- 2.0.1
- 2.0.0
- 1.9.9
- 1.9.8
- 1.9.7
- 1.9.6
- 1.9.5
- 1.9.4
- 1.9.3
- 1.9.2
- 1.9.1
- 1.9.0
- 1.8.0
- 1.7.0
- 1.6.0
- 1.5.0
- 1.4.0
- 1.3.0
- 1.2.0
- 1.1.0
- 1.0.0
This package is auto-updated.
Last update: 2025-10-05 11:40:06 UTC
README
About Luminova!
Luminova is a PHP framework built for speed and efficiency, designed to enhance your existing coding skills. At Luminova, we prioritize performance by offering feature customization through the env file. This ensures the framework includes only what's needed for your project, based on the features you enable. This approach allows you to enable or disable features as well as customizing your preferred template rendering mode and coding style.
Luminova, provide access to the template View object within the view files, allowing you to call template methods and properties using $this keyword within template files. This can be disabled if you prefer your views to be rendered in isolation, disabling it will allow you to access exported application classes using custom keyword $self.
Ready to light up your projects? Dive into our official documentation. For more tips, tricks, and some coding fun, check out our YouTube channel.
Composer Installation
Install luminova via Composer.
composer create-project luminovang/luminova my-project
Start Development Server
To start the PHP development server, run the following NovaKit command.
php novakit server
Sitemap Generator
To generate your website sitemap use the below NovaKit command.
php novakit generate:sitemap
To learn more about NovaKit commands read the novakit documentation.
Routing
Luminova support flexible routing implementation using Attributes or Router methods.
Define your route using PHP8 attributes:
#[Route('/', methods: ['GET'])] public function index(): int { return $this->view('index'); }
Or define your route using code-based routing:
<?php $router->get('/', 'YourController::index');
What's There For Me?
Here we can brief you on the basic features you can expect in Luminova. There's a lot more than what is written here. As Linus Torvalds said, "Talk is cheap. Show me the code."
- Database Builder: A powerful Object Relational Mapping (ORM) tool that organizes CRUD operations and simplifies database interactions.
- MVC & HMVC Architecture: Adheres to the Model-View-Controller and Hierarchical Model-View-Controller implementation.
- Flexible HTTP Routing: Dynamic and fast routing implementation with a clear separation of concerns.
- Templating: Optimized native PHP templating with additional inheritance and caching features. You can also use TwigorSmartytemplate engines.
- Error Handling: Comprehensive error handling ensures that no errors go unnoticed, including non-fatal inline errors.
- Session Management: Easily manage user login sessions without additional implementation.
- CLI Routing: Dynamic routing for CLI implementations similar to HTTP routing methods.
- Cloud Storage: Supports various cloud storage solutions like AWS, Azure, Google Cloud, and more.
- File Management: Deliver files to the browser from any location with temporary or permanent URLs to access private files.
- Sitemap Generator: Generate website sitemaps using the NovaKitcommand.
- Schema Object: Support for generating schema objects for website pages.
- Command Line Tool: Full support for implementing CLI tools, with everything you need available.
- AI Models: Integrate or extend AI features into your application.
- Database: A flexible database system that supports instant failover to a backup database without user interruption.
- Security: Various security implementations to secure your application and user information.
- Request Handling: Secure handling of incoming and outgoing HTTP requests.
- Email: Send emails anywhere, with support for sending entire view content as the email body.
- Translation: Create translations for your application using our translation class.
- Encryption: Support for different encryption handlers and methods.
- Services: Define classes that can be shared and discovered anywhere in your codebase, with support for serialization and class object caching.
Quick Tips
Q: My session works on the development server but not on the production server.
- A: In production, update the $sessionDomainin/app/Config/Session.phpto your actual production domain. A quick fix is to use'.' . APP_HOST. Also, don't forget to update theCookie.phpconfiguration accordingly.
Q: My CSS and images are broken on the production server.
- A: Make sure you set the app.environment.moodkey toproductionin your environment file when deploying to production. This small step ensures your assets are served correctly.
Something Missing?
Your feedback is highly appreciated! Drop us a line at peter@luminova.ng. Let us know what we can add to enhance your experience with Luminova. You can also recommend tutorials for our YouTube channel to help you understand and use Luminova better.
Most importantly, don't forget to rate Luminova on GitHub. Your rating is like fuel, helping to illuminate our motivation to add more features and make Luminova even better known and more powerful.