Перейти к содержанию

IP.Board 3.1.x, 3.2.x and 3.3.x Security Update


RSS Bot

Рекомендуемые сообщения

It has come to our attention that a security issue is present in IP.Board.

We strongly recommend that you follow the instructions below to patch your community.

Instructions

This security update is a simple one file patch. Simply download the relevant zip file for your version. Expand the zip file and upload /admin/sources/base/core.php to your /admin/sources/base directory on your server ensuring that the file is overwritten.

Please contact technical support if you're unsure how to update your community.

The main download zips have been updated at the time of this announcement.

IP.Board 3.3.x

post-1674-0-10127100-1365893989_thumb.pn

IP.Board 3.2.x

post-8565-0-16954400-1365927262_thumb.jp

IP.Board 3.1.x

post-8565-0-27583200-1365934712.jpg

Thank you to Egidio Romano (aka EgiX) for reporting the issue and lending his assistance with the fix.

Установка

1. Сообщение в АЦ появляется у всех независимо от версии IP.Board и от того, установлен фикс или нет.

2. Если у вас версия IP.Board 3.3.4 (неважно, русифицированная или нет) от меня и вы раньше не выполняли инструкции в статье и не знаете, что это такое, зачем оно надо и т.д., то:

просто скачайте файл и закачайте папку
admin
из архива в корень вашего форума.

3. Если у вас версия IP.Board 3.3.x (русифицированная), то:

1. Скачайте архив.

2. Отредактируйте файл core.php вот так:

Найдите:



static public function encodeForXml( $string )

{

if ( function_exists( 'mb_detect_encoding' ) )

{

$encoding = mb_detect_encoding( $string );

if ( $encoding != 'UTF-8' )

{

$string = IPSText::convertCharsets( $string, $encoding );

}

}

elseif ( strtolower( IPS_DOC_CHAR_SET ) == 'utf-8' )

{

$string = utf8_encode( $string );

}

return $string;

}

ниже вставьте:

static public function transliterate( $text )

{

return str_replace( array('а','б','в','г','д','е','ё','ж','з','и','й','к','л','м','н','о','п','р','с','т','у','ф','х','ц','ч','ш','щ','э','ю','я','ы','ь','ъ'), array('a','b','v','g','d','e','e','zh','z','i','i','k','l','m','n','o','p','r','s','t','u','f','h','c','ch','sh','sh','a','ju','ja','i','',''), $text);

}

static public function makeSeoTransliterate( $text )

{

$text = urldecode($text);

$text = self::transliterate( $text );

$text = preg_replace('#[^a-z0-9-]#', '', $text);

$text = urlencode($text);

return $text;

}

Внимание! Сохраните этот файл в кодировке UTF-8 БЕЗ BOM! По умолчанию он в кодировке ANSI, поэтому работать ничего не будет! Для того, чтобы сохранить файл в этой кодировке, скачайте программу Notepad++, откройте в ней этот файл (root/admin/sources/base/core.php) и выберите в верхнем меню Кодировки → Преобразовать в UTF-8 без BOM, после этого сохраните файл и закачайте к себе на сервер.

Изменено пользователем Respected
Ссылка на комментарий
Поделиться на другие сайты

В наш релиз 3.3.4 фикс встроил, для остальных — качаем по ссылке если у вас nulled илиесли у вас лицензионный IP.Board — качайте с официального сайта IPS, наоборот никак нельзя иначе будут проблемы с лицензией.

Ссылка на комментарий
Поделиться на другие сайты

Скачал ipb33_oct12.zip по ссылке из поста. Заменил, но сообщение не исчезает. Мб, нужно что-нибудь ещё сделать?

Ссылка на комментарий
Поделиться на другие сайты

Владимир, Какое сообщение?

Ссылка на комментарий
Поделиться на другие сайты

мне тоже скачивать файл из первого поста, версия 3.3.х не лицензия

c75094136414.jpg

(не увидел кнопки загрузить изображение)

Ссылка на комментарий
Поделиться на другие сайты

Владимир, Какое сообщение?

c75094136414.jpg

Ссылка на комментарий
Поделиться на другие сайты

После обновы выходит такая ошибка

