rotexsoft / slim3-skeleton-mvc-app
This is a template mvc web-application (powered by SlimPHP 4), that can be extended to build more complex web applications.
Installs: 466
Dependents: 0
Suggesters: 0
Security: 0
Stars: 39
Watchers: 3
Forks: 8
Open Issues: 5
Type:project
pkg:composer/rotexsoft/slim3-skeleton-mvc-app
Requires
- php: >=8.2.0
- rotexsoft/slim-skeleton-mvc-tools: ^6.0
Requires (Dev)
- guzzlehttp/guzzle: ^7.8
- phpunit/phpunit: ^11.0
- rector/rector: ^2.0
Suggests
- rotexsoft/leanorm: An efficient light-weight ORM for database access. See http://rotexsoft.github.io/leanorm/
- rotexsoft/versatile-acl: A simple, highly flexible and customizable access control package for PHP applications. See https://github.com/rotexsoft/versatile-acl
- rotexsoft/versatile-collections: A collections package for various use cases (supports strict typing). See https://github.com/rotexsoft/versatile-collections
- dev-master
- 6.1.5
- 6.1.4
- 6.1.3
- 6.1.2
- 6.1.1
- 6.1.0
- 6.0.0
- 5.0.8
- 5.0.7
- 5.0.6
- 5.0.5
- 5.0.4
- 5.0.3
- 5.0.2
- 5.0.1
- 5.0.0
- 4.0.1
- 4.0.0
- 3.0.4
- 3.0.3
- 3.0.2
- 3.0.1
- 3.0.0
- 2.1.1
- 2.1.0
- 2.0.2
- 2.0.1
- 2.0.0
- 1.x-dev
- 1.0.15
- 1.0.14
- 1.0.13
- 1.0.12
- 1.0.11
- 1.0.10
- 1.0.9
- 1.0.8
- 1.0.7
- 1.0.6
- 1.0.5
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- dev-slim-4-edition-versions-4.x
- dev-slim-4-edition-versions-5.x
- dev-project-website
- dev-slim-3-edition
This package is auto-updated.
Last update: 2025-10-25 14:21:02 UTC
README
The documentation for the version of this framework based on SlimPHP 3 can be found here.
This is a template web-application (powered by SlimPHP 4), that can be extended to build more complex web applications.
While it is not necessary to have expert understanding of the SlimPHP 4 framework (https://www.slimframework.com/docs/v4/) in order to build web-applications with this template application framework, such understanding would help in maximizing the capabilities of this template application framework.
Features / Benefits of using the Slim MVC Framework
- 
It adds the Model-View-Controller structure to your web-application. Actually, really more of Controller-View functionality with a model folder provided for housing your Model classes (leaving you with the responsibility of choosing whichever ORM / Database Access Library suits your needs or are most comfortable with) 
- 
Provides a skeleton folder / directory structure for your application: 
./path/to/newly/created/app
|-- config/
    |-- languages/
|       |-- en_US.php
|       `-- fr_CA.php
|   |-- app-settings.php
|   |-- app-settings-dist.php
|   |-- dependencies.php
|   |-- env.php
|   |-- env-dist.php
|   |-- ini-settings.php
|   `-- routes-and-middlewares.php
|
|-- logs/
|
|-- public/
|   |-- css/
|   |-- images/
|   |-- js/
|   `-- index.php
|
|-- src/
|   |-- controllers/
|   |-- layout-templates/
|   |-- models/
|   |-- views/
|   |-- AppEnvironments.php
|   |-- AppErrorHandler.php
|   |-- AppSettingsKeys.php
|   `-- ContainerKeys.php
|
|-- tests/
|
|-- tmp/
|
|-- vendor/
|
|-- .gitignore
|-- composer.json
|-- composer.lock
`-- README.md
- 
Provides some helper functions like sMVC_UriToString(\Psr\Http\Message\UriInterface $uri), sMVC_addQueryStrParamToUri(\Psr\Http\Message\UriInterface $uri, $param_name, $param_value), etc. in the default global namespace and a few string helper functions in the SlimMvcTools\Functions\Strnamespace
- 
Provides an automatic routing scheme for mapping request urls to methods in Controller classes that are sub-classes of SlimMvcTools\Controllers\BaseController. You don't need to define any routes for your application if you adhere to using Controllers that are compatible with the routing scheme- Also supports operating using only pure Slim PHP functionality (i.e. you can manually / explicitly define all or some of the routes (each of which may or may not make use of Controller classes as route handlers) and middle-wares for your application. You can also disable the automatic routing scheme described above if you plan to manually define all your routes. Manually / explicitly defined routes will override automatic routes with the same path definition)
 
- 
Ships whith a BaseController class (i.e. SlimMvcTools\Controllers\BaseController) that provides methods for authentication (login, logout & checking authentication status), listing all methods in all controller classes in an application that can be automatically routed to if the automatic MVC routing is enabled, forcing HTTP 400, 401, 403, 404, 405, 410, 500 & 501 responses and methods for rendering php view and layout files using the light-weight and easily extensible Rotexsoft\FileRenderer\Renderer class. Take a look at the class for a full list of methods that can be used in your applications.
- 
Provides a command-line script for creating Controller classes (that extend SlimMvcTools\Controllers\BaseControlleror any of its descendants).- ./vendor/bin/smvc-create-controlleron- *nix-likeOses and- .\vendor\bin\smvc-create-controller.baton- Windows- NOTE: ./vendor/bin/smvc-create-controller-wizardis the interactive version of./vendor/bin/smvc-create-controller
 
- NOTE: 
 
- 
Ships with a very minimal amount of composer / packagist dependencies (all of which are used by SlimMvcTools\Controllers\BaseController) in order to allow you to include only additional dependencies that suit the specific needs of your application. Thereby reducing the possibility of having unused / unneeded dependencies in your application. The following packages are used in this framework:- Slim Framework Version 4: for routing http requests to action methods in Controller classes (or other callables acceptable by Slim for responding to requests that match defined routes) and sending back http responses to clients
- File Renderer: for rendering php layout and view files (which basically contain a mix of php, html, css & Javascript) which will be sent back as html in http response bodies to clients. Plain Text, Json, Xml & other non-html responses can be emitted directly from Controller Action methods (they don't need this renderer)
- Vespula Auth: a lightweight authentication package that is used by the default login & logout actions in the BaseController to authenticate users. An in-memory sqlite db is used for authentication by default, you should switch to a proper relational db like Mysql (which this package can also autheticate against)
- Vespula Locale: another light-weight package for managing localized strings in this framework. Things like error messages during login are managed using an instance of this package to display those messages in the desired language selected by the user. US English & Canadian French are the two languages this framework supports out of the box. Other locale files can be added to the ./config/languages folder and their locale code(s) should be added to the container ($container[ContainerKeys::VALID_LOCALES]) and a link for that language should be added to the layout template with the appropriate query string so that users that click on it can set that language as their desired language when interacting with an application built with this framework
- Vespula Log: a PSR-3 Logger that is used throughout this framework for logging various events (like successful login & logout events, etc.). It's lighter than other packages like Monolog and pretty decent.
- Pimple: a simple Dependency Injection Container that is used to power \SlimMvcTools\Container (the PSR-11 compliant container that ships with this framework)
- Nyholm PSR7: A fast PHP7 implementation of PSR-7 injected into SlimPHP by this framework
- Nyholm PSR7 Server: Helper classes to handle PSR-7 server requests, also used by SlimPHP within this framework
 You should also look at the public methods available in \SlimMvcTools\Controllers\BaseController which all your applications' controller classes will be extending & which will come in handy in your applications like the forceHttp###, getResponseObjForLoginRedirectionIfNotLoggedIn, isLoggedIn, makeLink, renderLayout & renderView methods 
- 
Strives to adhere strictly to the PSR-7 HTTP messages and psr/container interfaces, in order to make it easy to use different implementations of the PSR-7 request and response objects and psr/container compliant containers 
Requirements
- PHP 7.2+ (for version 3.X) or PHP 7.4+ (for version 4.X) or PHP 8.1+ (for version 5.x) or PHP 8.2+ (for vewrsion 6.x)
- Pdo sqlite (3) extension for Authentication in non-production environments
- Composer (https://getcomposer.org)
Documentation
- Quick Start Guide
- MVC Functionality
- Real World Usage: Creating a Movie Catalog application
- All command-line examples assume you have changed directory to the root folder of your newly created application.
- Please submit an issue or a pull request if you find any issues with the documentation.
Branching
These are the branches in this repository:
- master: contains code for the latest major version of this framework (currently 6.x)
Before starting development on the next major version, create a slim-#-edition-versions-y.x branch of the master branch (where y is the current latest version's first digit and # is the first digit of the slim framework version the current latest version was built for) and then you can start coding for the next major version on the master branch 
- slim-4-edition-versions-5.x: contains code for the 5.x version of this package
- slim-4-edition-versions-4.x: contains code for the 4.x version of this package. No new features, only bug fixes accepted.
- slim-3-edition: contains code for the 3.x version of this package. No new features, only bug fixes accepted.
- 1.X: contains code for the 1.x version of this package. Abandoned.
- project-website: contains code for the documetation website for this project (https://rotexsoft.github.io/slim-skeleton-mvc-app/).
- THE project-website BRANCH WAS CREATED IN MAY 2024 AND IS CURRENTLY BEING DEVELOPED. WILL REMOVE THIS NOTICE WHEN THE DOCUMENTATION WEBSITE IS READY TO GO. FOR NOW KEEP READING THE DOCUMENTATION IN THE BRANCH FOR THE VERSION OF THIS FRAMEWORK YOU ARE CURRENTLY USING.
 
Issues
- Please submit an issue or a pull request if you find any problems with this skeleton app.
- If you are suggesting an enhancement please create an issue first so that it can be deliberated upon, before going on to submit a pull request.