Note: Groundwork is still in its alpha state and will undergo heavy changes before a more stable release structure is implemented.
This is the core library for the Groundwork project. See the default Groundwork project for more information.
The framework uses various external packages such as, but not limited to:
- Twig for rendering templates.
- Symfony for HTTP request / response processing.
- Carbon for date / time.
- Altorouter for routes.
- TailwindCSS for styling. You'll have to install it with npm. (see package.json in the default project)
To install, run composer require thijmendf/groundwork
In order to start the framework, send all http requests (except for requests for files such as assets) to a single php file inside a public
folder. In there, simply require the following bootstrap code from your project root:
// File location: ./public/index.php
require "../bootstrap.php";
In that bootstrap file, you can use this code to start the framework:
// File location: ./bootstrap.php
ini_set('display_errors', 'off');
error_reporting(E_ALL);
// Require the auto-loader
require __DIR__ . '../vendor/autoload.php';
use Groundwork\Server;
// Start the handle server
$server = Server::getInstance(__DIR__);
// Handle the request
$server->handle();
And that's it. It'll automatically handle the requests and responses.
A project that implements this framework needs the following file structure:
+ project
|---+ App <- This is where the main source code of your project will go to
| |---+ Models <- Database models
| |
| |---+ Controllers <- View controllers
| |
| |---+ Extensions <- Extending Groundwork
| |
| |---+ Requests <- Validating form requests
| |
| |---+ Middleware <- Middleware defined in the routes
|
|---+ cache <- Caching various systems such as the templates
|
|---+ database
| |---+ migrations <- Migrations that are run once. Doesn't have to be database related
| |
| |---+ seeders <- Seeders for the database
|
|---+ public
| |---+ assets <- Place for css, js, images, fonts etc.
| |
| |---- index.php <- All requests must go here. See code above
|
|---+ resources <- Root for uncompiled assets (views, css, js etc.)
| |
| |---+ views <- Root for templates
|
|---+ routes <- Here all routers can be added.
| File names don't matter, as long as they're php files.
|---- .env <- Configuration file. see .env.example
|
|---- bootstrap.php <- Main starting point for the framework.
You can also extend certain features by making a class in the /App/Extensions
namespace. Extensions must implement the Groundwork/Extensions/Extension
interface.
The following components can be extended:
-
App/Extensions/Renderer
For adding twig functions, filters etc. -
App/Extensions/Config
For verifying .env configuration. New items can be verified by usingConfig::required()
orConfig::optional()
. -
App/Extensions/Bootstrap
For starting the framework and registering any container instances. New instances can be passed by using:$container->register('identifier', new TargetClass());
or- As
$container->register('identifier', 'App/Namespaces/TargetClass');
(orTargetClass::class
).
Class paths mean the target class will only be instanced whenever it's requested (lazy loading).
-
More coming soon.
See Contributing on how to contribute to the project.