Chamilo is a learning management system focused on ease of use and accessibility
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
chamilo-lms/vendor/symfony/http-kernel/Symfony/Component/HttpKernel
Julio Montoya f319aaa06f Updating vendors 13 years ago
..
Bundle Adding web profiler provider 13 years ago
CacheClearer Updating vendor 13 years ago
CacheWarmer Updating vendor 13 years ago
Config Updating vendor 13 years ago
Controller Adding web profiler provider 13 years ago
DataCollector Updatinv vendors 13 years ago
Debug Updatinv vendors 13 years ago
DependencyInjection Adding web profiler provider 13 years ago
Event Adding web profiler provider 13 years ago
EventListener Adding web profiler provider 13 years ago
Exception Adding web profiler provider 13 years ago
Fragment Updatinv vendors 13 years ago
HttpCache Updatinv vendors 13 years ago
Log Adding web profiler provider 13 years ago
Profiler Updatinv vendors 13 years ago
Tests Updatinv vendors 13 years ago
CHANGELOG.md Adding web profiler provider 13 years ago
Client.php Adding web profiler provider 13 years ago
HttpKernel.php Adding web profiler provider 13 years ago
HttpKernelInterface.php Updating vendor 13 years ago
Kernel.php Updatinv vendors 13 years ago
KernelEvents.php Updating vendor 13 years ago
KernelInterface.php Adding web profiler provider 13 years ago
LICENSE Updating vendor 13 years ago
README.md Adding web profiler provider 13 years ago
TerminableInterface.php Updating vendor 13 years ago
UriSigner.php Adding web profiler provider 13 years ago
composer.json Adding web profiler provider 13 years ago
phpunit.xml.dist Adding web profiler provider 13 years ago

README.md

HttpKernel Component

HttpKernel provides the building blocks to create flexible and fast HTTP-based frameworks.

HttpKernelInterface is the core interface of the Symfony2 full-stack framework:

interface HttpKernelInterface
{
    /**
     * Handles a Request to convert it to a Response.
     *
     * @param  Request $request A Request instance
     *
     * @return Response A Response instance
     */
    function handle(Request $request, $type = self::MASTER_REQUEST, $catch = true);
}

It takes a Request as an input and should return a Response as an output. Using this interface makes your code compatible with all frameworks using the Symfony2 components. And this will give you many cool features for free.

Creating a framework based on the Symfony2 components is really easy. Here is a very simple, but fully-featured framework based on the Symfony2 components:

$routes = new RouteCollection();
$routes->add('hello', new Route('/hello', array('_controller' =>
    function (Request $request) {
        return new Response(sprintf("Hello %s", $request->get('name')));
    }
)));

$request = Request::createFromGlobals();

$context = new RequestContext();
$context->fromRequest($request);

$matcher = new UrlMatcher($routes, $context);

$dispatcher = new EventDispatcher();
$dispatcher->addSubscriber(new RouterListener($matcher));

$resolver = new ControllerResolver();

$kernel = new HttpKernel($dispatcher, $resolver);

$kernel->handle($request)->send();

This is all you need to create a flexible framework with the Symfony2 components.

Want to add an HTTP reverse proxy and benefit from HTTP caching and Edge Side Includes?

$kernel = new HttpKernel($dispatcher, $resolver);

$kernel = new HttpCache($kernel, new Store(__DIR__.'/cache'));

Want to functional test this small framework?

$client = new Client($kernel);
$crawler = $client->request('GET', '/hello/Fabien');

$this->assertEquals('Fabien', $crawler->filter('p > span')->text());

Want nice error pages instead of ugly PHP exceptions?

$dispatcher->addSubscriber(new ExceptionListener(function (Request $request) {
    $msg = 'Something went wrong! ('.$request->get('exception')->getMessage().')';

    return new Response($msg, 500);
}));

And that's why the simple looking HttpKernelInterface is so powerful. It gives you access to a lot of cool features, ready to be used out of the box, with no efforts.

Resources

You can run the unit tests with the following command:

$ cd path/to/Symfony/Component/HttpKernel/
$ composer.phar install --dev
$ phpunit