Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ikoene/symfony-micro
Use Symfony as a microframework.
https://github.com/ikoene/symfony-micro
micro-framework microkernel symfony symfony-micro
Last synced: about 1 month ago
JSON representation
Use Symfony as a microframework.
- Host: GitHub
- URL: https://github.com/ikoene/symfony-micro
- Owner: ikoene
- License: mit
- Created: 2015-12-07T21:20:17.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2017-12-21T19:16:40.000Z (about 7 years ago)
- Last Synced: 2024-12-13T07:45:15.240Z (about 1 month ago)
- Topics: micro-framework, microkernel, symfony, symfony-micro
- Language: PHP
- Size: 45.9 KB
- Stars: 35
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
[![Build Status](https://travis-ci.org/ikoene/symfony-micro.svg?branch=master)](https://travis-ci.org/ikoene/symfony-micro)
[![Scrutinizer Code Quality](https://scrutinizer-ci.com/g/ikoene/symfony-micro/badges/quality-score.png?b=master)](https://scrutinizer-ci.com/g/ikoene/symfony-micro/?branch=master)
[![SensioLabs Insight](https://img.shields.io/sensiolabs/i/7a556c44-8128-49e0-ac7e-d6f601d7fec7.svg)](https://insight.sensiolabs.com/projects/7a556c44-8128-49e0-ac7e-d6f601d7fec7)
[![Packagist](https://img.shields.io/packagist/v/ikoene/symfony-micro.svg)](https://packagist.org/packages/ikoene/symfony-micro)
[![Installs](https://img.shields.io/packagist/dt/ikoene/symfony-micro.svg)](https://packagist.org/packages/ikoene/symfony-micro)
[![license](https://img.shields.io/github/license/ikoene/symfony-micro.svg)](https://github.com/ikoene/symfony-micro/blob/master/LICENSE.md)# Symfony micro-framework
Use Symfony as a microframework.
## Installation
Create a new project with [Composer](https://getcomposer.org/).
```bash
composer create-project ikoene/symfony-micro
```## MicroKernelTrait
The **MicroKernelTrait** allows you to create a fully-functional Symfony application in as little as one file. It allows you to start with a tiny application, and then add features and structure as you need to. Its goal to give you the power to choose your bundles and structure. Since you're only enabling features and bundles you're actually going to use, your application gets a performance boost in comparison with using the Symfony full-stack framework.
## Bundles
These bundles are registered in the MicroKernel:
* [FrameworkBundle](https://github.com/]symfony/framework-bundle)
* [SensioFrameworkExtraBundle](https://github.com/sensiolabs/SensioFrameworkExtraBundle)
* [TwigBundle](https://github.com/symfony/twig-bundle)While you could argue what exactly should and should not be included in a microframework, I found myself always using these bundles. So they're enabled by default. Don't want to use Twig as your template engine? Remove it in the MicroKernel.
When working in a *dev* or *test* environment, the **MicroKernel** also registers the necesarry bundles to be able to debug your project:
* [WebProfilerBundle](https://github.com/symfony/web-profiler-bundle)
* [DebugBundle](https://github.com/symfony/debug-bundle)## Usage
### Development
Build your application in the AppBundle. You're free to structure your application as you want, but following the typical Symfony bundle structure has it's advantages. For one, it would be easier to migrate to a full-stack Symfony project if your application grows too big.
But, as I said, the choice is yours.
### Register bundles
Missing some features? Register your bundles in the MicroKernel:
```php
...
$bundles = array(
new Symfony\Bundle\FrameworkBundle\FrameworkBundle(),
new Symfony\Bundle\TwigBundle\TwigBundle(),
new Sensio\Bundle\FrameworkExtraBundle\SensioFrameworkExtraBundle(),
new AppBundle\AppBundle(),
);
...
```### Console
While this is a microframework, chances are you'll still need the console. Use it like this:
```bash
./console
```### PHPUnit Testing
Run all tests with this command:
```bash
bin/phpunit -c .
```# Additional info
[Building your own Framework with the MicroKernelTrait](https://symfony.com/doc/2.8/cookbook/configuration/micro-kernel-trait.html)