Jump to content

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

Featured Replies

Posted
comment_12872

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, после этого сохраните файл и закачайте к себе на сервер.

Edited by Respected

comment_12875

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

comment_12884

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

comment_12887

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

c75094136414.jpg

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

comment_12904

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

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

comment_12905

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

comment_12911

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

comment_12923

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

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

comment_12953

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

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

comment_12955

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]

comment_12984

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

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

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

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

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

comment_12988

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:

comment_12996

Исправление авторизации через 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]

Сохранить.

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

comment_13022

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

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

comment_13040

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

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

comment_13179

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

comment_13187

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

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

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

comment_13190

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

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

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

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

comment_13192

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

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

comment_13193

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

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

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

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.


Guest
Ответить в этой теме...

Последние посетители 0

  • No registered users viewing this page.