Fatal error: Call to undefined method IPSText::makeSeoTransliterate() in /var/www/forum.site.ru/core/sources/classes/output/publicOutput.php on line 2020

Версия 3.2.3

Ссылка на комментарий
Поделиться на другие сайты

Fever, такая же ошибка была и у меня, хорошо сделал копию файла core.РНР

Тогда решил по менять этот core.РНР на более новый и проблема исчезла, ошибки нет форум работает, все ок.

Ну а это сообщение в админ панели осталось :

Posted Today, 10:13 AM

POPULAR

It has come to our attention that a security issue is present in IP.Board.....

Возможно это объявление исчезнет позже. Или я не прав?

мой движок Версия 3.2.2

Ссылка на комментарий
Поделиться на другие сайты

Если файл заменён - сообщение должно исчезнуть, возможно чуть позже. У нас сообщение появилось не сразу, как вышел данный патч.

Ссылка на комментарий
Поделиться на другие сайты

1. Этот файл предназначен для английских версий 3.3.4, не от IBR. Чтобы убрать ошибку с makeSeoTransliterate нужно следовать инструкциям статьи.

2. Это сообщение не исчезнет, когда вы обновите этот файл. Все сообщения от IPS находятся в АЦ одну неделю.

Ссылка на комментарий
Поделиться на другие сайты

В наш релиз 3.3.4 фикс встроил, для остальных — качаем по ссылке если у вас nulled илиесли у вас лицензионный IP.Board — качайте с официального сайта IPS, наоборот никак нельзя иначе будут проблемы с лицензией.

так для 3.3.3 (ваш русский) не нужен этот фикс? сообщение тоже появилось в админке.

Ссылка на комментарий
Поделиться на другие сайты

1. Сообщение в АЦ появляется у всех независимо от версии IP.Board и от того, установлен фикс или нет.

2. Если у вас версия IP.Board 3.3.4 (неважно, русифицированная или нет) от меня и вы раньше не выполняли инструкции в статье и не знаете, что это такое, зачем оно надо и т.д., то:

просто скачайте файл и закачайте папку
admin
из архива в корень вашего форума.

3. Если у вас версия IP.Board 3.3.x (русифицированная), то:

1. Скачайте архив.

2. Отредактируйте файл core.php вот так:

Найдите:


static public function encodeForXml( $string )
{
if ( function_exists( 'mb_detect_encoding' ) )
{
$encoding = mb_detect_encoding( $string );
if ( $encoding != 'UTF-8' )
{
$string = IPSText::convertCharsets( $string, $encoding );
}
}
elseif ( strtolower( IPS_DOC_CHAR_SET ) == 'utf-8' )
{
$string = utf8_encode( $string );
}
return $string;
}




ниже вставьте:


static public function transliterate( $text )
{
return str_replace( array('а','б','в','г','д','е','ё','ж','з','и','й','к','л','м','н','о','п','р','с','т','у','ф','х','ц','ч','ш','щ','э','ю','я','ы','ь','ъ'), array('a','b','v','g','d','e','e','zh','z','i','i','k','l','m','n','o','p','r','s','t','u','f','h','c','ch','sh','sh','a','ju','ja','i','',''), $text);
}
static public function makeSeoTransliterate( $text )
{
$text = urldecode($text);
$text = self::transliterate( $text );
$text = preg_replace('#[^a-z0-9-]#', '', $text);
$text = urlencode($text);
return $text;
}
[/code]

[color=#282828][font=Trebuchet MS', helvetica, arial, sans-serif][background=red][b]Внимание![/b][/background][/font][/color][color=#282828][font=Trebuchet MS', helvetica, arial, sans-serif] [/font][/color][color=#FF0000][font=Trebuchet MS', helvetica, arial, sans-serif][b]Сохраните этот файл в кодировке UTF-8 БЕЗ BOM! По умолчанию он в кодировке ANSI, поэтому работать ничего не будет! Для того, чтобы сохранить файл в этой кодировке, скачайте программу Notepad++, откройте в ней этот файл ([i]root/admin/sources/base/core.php) [/i]и выберите в верхнем меню [/b][i][b]Кодировки → Преобразовать в UTF-8 без BOM[/b][/i][b], после этого сохраните файл и закачайте к себе на сервер.[/b][/font][/color]

[/spoiler]

Ссылка на комментарий
Поделиться на другие сайты

_Dark_, спасибо. но есть баг в такой доработке - пропадает авторизация через vkontakte

никаких других ошибок вроде нет, но именно при возврате к старому файлу core.php возвращается кнопка вконтакте.

и снова хелп! :)

