1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- <?php
- /**
- * Lithium: the most rad php framework
- *
- * @copyright Copyright 2013, Union of RAD (http://union-of-rad.org)
- * @license http://opensource.org/licenses/bsd-license.php The BSD License
- */
- /**
- * The `Collection` class, which serves as the base class for some of Lithium's data objects
- * (`RecordSet` and `Document`) provides a way to manage data collections in a very flexible and
- * intuitive way, using closures and SPL interfaces. The `to()` method allows a `Collection` (or
- * subclass) to be converted to another format, such as an array. The `Collection` class also allows
- * other classes to be connected as handlers to convert `Collection` objects to other formats.
- *
- * The following connects the `Media` class as a format handler, which allows `Collection`s to be
- * exported to any format with a handler provided by `Media`, i.e. JSON. This enables things like
- * the following:
- * {{{
- * $posts = Post::find('all');
- * return $posts->to('json');
- * }}}
- */
- use lithium\util\Collection;
- Collection::formats('lithium\net\http\Media');
- /**
- * This filter is a convenience method which allows you to automatically route requests for static
- * assets stored within active plugins. For example, given a JavaScript file `bar.js` inside the
- * `li3_foo` plugin installed in an application, requests to `http://app/path/li3_foo/js/bar.js`
- * will be routed to `/path/to/app/libraries/plugins/li3_foo/webroot/js/bar.js` on the filesystem.
- * In production, it is recommended that you disable this filter in favor of symlinking each
- * plugin's `webroot` directory into your main application's `webroot` directory, or adding routing
- * rules in your web server's configuration.
- */
- // use lithium\action\Dispatcher;
- // use lithium\action\Response;
- // use lithium\net\http\Media;
- //
- // Dispatcher::applyFilter('_callable', function($self, $params, $chain) {
- // list($library, $asset) = explode('/', $params['request']->url, 2) + array("", "");
- //
- // if ($asset && ($path = Media::webroot($library)) && file_exists($file = "{$path}/{$asset}")) {
- // return function() use ($file) {
- // $info = pathinfo($file);
- // $media = Media::type($info['extension']);
- // $content = (array) $media['content'];
- //
- // return new Response(array(
- // 'headers' => array('Content-type' => reset($content)),
- // 'body' => file_get_contents($file)
- // ));
- // };
- // }
- // return $chain->next($self, $params, $chain);
- // });
- ?>
|