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.
Install luminova via Composer.
composer create-project luminovang/luminova my-project
To start the PHP
development server, run the following NovaKit
command.
php novakit server
To generate your website sitemap use the below NovaKit
command.
php novakit generate:sitemap
To learn more about NovaKit commands read the novakit documentation.
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');
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
Twig
orSmarty
template 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
NovaKit
command. - 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.
Q: My session works on the development server but not on the production server.
- A: In production, update the
$sessionDomain
in/app/Config/Session.php
to your actual production domain. A quick fix is to use'.' . APP_HOST
. Also, don't forget to update theCookie.php
configuration accordingly.
Q: My CSS and images are broken on the production server.
- A: Make sure you set the
app.environment.mood
key toproduction
in your environment file when deploying to production. This small step ensures your assets are served correctly.
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.