проверьте плииииииз

PS речь о вашей IPB 3.3.3 rus

Ссылка на комментарий
Поделиться на другие сайты

1. Сообщение в АЦ появляется у всех независимо от версии IP.Board и от того, установлен фикс или нет. 2. Если у вас версия IP.Board 3.3.4 (неважно, русифицированная или нет) от меня и вы раньше не выполняли инструкции в статье и не знаете, что это такое, зачем оно надо и т.д., то:
просто скачайте файл и закачайте папку
admin
из архива в корень вашего форума.
3. Если у вас версия IP.Board 3.3.x (русифицированная), то:
1. Скачайте архив.
2. Отредактируйте файл core.php вот так:

Найдите:

 static public function encodeForXml( $string ) { if ( function_exists( 'mb_detect_encoding' ) ) { $encoding = mb_detect_encoding( $string ); if ( $encoding != 'UTF-8' ) { $string = IPSText::convertCharsets( $string, $encoding ); } } elseif ( strtolower( IPS_DOC_CHAR_SET ) == 'utf-8' ) { $string = utf8_encode( $string ); } return $string; } 
ниже вставьте:
 static public function transliterate( $text ) { return str_replace( array('а','б','в','г','д','е','ё','ж','з','и','й','к','л','м','н','о','п','р','с','т','у','ф','х','ц','ч','ш','щ','э','ю','я','ы','ь','ъ'), array('a','b','v','g','d','e','e','zh','z','i','i','k','l','m','n','o','p','r','s','t','u','f','h','c','ch','sh','sh','a','ju','ja','i','',''), $text); } static public function makeSeoTransliterate( $text ) { $text = urldecode($text); $text = self::transliterate( $text ); $text = preg_replace('#[^a-z0-9-]#', '', $text); $text = urlencode($text); return $text; } [/code]

