lan / ice-fork
Ice Open Source PHP Framework
1.30.16
2026-03-30 08:25 UTC
Requires
- php: 7.4.* || 8.0.* || 8.3.*
- mrclay/minify: 3.0.*
- phpmailer/phpmailer: ^6
- phpoffice/phpspreadsheet: 4.1.*
- phpoffice/phpword: 1.3.*
- rybakit/msgpack: 0.8.*
- spb-lan/ice-cli-fork: 0.0.8
- spb-lan/ice-http-fork: 0.0.7
- tarantool/client: 0.9.*
- vlucas/phpdotenv: ^2.4.0 | ^5.4.1
Requires (Dev)
- ccampbell/chromephp: dev-master
- codeception/codeception: ^5.2.1
- lox/xhprof: dev-master
- squizlabs/php_codesniffer: dev-master
This package is auto-updated.
Last update: 2026-05-30 08:47:26 UTC
README
Ice is a general purpose PHP-framework. You may fully rely on Ice while developing complex web-applications. Ice key features are the built-in cache support of the main components, flexible configuration and the ability to easily extend existing functionality.
The basics
Routes
sample /config/Ice/Core/Route.php:
<?php return [ 'mp_page' => [ 'route' => '/page/{$page}', 'params' => [ 'page' => '(\d)' ], 'weight' => 10000, 'request' => [ 'GET' => [ 'Www:Layout_Main' => [ 'actions' => [ ['Ice:Title' => 'title', ['title' => 'Ice - Open Source PHP Framework ']], 'Www:Index' => 'main' ] ] ] ] ] ]
Important parts:
- 'mp_page' - Route name, (Uses: Route::getInstance('mp_page')->getUrl(20)) returned '/page/20' etc.)
- 'weight' - Priority of matched routes. Greater weight - greater priority.
- 'request' section - Array of available requuest methods (GET, POST etc.)
- 'request/GET' - Only one item (first) contained layout action class as key and params as value
Actions
namespace Mp\Action; use Ice\Core\Action; class Page extends Action { protected static function config() { return [ 'view' => ['viewRenderClass' => 'Ice:Smarty', 'template' => null, 'layout' => null], 'actions' => [], 'input' => [], 'output' => [], 'cache' => ['ttl' => -1, 'count' => 1000], 'access' => [ 'roles' => [], 'request' => null, 'env' => null ] ]; } public function run(array $input) { } }
2 main methods - config and run
method config - return array:
- 'view' - Define way of render output data ('viewRenderClass' - render class, 'template' - template for render, layout - template-wrapper of rendered content in emmet style)
- 'actions' - Child actions
- 'input' - Array of input params with their data providers. Also information of validators, defaults end other.
- 'output' - Фdditional sources of output (params and their data providers as well as 'input' section)
- 'ttl' - time stored in cache (now supported only 3600 :) )
- 'access' - Information to checks permissions to run action (support environment - one of 'production', 'test' or 'development' and request - one of 'cli' or 'ajax')
Models
Select examples:
// 1. $page = Page::getModel(20, ['title', 'desc']); // or Page::getModel(20, '*') // 2. $page = Page::create(['title' => 'page 20')->find([id, 'desc']); // 3. $page = Page::createQueryBuilder()->eq(['desc' => '20th page'])->getSelectQuery()->getModel();
Insert examples:
// 1. Page::create(['title' => 'page 20', 'desc' => '20th page'])->save(); // 2. Page::createQueryBuilder()->getInsertQuery(['title' => 'page 20', 'desc' => '20th page'])->getQueryResult();
Update examples:
// 1. Page::getModel(20, ['title', 'desc'])->set(['title' => 'another title'])->save(); // 2. Page::createQueryBuilder()->eq(['id' => 20])->getUpdateQuery(['title' => 'another title'])->getQueryResult();
Update examples:
// 1. Page::getModel(20, '/pk')->remove(); // 2. Page::createQueryBuilder()->getDeleteQuery(20)->getQueryResult();