Перейти к публикации
Дизайн и модификация IPS Community IPBSkinsBETA
Поиск в
  • Дополнительно...
Искать результаты, содержащие...
Искать результаты в...
Alien2001

Избавление от внешних ссылок

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

Возникла необходимость избавиться от внешних ссылок путем редиректа вида www.forum.ru/out/http://yandex.ru

 

Просмотрев разные варианты, решил пойти по пути правки файла /admin/sources/classes/bbcode/custom/defaults.php, отвечающего за работу с кодом URL.

В самом конце файла идет проверка на внешние ссылки, добавление nofollow и external. Там же вставил такие строчки:

if ($extlink == 1 ) {

if ($this->settings['htaccess_mod_rewrite'] == 1) 	$option = "{$this->settings['board_url']}/out/$option";
else $option = "{$this->settings['board_url']}?/out/$option";
	}

 

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

 

Однако появилось неожиданная проблема: при первичной отправке сообщения оно записывается в базу корректно (то есть там чистый урл _http://yandex.ru ), однако, если мы сообщение редактируем, оно по какой-то причине попадает в редактор уже с "грязным" урлом - _http://www.forum.ru/out/http://yandex.ru Это немного неожиданно, потому что вроде бы добавления касались именно отображаемой информации, html-кода.

 

Подскажите, пожалуйста, где копнуть, чтобы этого избежать.

 

Версия 3.3

Поделиться сообщением


Ссылка на сообщение
Обратите внимание

По указанному вами в профиле "Board url" находится не IP.Board, либо модифицированный пиратский скрипт с удаленными копирайтами. Если вы указали неверный URL, пожауйста, поправьте его, потому что он скорее всего потребуется при диагностике вашей проблемы. Нелицензионные скрипты не приветствуются, т.к. зачастую именно некорректное "нуление" и является причиной проблем в них.

Поделиться сообщением


Ссылка на сообщение

Подобное решение, как казалось, позволило сохранить в базе "чистые" урлы

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

Можно попробовать такой костыль

 

	if( $extlink AND $this->request['do'] != 'edit_post' )
	{
		if( $this->settings['htaccess_mod_rewrite'] == 1 )
			$option = "{$this->settings['board_url']}/out/{$option}";
		else
			$option = "{$this->settings['board_url']}?/out/{$option}";
	}

  • Upvote 1

Поделиться сообщением


Ссылка на сообщение

Спасибо огромное. Я как раз сообразил, что в WYSIWYG-редакторе как раз тоже нужно парсить, он же WYSIWYG :rolleyes: Сидел думал, какое бы условие придумать, чтобы понять, что мы не в посте, а в редактировании.

 

Однако, do при редактировании поста отдает значение 'editBoxShow', а не 'edit_post', в комментах в блогах - editentry и showEdit.

 

А нет другого способа определить, что вызов идет из редактора?

Поделиться сообщением


Ссылка на сообщение
AND ! in_array($this->request['do'], array('edit_post', 'editBoxShow', 'editentry', 'showEdit'))

Поделиться сообщением


Ссылка на сообщение

Дубль, сорри. Пока писал условие уже ответили...

Поделиться сообщением


Ссылка на сообщение

Ну, это понятно, спасибо.

 

Я просто опасаюсь, что выловил не все события, где может идти парсинг ссылок.

По идее ведь редактор во всех случаях один (обычный или усеченный), нет ли возможности выявить, что именно из него вызван парсинг?

Поделиться сообщением


Ссылка на сообщение

Ну добавьте тогда в форме редактора какую нибудь переменную, которую будете проверять. Сам редактор ничего не отправляет, чем можно было бы его однозначно опознать (по крайней мере я не заметил).

Поделиться сообщением


Ссылка на сообщение

Спасибо, попробую.

Поделиться сообщением


Ссылка на сообщение

Ну добавьте тогда в форме редактора какую нибудь переменную, которую будете проверять. Сам редактор ничего не отправляет, чем можно было бы его однозначно опознать (по крайней мере я не заметил).

Нет, не так. Контент вызывает не редактор, а событие (do) который вызывает редактор вместе с контеном. Значит этот вариант работать не будет. Ну в общем самый простой способ остается по прежнему проверка do, либо найти единое место через которое проходит текст при полном редактирование или быстром и сделать там замену.

Поделиться сообщением


Ссылка на сообщение

Кстати, вот одна явная переменная которая присутствует и при запросе быстрого редактирования и при запросе полно редактирования $this->request['mod_options']

 

if( $extlink AND ! array_key_exists('mod_options', $this->request) )

Поделиться сообщением


Ссылка на сообщение

Кстати, вот одна явная переменная которая присутствует и при запросе быстрого редактирования и при запросе полно редактирования $this->request['mod_options']

 

if( $extlink AND ! isset($this->request['mod_options']) )

В контенте, например, нет этой переменной.

Array ( [/articles_html/_/novosti/escho-odna-novost?do] => edit [module] => [section] => [request_method] => get [do] => edit [_isDatabase] => novosti/escho-odna-novost [database] => 1 [record] => 12 [category] => 11 )

Ну и "$this->request['do'] == 'edit'", до кучи.

 

P.S. Да и в блогах не вижу.

Поделиться сообщением


Ссылка на сообщение

Значит не судьба у ТСа :)

Поделиться сообщением


Ссылка на сообщение

Спасибо. Я упрямый - решение будет найдено обязательно

Поделиться сообщением


Ссылка на сообщение

У Вас есть решение:

if( $extlink AND ! in_array( $this->request['do'], array('edit', 'edit_post', 'editBoxShow', 'editentry', 'showEdit') )

Если вдруг обнаружится ещё какой то ключ, просто добавите его в массив.

Сомневаюсь, что найдете что то лучше.

Поделиться сообщением


Ссылка на сообщение

Создайте аккаунт или войдите в него для комментирования

Вы должны быть пользователем, чтобы оставить комментарий

Создать аккаунт

Зарегистрируйтесь для получения аккаунта. Это просто!

Зарегистрировать аккаунт

Войти

Уже зарегистрированы? Войдите здесь.

Войти сейчас

  • Сейчас на странице   0 пользователей

    Нет пользователей, просматривающих эту страницу.

×
×
  • Создать...