[color=#282828][font=Trebuchet MS', helvetica, arial, sans-serif][background=red][b]Внимание![/b][/background][/font][/color][color=#282828][font=Trebuchet MS', helvetica, arial, sans-serif] [/font][/color][color=#FF0000][font=Trebuchet MS', helvetica, arial, sans-serif][b]Сохраните этот файл в кодировке UTF-8 БЕЗ BOM! По умолчанию он в кодировке ANSI, поэтому работать ничего не будет! Для того, чтобы сохранить файл в этой кодировке, скачайте программу Notepad++, откройте в ней этот файл ([i]root/admin/sources/base/core.php) [/i]и выберите в верхнем меню [/b][i][b]Кодировки → Преобразовать в UTF-8 без BOM[/b][/i][b], после этого сохраните файл и закачайте к себе на сервер.[/b][/font][/color] [/spoiler]

Сделал все по инструкции. Пока, полет нормальный. :hi:

Ссылка на комментарий
Поделиться на другие сайты

Prowler, у вас была авторизация через "вконтакте"? если да, не слетела?

Ссылка на комментарий
Поделиться на другие сайты

Исправление авторизации через Vk

Открыть core.php, найти:


/**
* Checks to see if there is a template hook installed at the specified location
*
*
* @param string $group
* @param array $id
* @return bool
*/
static public function locationHasHooks( $group, $ids )
{
/* Return right away if we don't have an ids to check */
if( ! is_array( $ids ) || ! count( $ids ) )
{
return false;
}
/* Reformat the cache on the first call, to save processing later */
static $formattedCache = array();
if( !isset($formattedCache[ $group ]) )
{
$formattedCache[ $group ] = array();

$hookCache = ipsRegistry::cache()->getCache( 'hooks' );
if ( isset( $hookCache['templateHooks'][ $group ] ) AND is_array($hookCache['templateHooks'][ $group ]) AND count($hookCache['templateHooks'][ $group ]) )
{
foreach( $hookCache['templateHooks'][ $group ] as $_hook )
{
$formattedCache[ $group ][] = $_hook['id'];
}
}
}
/* Use formatted cache to check */
if( count( $formattedCache[ $group ] ) )
{
foreach( $ids as $id )
{
if( in_array( $id, $formattedCache[ $group ] ) )
{
return true;
}
}
}
return false;
}



Ниже вставить:

/**
* Quickly determines if we've got VK enabled and set up
*
* @access public
* @return boolean
*/
static public function vkontakte_enabled()
{
return ( ipsRegistry::$settings['vk_enabled'] AND ipsRegistry::$settings['vk_api_id'] AND ipsRegistry::$settings['vk_secret'] ) ? TRUE : FALSE;
}
[/code]


[/spoiler]


Найти:


[spoiler]

[code]
/**
* Quickly determines if we've got other log in enabled and set up
*
* @return boolean
*/
static public function loginMethod_enabled( $method )
{
if ( ! count( self::$_lims ) )
{
if ( is_array( ipsRegistry::cache()->getCache('login_methods') ) )
{
$cache = ipsRegistry::cache()->getCache('login_methods');

foreach( $cache as $lim )
{
self::$_lims[ $lim['login_folder_name'] ] = $lim['login_folder_name'];
}
}
}

switch( $method )
{
case 'facebook':
return self::fbc_enabled();
break;
case 'twitter':
return self::twitter_enabled();
break;
default:
return in_array( $method, self::$_lims ) ? true : false;
break;
}
}
[/code]
[/spoiler] Заменить [spoiler]
[code]
switch( $method )
{
case 'facebook':
return self::fbc_enabled();
break;
case 'twitter':
return self::twitter_enabled();
break;
default:
return in_array( $method, self::$_lims ) ? true : false;
break;
}
[/code]
[/spoiler] на: [spoiler]
[CODE]
switch( $method )
{
case 'vkontakte':
return self::vkontakte_enabled();
break;
case 'facebook':
return self::fbc_enabled();
break;
case 'twitter':
return self::twitter_enabled();
break;
default:
return in_array( $method, self::$_lims ) ? true : false;
break;
}
[/code]

[/spoiler]

Сохранить.

Не проверял, но работать должно.

Ссылка на комментарий
Поделиться на другие сайты

профи! работает на русской 3.3.3 (кнопочка авторизации вконтакте на месте)

PS чувствую с VK ещё намучаюсь... даже на 3.3.4 пока не могу из-за этой авторизации пересесть.

Ссылка на комментарий
Поделиться на другие сайты

в контакте не пользую..

Мафия, реальные маги IPB :hi:

Ссылка на комментарий
Поделиться на другие сайты

Насчет Vk под 3.3.4:

сейчас времени нет, но думаю в понедельник разберусь с этим и напишу статью об авторизации через Vk на версии 3.3.4.

Ссылка на комментарий
Поделиться на другие сайты

Не знаю глупый-ли вопрос, но неужели это такой важный фикс, что приходится потом пол форума восстанавливать? Что он латает? Какую уязвимость? Критичная ли она?

Ссылка на комментарий
Поделиться на другие сайты

Заменил, вылезла фатал ерор, и опять закинyл старый файл.

Я почитал, и полyчается y меня на форyме и стоял новый файл?

Просто BertT что y него когда старый файл ставил, тогда такая ошибка была, а я ставлю новый, который в теме и вылазит ошибка.

Ссылка на комментарий
Поделиться на другие сайты

Не знаю глупый-ли вопрос, но неужели это такой важный фикс, что приходится потом пол форума восстанавливать? Что он латает? Какую уязвимость? Критичная ли она?

Кто вас заставляет его ставить.

Заменил, вылезла фатал ерор, и опять закинyл старый файл.

Я для тех, кто не любит читать первую страницу темы в первое сообщение написал как устанавливать.

Ссылка на комментарий
Поделиться на другие сайты

я прочитал всю тему до того как спросить.

Как тогда вы могли не заметить

Ссылка на комментарий
Поделиться на другие сайты

В этой статье много чего левого, то что ненадо.

Раз вы добавили только один пункт.

Темболее я незнаю даже что я делал и что бы получилось, заменив то все.

Ссылка на комментарий
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.

Гость
Ответить в этой теме...

×   Вставлено с форматированием.   Вставить как обычный текст

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
×
×
  • Создать...