...
Типичная ситуация, стартует проект, под него берут самый простенький сервер, который трудится полгода, проект вырастает и просит большой и злобный сервер.
Обычно ставят на новую железку новую ОС, поднимают софт, настраивают, переносят контент, базы и прочее, меняют DNS и через двое суток выключают старый сервер. Казалось бы простая процедура, сотни раз её делал любой сисадмин. НО, в процессе как показывает практика что-то забывается и уже на боевом сервере нужно делать правки и настройки, тащить старые костыли и адаптировать их на новом месте.
Этот вариант иногда неизбежен, например когда сервера в разных датацентрах. Но если сервера (новый и старый) стоят в соседних стойках, то можно просто перенести ОС на новую железку а старую сразу погасить. О том как это сделать я и напишу небольшую статью-чеклист. Итак поехали!
Читать дальше →
Изменения в классе Request
Класс Request был разделён на два класс Request и Response. Для установки ответа вы использовали:
$this->request->response = 'foo';
Оно было изменено на:
$this->response->body('foo');
Некоторые свойста существовавшие в классе Request были преобразованы в методы класса:
Request::$controller -> Request::controller()
Request::$action -> Request::action()
Request::$directory -> Request::directory()
Request::$uri -> Request::uri()
Request::instance() был заменен на Request::current() и Request::initial(). Обычно вы будете использовать Request::current(), но если вы уверены что хотите оригинальный запрос (когда запущен HMVC), используйте Request::initial()
Изменения в классе Validation
Класс проверки был улучшен для включения поддержки "контекста", из-за этого изменился API. Кроме того класс был разделён: ядро логики проверки теперь отделено от встроенных правил проверки. Новый класс ядра называется Validation, а правила расположены в классе Valid.
Проверка контекста
Класс проверки теперь содержит поддержку "контекста". Это позволило объединить методы rule() и callback(), и в теперь это просто метод rule() который может использоваться в обоих случаях.
Старый вариант использования:
rule('password', 'matches', array('repeat_password'))
Новый вариант использования:
rule('password', 'matches', array(':validation', 'password', 'repeat_password'))
Третий параметр содержит все параметры которые должны пройти проверку правилом. Если взглянуть на Valid::matches(), то увидим:
public static function matches($array, $field, $match)
:validation первый параметр, 'password' - второй (поле которое мы хотим проверить) и 'repeat_password' это третье (которое мы хотим сравнить)
:validation это специальная переменная "контекста" которая указывает классу Validation о замене текущего класса проверки. Таким образом правила matches() не отличаются от callback() в работе, но более мощные. Есть и другие контекстные переменные:
:validation - Объект проверки
:field - Имя поля (rule('username', 'min_length', array(':field', 4)))
:value - Значение поля
Можно использовать любую php функцию, если она возвращает логическое значение.
Куки salt
Класс Cookie вызывает исключение, если salt не установлена, по умолчанию salt не установлена. Вы должны убедиться, что установили salt в файле инициализации (bootstrap.php):
Cookie::$salt = 'foobar';
Или определить расширение класса Cookie в вашем приложении:
class Cookie extends Kohana_Cookie
{
public static $salt = 'foobar';
}
Изменение конструктора контроллера
Если по какой-то причине вы хотите изменить свой конструктор контроллера, он изменился на:
public function __construct(Request $request, Response $response)
Изменения index.php и bootstrap.php
Основным изменением стало удаление запроса из bootstrap.php и перенос его в index.php. Это позволит использовать один файл инициализации для выполнения тестирования. Причина изменения в том, что инициализации выполняет только установку среды, она не должна запускать её.
Обработка 404
Теперь Kohana имеет встроенную поддержку исключения для 404 и других кодов статуса HTTP. Если вы использовали ReflectionException для обнаружения 404, то сейчас должны использовать Http_Exception_404. Подробности обработка ошибок