Первая бета Phalcon 1.0.0

в 9:05, , рубрики: phalcon, php, переводы, разработка, фреймворк, метки: , ,

Сегодня граппа разработчиков Phalcon выпустило первую бета-версию фреймворка Phalcon 1.0.0. Для тех, кто не в курсе: Phalcon — это PHP-фреймворк, написанный на Си и работающий как расширение для PHP, прочитать про него на Хабре можно в статьях Phalcon — скомпилированный PHP MVC Framework и Phalcon: Давайте учиться на примере.
Цель выпуска этой версии — получение обратной связи от сообщества и обнаружение максимума ошибок.

Первая бета Phalcon 1.0.0

Краткий анонс важных нововведений этой версии:

  1. Многоуровневое кеширование
  2. Улучшения в шаблонизаторе Volt
  3. Горизонтальный и вертикальный шардинг
  4. Запись состояния (Record Snapshots)
  5. Динамическое обновление
  6. Валидация


1. Многоуровневое кеширование

Новая возможность компонента кеширования позволяет разработчику осуществлять кеш в несколько уровней. Возможность будет полезна при сохранении кеша в нескольких местах (системах кеширования) с разным временем жизни, и последующим поочерёдным чтением из них начиная с самого быстрого (в порядке регистрации) и заканчивая самым медленным, пока срок жизни во всех них не истечет.

<?php

$ultraFastFrontend = new PhalconCacheFrontendData(array(
    "lifetime" => 3600
));

$fastFrontend = new PhalconCacheFrontendData(array(
    "lifetime" => 86400
));

$slowFrontend = new PhalconCacheFrontendData(array(
    "lifetime" => 604800
));

//Backends are registered from the fastest to the slower
$cache = new PhalconCacheMultiple(array(
  new PhalconCacheBackendApc($frontCache, array(
        "prefix" => 'cache',
    )),
    new PhalconCacheBackendMemcache($fastFrontCache, array(
        "prefix" => 'cache',
        "host" => "localhost",
        "port" => "11211"
    )),
    new PhalconCacheBackendFile($slowestFrontCache, array(
        "prefix" => 'cache',
        "cacheDir" => "../app/cache/"
    ));
));

// Сохранение, сохраняется сразу во все системы кеширования
$cache->save('my-key', $data);

// Получение, читается сразу со всех систем где кеш еще живой
$data = $cache->get('my-key');

2. Улучшения в шаблонизаторе Volt

Volt (написанный так же на Си) получил в этой версии несколько новых возможностей:

{# Тернарный оператор #}
{{ total > 0 ? total|format('%0.2f') : '0.0' }}

{# Поддержка For-Else #}
{% for robot in robots %}
    {{ robot.name }}
{% else %}
    There are no robots
{% endfor %}

{# Циклы внутри контекста #}
<table>
{% for robot in robots %}
    {% if loop.first %}
        <thead>
            <tr>
                <th>Position</th>
                <th>Id</th>
                <th>Name</th>
            </tr>
        </thead>ae
        <tbody>
    {% endif %}
    <tr>
        <th>{{ loop.index }}</th>
        <th>{{ robot.id }}</th>
        <th>{{ robot.name }}</th>
    </tr>
    {% if loop.last %}
        <tbody>
    {% endif %}
{% endfor %}
</table>

{# Контролирование пробелов в разделении (Space control delimiters) #}
<ul>
    {%- for robot in robots -%}
    <li>  {{- robot.name -}}</li>
    {%- endfor %}
</ul>

3. Горизонтальный и вертикальный шардинг

Теперь для записи и чтения из базы данных можно использовать разные соединения. Полезность проявляется при работе с master/slave конфигурацией СУБД:

class Robots extends PhalconMvcModel
{
    public function initialize()
    {
        $this->setReadConnectionService('dbSlave');
        $this->setWriteConnectionService('dbMaster');
    }
}

Также возможен горизонтальный шардинг, когда соединение выбирается в зависимости от запрашиваемых данных:

class Robots extends PhalconMvcModel
{
    public function selectReadConnection($intermediate, $bindParams, $bindTypes)
    {
        // Проверяем, есть ли в запросе условие 'where'
        if (isset($intermediate['where'])) {

            $conditions = $intermediate['where'];

            // Выбираем соединение в зависимости по требуемому условия
            if ($conditions['left']['name'] == 'id') {
                $id = $conditions['right']['value'];
                if ($id > 0 && $id < 10000) {
                    return $this->getDI()->get('dbShard1');
                }
                if ($id > 10000) {
                    return $this->getDI()->get('dbShard2');
                }
            }
        }

        // В остальных случаях используем соединение по умолчанию
        return $this->getDI()->get('dbShard0');
    }

}

4. Запись состояния (Record Snapshots)

Теперь в моделях может быть установлено свойство для хранения значений полей в момент запроса. Вы можете использовать эту функцию для аудита или проверки изменения значений полей в процессе работы:

class Robots extends PhalconMvcModel
{
    public function initalize()
    {
        $this->keepSnapshots(true);
    }
}

Так можно проверить значения каких полей были изменены:

$robot = new Robots();
$robot->name = 'Other name';
var_dump($robot->getChangedFields()); // ['name']
var_dump($robot->hasChanged('name')); // true
var_dump($robot->hasChanged('type')); // false

5. Динамическое обновление

Позволяет ORM при формирования SQL запроса UPDATE использовать в нём только те поля, значения которых были изменены, а не собирать все поля и все их значения. Это уменьшает трафик между серверами приложения и базы данных, что в свою очередь может благоприятно сказаться на производительности:

class Robots extends PhalconMvcModel
{
    public function initalize()
    {
        $this->useDynamicUpdate(true);
    }
}

6. Валидация

Новый компонент PhalconValidation позволяет осуществлять независимую проверку данных. Компонент основан на проверках уже реализованных в ORM и ODM. С его помощью можно проверять данные не связанные с какой-либо моделью или коллекцией:

$validation = new PhalconValidation();

$validation
    ->add('name', new PresenceOf(array(
        'message' => 'Поле name обязательно для заполнения'
    )))
    ->add('name', new StringLength(array(
        'min' => 5,
        'minimumMessage' => 'Значение поля name слишком короткое'
    )))
    ->add('email', new PresenceOf(array(
        'message' => 'Поле email обязательно для заполнения '
    )))
    ->add('email', new Email(array(
        'message' => 'Email не соответствует формату'
    )))
    ->add('login', new PresenceOf(array(
        'message' => 'Поле login обязательно для заполнения'
    )));

$messages = $validation->validate($_POST);
if (count($messages)) {
    foreach ($messages as $message) {
        echo $message;
    }
} 

Этот выпуск так же содержит другие улучшения и исправления, вы можете узнать их все прочитав полный список изменений или его же на русском в русской группе поддержки Phalcon вконтакте.

Помочь с тестированием

Получить эту версию можно с GitHub из ветки 1.0.0:

git clone http://github.com/phalcon/cphalcon
cd build
git checkout 1.0.0
sudo ./install

Пользователи Windows могут скачать готовую библиотеку DLL на странице загрузки.

С радостью примем ваши замечания и предложения на Phosphorum, Stack Overflow или Google Group. Если вы обнаружили ошибку и можете сформировать тест для её повторения или решения — отправте нам pull request или создайте issue на GitHub.

P.S. Перевод вольный с дополнениями, оригинал здесь.
Для поддержки фреймворка создана група вконтакте, русский сайт и начата локализации документации, присоединяйтесь!
Есть так же другой перевод документации и примеров Phalcon PHP FrameWork

Права на оригинальное фото принадлежат Simon Roy: 500px.com/photo/7924712

Автор: boston

Источник

* - обязательные к заполнению поля


https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js