Textpattern - на русском языке

форум общения русскоязычных пользователей CMS Текстпаттерн

Вы не зашли.

#1 29-08-2007 23:29:50

Colin Foster
глаголь
Откуда: Лимерик
Зарегистрирован: 22-08-2007
Сообщений: 32
Вебсайт

mem_self_register

Стоит ли вообще использовать плагин?

1. Кто-нибудь пользовался? Можете показать примеры?
2. Нет ли дыр?

Пока больше проблем, редактировал настройки (по инструкции), теперь вылезает следующий баг:

Parse error: syntax error, unexpected T_STRING in /home/aporno/public_html/textpattern/include/txp_auth.php on line 27

Вообще не знаю, как с этим бороться, жалею уже, что установил (

Неактивен

 

#2 30-08-2007 00:46:37

AngryCAT
ферт
Откуда: Германия
Зарегистрирован: 18-04-2006
Сообщений: 486
Вебсайт

Re: mem_self_register

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


TextPattern строить и жить помогает! Кстати, пишу плагины на заказ. ICQ 155-08-081. В асю, пожалуйста, по поводу заказов или платных консультаций (10$ час). Остальные вопросы в форум или на почту.

Неактивен

 

#3 31-08-2007 03:36:48

Colin Foster
глаголь
Откуда: Лимерик
Зарегистрирован: 22-08-2007
Сообщений: 32
Вебсайт

Re: mem_self_register

Да, вы, конечно, правы, но до этого всё шло как по маслу? Можно ли теперь сделать откат? Просто заменить изменённые вручную файлы на исходные?

Неактивен

 

#4 31-08-2007 16:19:14

Evgeny
ять
Зарегистрирован: 15-03-2005
Сообщений: 1869

Re: mem_self_register

Colin Foster написал:

заменить изменённые вручную файлы на исходные?

да, проблем быть не должно

Неактивен

 

#5 15-11-2007 16:24:07

tima
аз
Зарегистрирован: 15-11-2007
Сообщений: 1

Re: mem_self_register

Где можно скачать данный плагин?
С  официального сайта не скачивается sad

Отредактированно tima (15-11-2007 16:24:46)

Неактивен

 

#6 16-11-2007 01:55:44

AngryCAT
ферт
Откуда: Германия
Зарегистрирован: 18-04-2006
Сообщений: 486
Вебсайт

Re: mem_self_register

Всем страждущим посвящается.

Код:

a:9:{s:4:"name";s:17:"mem_self_register";s:7:"version";s:5:"0.8.3";s:6:"author";s:14:"Michael Manfre";s:10:"author_uri";s:18:"http://manfre.net/";s:11:"description";s:49:"User self registration. Read the help to install.";s:4:"type";i:1;s:4:"help";s:9237:"
	<h2>User Self Registration</h2>

	<h3>Installation</h3>

	<p><a href="index.php?event=self-reg&#38;step=preinstall&#38;area=admin">Start Install Wizard</a></p>

	<h3>Summary</h3>

	<p>This plugin is designed to enable community driven sites. Users will be able to register themselves for an account to access the system. This plugin is compatible with the ign_user_password plugin alternate user table. This plugin provides user side tags for generating an html form where users can edit their account information.</p>

	<h3>Client Plug-in Tags:</h3>

	<ul>
	<li><strong>mem_self_register_form</strong></li>
		<li><strong>self_register_email_message</strong></li>
		<li><strong>self_register_status_message</strong></li>
		<li><strong>if_self_registered</strong></li>
		<li><strong>mem_change_password_form</strong></li>
		<li><strong>mem_user_edit_form</strong></li>
		<li><strong>mem_profile</strong></li>
	</ul>

	<p><hr /></p>

	<h4>mem_self_register_form</h4>

	<p>This will output an HTML form that will allow a user to register themselves with an account.</p>

	<p>Tag Attributes:</p>

	<ul>
	<li><strong>form</strong>&#8212;Specifies which form contains the HTML form template. Default is &#8220;self_register_form&#8221;.</li>
		<li><strong>email_form</strong>&#8212;Specifies which form contains the email message template that will be sent to a user upon registering. Default is &#8220;self_register_email&#8221;.</li>
		<li><strong>wraptag</strong>&#8212;The HTML tag that will wrap the generated form. Default is none.</li>
		<li><strong>isize</strong>&#8212;The size of the input fields. Default is 25.</li>
		<li><strong>label</strong>&#8212;The text to place on the submit button. Default is the localized &#8220;submit&#8221;.</li>
		<li><strong>namewarn</strong>&#8212;An error message that will be displayed to the user when the name field is left blank.</li>
		<li><strong>userwarn</strong>&#8212;An error message that will be displayed to the user when the user field is left blank.</li>
		<li><strong>emailwarn</strong>&#8212;An error message that will be displayed to the user when the email field is left blank.</li>
		<li><strong>class</strong>&#8212;The css style class to add to the wraptag. Default is &#8220;mem_self_register_form&#8221;.</li>
	</ul>

	<p>Template tags that can be used within the HTML template form.</p>

	<ul>
	<li><code>&lt;txp:mem_name_warn /&gt;</code>&#8212;This will display the contents of namewarn when the name_input field is left blank.</li>
		<li><code>&lt;txp:mem_user_warn /&gt;</code>&#8212;This will display the contents of userwarn when the user_input field is left blank.</li>
		<li><code>&lt;txp:mem_email_warn /&gt;</code>&#8212;This will display the contents of emailwarn when the email_input field is left blank.</li>
		<li><code>&lt;txp:mem_name_input /&gt;</code>&#8212;This will display the name field.</li>
		<li><code>&lt;txp:mem_user_input /&gt;</code>&#8212;This will display the user field.</li>
		<li><code>&lt;txp:mem_email_input /&gt;</code>&#8212;This will display the email field.</li>
		<li><code>&lt;txp:mem_submit /&gt;</code>&#8212;This will display the submit button.</li>
	</ul>

	<p>Starter Template:</p>

<code><br />
Name: &lt;txp:mem_name_input /&gt;&lt;br /&gt;<br />
User Name: &lt;txp:mem_user_input /&gt;&lt;br /&gt;<br />
Email: &lt;txp:mem_email_input /&gt;&lt;br /&gt;<br />
&lt;txp:mem_submit /&gt;<br />
</code>

	<p>Template tags that can be used within the email template form. In addition to the tags listed below, any other Textpattern tag can be used.</p>

	<ul>
	<li><code>&lt;txp:mem_name /&gt;</code>&#8212;The name submitted by the user.</li>
		<li><code>&lt;txp:mem_username /&gt;</code>&#8212;The username submitted by the user.</li>
		<li><code>&lt;txp:mem_email /&gt;</code>&#8212;The email address submitted by the user.</li>
		<li><code>&lt;txp:mem_password /&gt;</code>&#8212;The password generated for the user.</li>
		<li><code>&lt;txp:mem_sitename /&gt;</code>&#8212;The site name as specified in the Site Configuration (prefs tab).</li>
		<li><code>&lt;txp:mem_siteurl /&gt;</code>&#8212;The url to the front page of this site.</li>
		<li><code>&lt;txp:mem_loginurl /&gt;</code>&#8212;The url to the Textpattern log in page.</li>
		<li><code>&lt;txp:mem_admin_name /&gt;</code>&#8212;The name of the administrative contact. This will automatically be in the email from field.</li>
		<li><code>&lt;txp:mem_admin_email /&gt;</code>&#8212;The email address of the administrative contact. This will automatically be in the email from field.</li>
	</ul>

	<p>Starter Template:</p>

<code><br />
Dear &lt;txp:mem_name /&gt;,
  Thank you for registering for &lt;txp:mem_sitename /&gt;. Below are you user account details.

	<p>Username: &lt;txp:mem_username /&gt;<br />
Password: &lt;txp:mem_password /&gt;<br />
Site URL: &lt;txp:mem_siteurl /&gt;<br />
Login URL: &lt;txp:mem_loginurl /&gt;</p>

	<p>Sincerely,<br />
&lt;txp:mem_admin_name /&gt;<br />
Email: &lt;txp:mem_admin_email /&gt;<br />
</code></p>

	<p>Example:</p>

	<p><code><br />
&lt;txp:mem_self_register_form wraptag="div" isize="20" label="Register" namewarn="Name is required" userwarn="Username is required" emailwarn="Email address is required" /&gt;<br />
</code></p>

	<p><hr /></p>

	<h4>self_register_status_message</h4>

	<p>This will output the status message generated after submitting the self registration form.</p>

	<p><hr /></p>

	<h4>self_register_email_message</h4>

	<p>After the form is submitted, this will output the entire email message that was sent to the user.</p>

	<p><hr /></p>

	<h4>if_self_registered</h4>

	<p>This will output the contents of the tag if the user has already been registered. To work properly, this requires browser cookies after the initial form submission. This tag supports <code>&lt;txp:else /&gt;</code></p>

	<p>Example:</p>

	<p><code><br />
&lt;txp:if_self_registered&gt;<br />
You already have an account.<br />
&lt;txp:else /&gt;<br />
&lt;txp:mem_self_register_form /&gt;<br />
&lt;/txp:if_self_registered&gt;<br />
</code></p>

	<p><hr /></p>

	<h4>mem_change_password_form</h4>

	<p>This tag allows a change password form to be displayed on the user portion of the website. This is meant to be used with the ign_password_protect plugin. This tag supports the tag txp:mem_profile (see below).</p>

	<p>Tag Attributes:</p>

	<ul>
	<li><strong>form</strong>&#8212;Specifies which form contains the HTML form template. This form will be reparsed by Txp. Default is none. If not specified, a default form will be used.</li>
		<li><strong>form_mail</strong>&#8212;Specifies which form contains the message template that will be used to create the message that will be emailed to the user. Default is none. If not specified, a default message template will be used.</li>
		<li><strong>wraptag</strong>&#8212;The HTML tag that will wrap the generated form. Default is none.</li>
		<li><strong>class</strong>&#8212;The css style class to add to the wraptag. Default is &#8220;mem_password_form&#8221;.</li>
	</ul>

	<p>Template tags that can be used within the &#8216;form&#8217; template form.</p>

	<ul>
	<li><code>&lt;txp:mem_password_input /&gt;</code>&#8212;This will display a password form field</li>
		<li><code>&lt;txp:mem_submit /&gt;</code>&#8212;This will display a form submit button</li>
	</ul>

	<p>Template tags that can be used within the &#8216;form_mail&#8217; template form.</p>

	<ul>
	<li><code>&lt;txp:mem_realname /&gt;</code>&#8212;This will be replaced with the user&#8217;s real name.</li>
		<li><code>&lt;txp:mem_password /&gt;</code>&#8212;This will be replaced with the user&#8217;s password.</li>
	</ul>

	<p><hr /></p>

	<h4>mem_user_edit_form</h4>

	<p>This tag allows a form to modify user information to be displayed on the user portion of the website. This is meant to be used with the ign_password_protect plugin. This tag supports the tag txp:mem_profile.</p>

	<p>Tag Attributes:</p>

	<ul>
	<li><strong>form</strong>&#8212;Specifies which form contains the HTML form template. This form will be reparsed by Txp. Default is none.</li>
		<li><strong>wraptag</strong>&#8212;The HTML tag that will wrap the generated form. Default is none.</li>
		<li><strong>class</strong>&#8212;The css style class to add to the wraptag. Default is &#8220;mem_uedit_form&#8221;.</li>
	</ul>

	<p>Template tags that can be used within the HTML template form.</p>

	<ul>
	<li><code>&lt;txp:mem_message /&gt;</code>&#8212;This will be replaced with the message generated from submitting the form.</li>
		<li><code>&lt;txp:mem_realname_input /&gt;</code>&#8212;This will display a form field for changing the user&#8217;s Real Name.</li>
		<li><code>&lt;txp:mem_email_input /&gt;</code>&#8212;This will display a form field for changing the user&#8217;s email address.</li>
		<li><code>&lt;txp:mem_submit /&gt;</code>&#8212;This will display a form submit button</li>
	</ul>

	<h4>mem_profile</h4>

	<p>This tag will output the values of the user&#8217;s profile.</p>

	<p>Tag Attributes:</p>

	<ul>
	<li><strong>var</strong>&#8212;Specifies the profile value name to output. Supported values are &#8220;RealName&#8221;,&#8221;email&#8221;, and &#8220;new_pass&#8221;.</li>
	</ul>




 ";s:4:"code";s:26987:"
////////////////////////////////////////////////////////////
// Plugin mem_self_register
// Author: Michael Manfre (http://manfre.net/)
////////////////////////////////////////////////////////////

if (!function_exists('mem_set_pref')) {
	function mem_set_pref($name, $val, $event,  $type, $position=0, $html='text_input')
	{
		global $pref_cache;

		if ($pref_cache==null)
			$pref_cache = array();

		$args = func_get_args();
		$args['html'] = $html;
		$args['position'] = $position;
		$args['prefs_id'] = 1;

		$pref_cache[$name] = $args;

		extract(doSlash($args));

    	if (!safe_row("*", 'txp_prefs', "name = '$name'") ) {
        	return safe_insert('txp_prefs', "
				name  = '$name',
				val   = '$val',
				event = '$event',
				html  = '$html',
				type  = '$type',
				position = '$position',
				prefs_id = 1"
			);
    	} else {
        	return safe_update(	'txp_prefs', "
	        						val   = '$val',
	        						event = '$event',
	        						html  = '$html',
	        						type  = '$type',
	        						position = '$position'",
        						"name like '$name'");
    	}
    	return false;
	}
}

if (!function_exists('mem_get_pref')) {
	function mem_get_pref($name,$val='')
	{
		global $pref_cache;

		if ($pref_cache==null)
			$pref_cache = array();

		if (!in_array($name,$pref_cache) or $pref_cache[$name] === false) {
			$pref_cache[$name] = safe_row('*','txp_prefs',"name='$name'");
		} else {
			$pref_cache[$name] = false;
		}

		if (!empty($val) && in_array($val,$pref_cache[$name]))
			return $pref_cache[$name][$val];
		else
			return $pref_cache[$name];
	}
}

global $mem_self_lang;

if (!is_array($mem_self_lang))
{
	$mem_self_lang = array(
		'your_login_info'	=>	'Your Login Info',
		'admin_name'		=>	'Admin Name',
		'admin_email'		=>	'Admin Email',
		'password_sent_to'	=>	'Password Sent To',
		'error_adding_new_author'	=>	'Error adding new author',
		'greeting'			=>	'Hello',
		'your_password_is'	=>	'Your password is',
		'your_new_password'	=>	'Your new password',
		'password_changed'	=>	'Password changed',
		'password_change_failed'	=>	'Failed to change password',
		'log_in_at'			=>	'Log in at',
		'saved_user_profile'	=>	'Saved User Profile',
		'user_exists'		=>	'Username already exists. Please try another name',
	);
}

function mem_self_gTxt($name)
{
	global $mem_self_lang;

	$gtxt = gTxt($name);

	if ( strcmp($gtxt,$name) == 0 )
	{
		if ( array_key_exists($name,$mem_self_lang) )
			$gtxt = $mem_self_lang[$name];
	}

	return $gtxt;
}

global $event;

if (!isset($event)) $event = '';

if ($event != 'admin') {
	require_once txpath.'/include/txp_admin.php';

	global $levels;

	// copied from txp_admin.php
	$levels = array(
		0 => mem_self_gTxt('none'),
		6 => mem_self_gTxt('designer'),
		5 => mem_self_gTxt('freelancer'),
		4 => mem_self_gTxt('staff_writer'),
		3 => mem_self_gTxt('copy_editor'),
		2 => mem_self_gTxt('managing_editor'),
		1 => mem_self_gTxt('publisher')
	);

//-------------------------------------------------------------
	if (!function_exists('priv_levels')) {
		function priv_levels($item, $var) {
			global $levels;

			return selectInput($item, $levels, $var);
		}
	}
}


global $mem_self;

$mem_self = array(
				'admin_email'		=>	'',
				'admin_name'		=>	'',
				'new_user_priv'		=>	'0',
				'status'			=>	false,
				'status_message'	=>	'You are already registered.',
				'email_message'		=>	''
			);

$mem_self['admin_email'] = mem_get_pref('mem_self_admin_email','val'); //safe_field('val','txp_prefs',"name='mem_self_admin_email'");
$mem_self['admin_name'] = mem_get_pref('mem_self_admin_name','val'); //safe_field('val','txp_prefs',"name='mem_self_admin_name'");
$mem_self['new_user_priv'] = mem_get_pref('mem_self_new_user_priv','val'); //safe_field('val','txp_prefs',"name='mem_self_new_user_priv'");

if ( @txpinterface == 'admin' ) {
	register_callback('mem_self_register','self-reg','', 1);
	if ($event=='self-reg') {
		// fake tabs when using them. Silences warnings from pageTop()
		register_tab('admin','self-reg','self-reg');

		include_once txpath.'/publish/taghandlers.php';
	}

	function mem_self_register($event, $step) {
		if ($event!='self-reg')
			return;

		pageTop('Self Registration','');

		if ($step == 'install') {
			echo mem_self_register_install();
		} else if ($step=='preinstall') {
			$mem_admin_name	= mem_get_pref('mem_self_admin_name');
			$mem_admin_email	= mem_get_pref('mem_self_admin_email');
			$mem_new_user_priv	= mem_get_pref('mem_self_new_user_priv');
			$mem_use_ign_db	= mem_get_pref('mem_self_use_ign_db');
			$mem_xtra_columns	= mem_get_extra_user_columns();

			$mem_admin_name = @$mem_admin_name ? $mem_admin_name['val'] : 'Admin';
			$mem_admin_email = @$mem_admin_email ? $mem_admin_email['val'] : 'Admin@yourdomain.com';
			$mem_new_use_priv = @$mem_new_use_priv ? $mem_new_use_priv['val'] : '0';

			$use_ign_input = '';
			// is ign_password_protect loaded on the system?
			if (load_plugin('ign_password_protect') || $mem_use_ign_db) {
				$mem_use_ign_db = $mem_use_ign_db ? $mem_use_ign_db['val'] : '0';
				$use_ign_input = yesnoradio('use_ign_db',$mem_use_ign_db);
			}

			$xtra_columns = mem_get_extra_user_columns();
			$has_address = in_array('address',$xtra_columns);
			$has_phone = in_array('phone',$xtra_columns);

			$add_address_input = yesnoradio('add_address','0');
			$add_phone_input = yesnoradio('add_phone','0');

			echo form(
				eInput('self-reg').sInput('install').
				startTable('edit') .
					tr( fLabelCell('admin_name')	. tda(fInput('text','admin_name',$mem_admin_name,'edit')) ) .
					tr( fLabelCell('admin_email')	. tda(fInput('text','admin_email',$mem_admin_email,'edit')) ) .
					tr( fLabelCell('new_user_priv')	. tda(priv_levels('new_user_priv',$mem_new_use_priv)) ) .
					tr( fLabelCell('use_ign_db')	. tda($use_ign_input) ) .
					($has_address ? '' : tr( fLabelCell('add_address_field') . tda($add_address_input) ) ) .
					($has_phone ? '' : tr( fLabelCell('add_phone_field') . tda($add_phone_input) ) ) .
					tr( td() . td( fInput("submit", 'submit',mem_self_gTxt('install'),"Publish"), 2 ) ) .
				endTable()
				);
		} else {
			echo '<div><a href="?event=self-reg&step=preinstall">'.mem_self_gTxt('install').'</a></div>';
		}
	}


	function mem_self_register_install() {
		global $mem_self;

		extract(doSlash(gpsa(array(
			'admin_email',
			'admin_name',
			'new_user_priv',
			'use_ign_db',
			'add_address',
			'add_phone'
		))));

		if (!isset($new_user_priv) || empty($new_user_priv)) $new_user_priv = '0';

		$log = array();

		if (!($rs=safe_field('val,html','txp_prefs',"name='mem_self_use_ign_db'"))) {
			if ( mem_set_pref('mem_self_use_ign_db',$use_ign_db,'self_reg',1,'yesnoradio')) {
				$log[] = "Added pref 'mem_self_use_ign_db'";
			} else {
				$log[] = "Failed to add pref 'mem_self_use_ign_db'. " . mysql_error();
			}
		} else {
			if ($rs['html'] != 'yesnoradio') {
				safe_update('txp_prefs',"html='yesnoradio'","name='mem_self_use_ign_db'");
			}
			$log[] = "Pref 'mem_self_use_ign_db' is already installed. Current value is '{$rs}'.";
		}

		$user_table = mem_get_user_table_name();

		$xtra_columns = mem_get_extra_user_columns();
		if ($add_address) {
			if (!in_array('address',$xtra_columns)) {
				if (safe_alter($user_table,"ADD `address` VARCHAR( 128 )")) {
					$log[] = "Added column 'address' to user table '{$user_table}'";
				} else {
					$log[] = "Failed to add column 'address' to user table '{$user_table}'. " . mysql_error();
				}
			} else {
				$log[] = "Table {$user_table} already has column 'address'";
			}
		}
		if ($add_phone) {
			if (!in_array('phone',$xtra_columns)) {
				if (safe_alter($user_table,"ADD `phone` VARCHAR( 32 )")) {
					$log[] = "Added column 'phone' to user table '{$user_table}'";
				} else {
					$log[] = "Failed to add column 'phone' to user table '{$user_table}'. " . mysql_error();
				}
			} else {
				$log[] = "Table {$user_table} already has column 'phone'";
			}
		}

		if (!($rs=safe_field('val','txp_prefs',"name='mem_self_admin_email'"))) {
			if ( mem_set_pref('mem_self_admin_email',$admin_email,'self_reg',1)) {
				$log[] = "Added pref 'mem_self_admin_email'";
			} else {
				$log[] = "Failed to add pref 'mem_self_admin_email'. " . mysql_error();
			}
		} else {
			$log[] = "Pref 'mem_self_admin_email' is already installed. Current value is '{$rs}'.";
		}
		if (!($rs=safe_field('val','txp_prefs',"name='mem_self_admin_name'"))) {
			if ( mem_set_pref('mem_self_admin_name',$admin_name,'self_reg',1)) {
				$log[] = "Added pref 'mem_self_admin_name'";
			} else {
				$log[] = "Failed to add pref 'mem_self_admin_name'. " . mysql_error();
			}
		} else {
			$log[] = "Pref 'mem_self_admin_name' is already installed. Current value is '{$rs}'.";
		}
		if (($rs=safe_field('val,html','txp_prefs',"name='mem_self_new_user_priv'")) === false) {
			if ( mem_set_pref('mem_self_new_user_priv',$new_user_priv,'self_reg',1,'priv_levels')) {
				$log[] = "Added pref 'mem_self_new_user_priv' with value of '{$new_user_priv}'";
				$mem_self['new_user_priv'] = $new_user_priv;
			} else {
				$log[] = "Failed to add pref 'mem_self_newuser_priv'. " . mysql_error();
			}
		} else {
			if ($rs['html'] != 'priv_levels')
				safe_update('txp_prefs',"html='priv_levels'","name='mem_self_new_user_priv'");

			$log[] = "Pref 'mem_self_new_user_priv' is already installed. Current value is '{$rs}'.";
		}

		// create default registration form
		$form_html = <<<EOF
<table>
<tr>
	<td>Full Name</td>
	<td><txp:mem_name_input /></td>
	<td><txp:mem_name_warn /></td>
</tr>
<tr>
	<td>Username</td>
	<td><txp:mem_user_input /></td>
	<td><txp:mem_user_warn /></td>
</tr>
<tr>
	<td>Email</td>
	<td><txp:mem_email_input /></td>
	<td><txp:mem_email_warn /></td>
</tr>
<tr>
	<td colspan="3"><txp:mem_submit /></td>
</tr>
</table>
EOF;

		$form = fetch('Form','txp_form','name','self_register_form');
		if (!$form) {
			if (safe_insert('txp_form',"name='self_register_form',type='misc',Form='{$form_html}'")) {
				$log[] = "Added form 'self_register_form'";
			} else {
				$log[] = "Failed to add form 'self_register_form'. " . mysql_error().br.
					"You need to manually create a form template. Here is an example.".br.
					'<textpattern style="width:300px;height:150px;">'.htmlspecialchars($form_html).'</textarea>';
			}
		} else {
			$log[] = "Found form 'self_register_form'. Skipping installation of default form.";
		}

		// create default successful registration form to show the user
		$form_html = <<<EOF
<h3>Account Created</h3>
<p>An email containing your password has been sent to <txp:mem_profile var="email" />.</p>
EOF;

		$form = fetch('Form','txp_form','name','self_register_success');
		if (!$form) {
			if (safe_insert('txp_form',"name='self_register_success',type='misc',Form='{$form_html}'")) {
				$log[] = "Added form 'self_register_success'";
			} else {
				$log[] = "Failed to add form 'self_register_success'. " . mysql_error().br.
					"You need to manually create a form template. Here is an example.".br.
					'<textpattern style="width:300px;height:150px;">'.htmlspecialchars($form_html).'</textarea>';
			}
		} else {
			$log[] = "Found form 'self_register_success'. Skipping installation of default form.";
		}

		// create default successful registration email form
		$form_html = <<<EOF
Dear <txp:mem_name />,

Thank you for registering at <txp:mem_siteurl />.

Your login name: <txp:mem_username />
Your password: <txp:mem_password />

If you have any questions please reply to this email address.

Sincerely,
<txp:mem_admin_name />
<txp:mem_admin_email />
EOF;

		$form = fetch('Form','txp_form','name','self_register_email');
		if (!$form) {
			if (safe_insert('txp_form',"name='self_register_email',type='misc',Form='{$form_html}'")) {
				$log[] = "Added form 'self_register_email'";
			} else {
				$log[] = "Failed to add form 'self_register_email'. " . mysql_error().br.
					"You need to manually create a form template. Here is an example.".br.
					'<textpattern style="width:300px;height:150px;">'.htmlspecialchars($form_html).'</textarea>';
			}
		} else {
			$log[] = "Found form 'self_register_form'. Skipping installation of default form.";
		}

		$tag_help = '<txp:mem_self_register_form form="self_register_form" />';
		$log[] = 'Example tag to use in your page template.'.br.
			'<textarea style="width:400px;height:40px;">'.htmlspecialchars($tag_help).'</textarea>';

		return doWrap($log,'ul','li');
	}
}

function mem_get_user_table_name() {
	$use_ign_db = mem_get_pref('mem_self_use_ign_db');

	$table_name = 'txp_users';

	if ($use_ign_db) {
		$ign_use_custom = mem_get_pref('ign_use_custom');
		if ($ign_use_custom && $ign_use_custom['val']=='1') {
			$ign_user_db = mem_get_pref('ign_user_db');
			if ($ign_user_db && !empty($ign_user_db['val']))
				$table_name = $ign_user_db['val'];
		}
	}
	return $table_name;
}

// -------------------------------------------------------------
function mem_self_register_form($atts,$thing='')
{
	global $txpac;

	$namewarn = $userwarn = $emailwarn = '';

	extract(doSlash(psa(array('event','step','name','email','username','address','phone','mem_self_register'))));

	extract(lAtts(array(
		'class'		=> __FUNCTION__,
		'form'		=> 'self_register_form',
		'success_form'	=> 'self_register_success',
		'email_form'	=> 'self_register_email',
		'wraptag'	=> '',
		'isize'		=> '25',
		'label'		=> mem_self_gTxt('submit'),
		'namewarn'	=> mem_self_gTxt('name_required'),
		'userwarn'	=> mem_self_gTxt('user_required'),
		'emailwarn'	=> mem_self_gTxt('email_required'),
	),$atts));

	$name = trim($name);
	$username = trim($username);
	$email = trim($email);
	$phone = trim($phone);
	$address = trim($address);

	$saved = false;

	if ($event=='self-reg' && $step=='register') {
		if (!is_valid_form()) {
			$namewarn = empty($name) ? $namewarn : '';
			$userwarn = empty($username) ? $userwarn : '';
			// if all fields are non empty, then the email address failed for some reason.
			$emailwarn = empty($email) ? $emailwarn : (empty($namewarn) and empty($userwarn) ? $emailwarn : '');
		} else {

			$rs = safe_field('name',mem_get_user_table_name(),"name='{$username}'");

			if (empty($rs)) {
				mem_self_register_save();
				$saved = true;
			} else {
				// don't change $userwarn
				$namewarn = $emailwarn = '';
			}
		}
	} else {
		// don't show the warnings
		$namewarn = '';
		$userwarn = '';
		$emailwarn = '';
	}

	if (@$saved) {
		$Form = fetch_form($success_form);
		$out = parse($Form);
	} else {

		$Form = fetch_form($form);

		$vals = array(
			'name_warn'		=> $namewarn,
			'user_warn'		=> $userwarn,
			'email_warn'	=> $emailwarn,
			'name_input'	=> fInput('text','name',  $name, 'register_name_input','','',$isize,"0", 'mem_name_input'),
			'user_input'	=> fInput('text','username', $username, 'register_user_input', '', '', $isize, "0", 'mem_user_input'),
			'email_input'	=> fInput('text','email', $email,'register_email_input','','',$isize,"0", 'mem_email_input'),
			'submit'		=> fInput('submit','submit',mem_self_gTxt($label),'button'),
			'phone_input'	=> fInput('text','phone', $phone, 'register_phone_input', '', '', $isize, "0", 'mem_phone_input'),
			'address_input'	=> fInput('text','address', $address, 'register_address_input', '', '', $isize, "0", 'mem_address_input'),
		);

		foreach ($vals as $a=>$b) {
			$Form = str_replace('<txp:mem_'.$a.' />',$b,$Form);
		}

		$action_url = $_SERVER['REQUEST_URI'];
		$qs = strpos($action_url,'?');
		if ($qs) $action_url = substr($action_url, 0, $qs);

		$out =	n.n."<form enctype='multipart/form-data' action='{$action_url}' method='post'>" .
				eInput('self-reg') . sInput('register') . hInput('email_form',$email_form) . hInput('mem_self_register','register') .
				parse($Form) .
				"</form>".n;
	}

	return doTag($out,$wraptag,$class);

}

function mem_get_extra_user_columns_insert_string() {
	$xtra_columns = mem_get_extra_user_columns();

	$xtra = '';

	foreach ($xtra_columns as $xcol) {
		$name = $xcol['Field'];
		$type = strtolower($xcol['Type']);
		$val = gps($name);

		if ( strstr($type,'int')
				|| $type=='float'
				|| $type=='decimal'
				|| $type=='double'
				|| $type=='bool' ) {
			// don't quote value
			$xtra .= ", {$name}=" . doSlash($val);
		} else {
			// quote value
			$xtra .= ", {$name}='" . doSlash($val) ."'";
		}
	}

	return $xtra;
}

function mem_get_extra_user_columns()
{
	static $default_columns = array('user_id','name','pass','RealName','email','privs','last_access','nonce');
	static $xtra_columns = false;

	if (is_array($xtra_columns))
		return $xtra_columns;

	$table_name = mem_get_user_table_name();
	$txpdesc = getRows('describe '.PFX. $table_name);

	$xtra_cols = array();

	$dcols = $default_columns;

	foreach($txpdesc as $r) {
		if ( !in_array($r['Field'], $default_columns) )
			$xtra_cols[] = $r;
	}

	return $xtra_cols;
}

// -------------------------------------------------------------
function mem_self_register_save()
{
	global $mem_self,$sitename,$mem_profile;

	extract(doSlash(psa(array('name','email','username','email_form','address','phone','mem_self_register','login_url'))));
	extract($mem_self);

	if ($mem_self_register != 'register') return '';

	$pw = generate_password(6);

	if (!$mem_profile) $mem_profile = array();

	$mem_profile['nonce'] = $nonce = md5( uniqid( rand(), true ) );

	$mem_profile['RealName'] = $name = trim($name);
	$mem_profile['email'] = $email = trim($email);
	$mem_profile['name'] = $username = trim($username);
	$mem_profile['privs'] = $new_user_priv;

	$xtra_columns = mem_get_extra_user_columns();

	foreach($xtra_columns as $c) {
		$c_name = trim( $c['Field'] );

		$mem_profile[$c_name] = gps($c_name);
	}

	$rs = false;

	$xtra = mem_get_extra_user_columns_insert_string();

	$rs = safe_insert(
		mem_get_user_table_name(),
		"privs    = '$new_user_priv',
		 name     = '$username',
		 email    = '$email',
		 RealName = '$name',
		 pass     =  password(lower('$pw')),
		 nonce    = '$nonce'" . $xtra
	);

	if ($rs) {
		$mem_profile['user_id'] = $rs;
		$mem_profile['last_access'] = 0;

		if ($email_form) {
			$message = fetch('Form','txp_form','name',$email_form);

			if (is_array($admin_name))
				$admin_name = $admin_name['val'];
			if (is_array($admin_email))
				$admin_email = $admin_email['val'];

			if (empty($login_url))
				$login_url = rtrim(hu,'/').'/textpattern/index.php';

			$vals = array(
				'admin_name'	=>	$admin_name,
				'admin_email'	=>	$admin_email,
				'name'		=>	$name,
				'username'	=>	$username,
				'email'		=>	$email,
				'password'	=>	$pw,
				'sitename'	=>	$sitename,
				'loginurl'	=>	$login_url,
				'siteurl'	=>	hu,
				'address'	=>	$address,
				'phone'		=>	$phone
			);

			foreach ($vals as $a=>$b) {
				@$message = str_replace('<txp:mem_'.$a.' />',$b,$message);
			}

			$message = parse($message);

			$emailbody = "From: {$admin_name} <{$admin_email}>\r\n"
				."Bcc: {$admin_email}\r\n"
				."Reply-To: {$admin_email}\r\n"
				."Content-Transfer-Encoding: 8bit\r\n"
				."Content-Type: text/plain; charset=\"UTF-8\"\r\n";

			$sent = mail($email, "[$sitename] ".mem_self_gTxt('your_login_info'), $message, $emailbody);

			$mem_self['email_status'] = $sent;
			$mem_self['email_message'] = $message;

			if ($sent) {
				$cookietime = time() + (365*24*3600);
				setcookie("txp_self_registered", "1",  $cookietime, "/");

				$mem_self['status_message'] = mem_self_gTxt('password_sent_to').sp.$email;
			} else {
				// failed to send email
			}
		}
	} else {
		$mem_self['status_message'] = mem_self_gTxt('error_adding_new_author');
	}
}

// -------------------------------------------------------------
function self_register_email_message($atts)
{
	global $mem_self;
	return $mem_self['email_message'];
}

// -------------------------------------------------------------
function self_register_status_message($atts)
{
	global $mem_self;
	return $mem_self['status_message'];
}


// -------------------------------------------------------------
function if_message_sent($atts,$thing)
{
	global $mem_self;
	$condition = ($mem_self['email_status']);
	return parse(EvalElse($thing, $condition));
}

// -------------------------------------------------------------
function if_self_registered($atts,$thing)
{
	global $mem_self,$txp_user;
	$condition = ($mem_self['status'] or $mem_self['form_valid'] or !empty($_COOKIE['txp_self_registered']) or (isset($txp_user) and !empty($txp_user)) );
	return parse(EvalElse($thing, $condition));
}

// added to txplib_misc
if (!function_exists('is_valid_email')) {
function is_valid_email($email)
{
	$addr = explode('@',$email);

	$host = $addr[1];

	if ($host != gethostbyname($host) and eregi("^[0-9a-z]([-_.~]?[0-9a-z])*$",$addr[0]))
		return true;

	return false;
}
}

function is_valid_form()
{
	extract(doSlash(psa(array('name','email','username','mem_self_register'))));

	$name = trim($name);
	$email = trim($email);
	$username = trim($username);

	if ($mem_self_register=='register') {
		if (!(empty($name) || empty($username) || empty($email)) && is_valid_email($email)) {
			return true;
		}
	}

	return false;
}



////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////
// User Side Profile and Password Change Forms
// -------------------------------------------------------------
function mem_change_password_form($atts,$thing='')
{
	return mem_change_pass_form($atts,$thing);
}
function mem_change_pass_form($atts,$thing='')
{
	global $ign_user,$txp_user,$sitename,$mem_profile;

	extract(lAtts(array(
		'class'		=> 'mem_password_form',
		'wraptag'	=> '',
		'form'		=> '',
		'form_mail'	=> ''
	),$atts));

	$out = '';

	if (isset($ign_user)) $txp_user = $ign_user;

	$step = gps('step');

	if (isset($step) && $step=='mem_change_pass') {
		$new_pass = gps('new_pass');

		$rs = safe_update(
			mem_get_user_table_name(),
			"pass = password(lower('$new_pass'))",
			"name='$txp_user'"
		);

		if ($rs) {

			// successful
			$mem_profile = safe_row('*',mem_get_user_table_name(),"name = '{$txp_user}'");

			if ($mem_profile) {
				$mem_profile['new_pass'] = $new_pass;

				if (!empty($form_mail))
					$message = fetch_form($form_mail);
				if (empty($message)) {
					$message = mem_self_gTxt('greeting').' <txp:mem_realname />,'."\r\n".
						mem_self_gTxt('your_password_is').": <txp:mem_password />\r\n"."\r\n".
						mem_self_gTxt('log_in_at').' '.hu.'textpattern/index.php';
				}

				$vals = array(
					'realname'	=>	$mem_profile['RealName'],
					'password'	=>	$mem_profile['new_pass'],
				);

				foreach ($vals as $a=>$b) {
					$message = str_replace('<txp:mem_'.$a.' />',$b,$message);
				}

				$message = parse($message);

				// email password
				if (txpMail($mem_profile['email'], "[$sitename] ".mem_self_gTxt('your_new_password'), $message))
					$out = mem_self_gTxt('password_changed');
				else
					$out = mem_self_gTxt('password_change_failed');
			} else return mysql_error();
		} else {
			return mysql_error();
		}
	} else {
		$Form = $thing;
		if (!empty($form))
			$Form = fetch_form($form);
		if (empty($Form)) {
			$Form = "<h3>Change Password</h3><div><txp:mem_password_input /><txp:mem_submit /></div>";
		}
		$out = 	"<form action='{$_SERVER['REQUEST_URI']}' method='post'>".
				parse($Form).
				eInput('mem_user_workspace').sInput('mem_change_pass').
				"</form>";

//				graf(mem_self_gTxt('new_password').' '.fInput('password','new_pass','','edit','','','20','1').

	}

	return $out;
}

// -------------------------------------------------------------
function mem_user_edit_form($atts, $thing)
{
	global $txpcfg,$txp_user,$ign_user,$mem_profile;

	if (isset($ign_user)) $txp_user = $ign_user;

	extract(lAtts(array(
		'class'		=> 'mem_uedit_form',
		'wraptag'	=> '',
		'form'		=> ''
		), $atts));

	$out = '';
	$message = '';

	$step = gps('step');
	$new_pass = gps('new_pass');

	if (isset($step) && $step=='save_user_profile') {
		extract(gpsa(array('email','name','RealName','address','phone')));

		$xtra = mem_get_extra_user_columns_insert_string();

		$rs = safe_update(mem_get_user_table_name(),
			"email = '{$email}', RealName = '{$RealName}'" . $xtra,
			"name = '{$txp_user}'");

		if ($rs) {
			$message = mem_self_gTxt('saved_user_profile');
		} else {
			$message = mysql_error();
		}
	}

	$mem_profile = safe_row('*',mem_get_user_table_name(),"name = '{$txp_user}'");

	if ($mem_profile) {
		$Form = $thing;
		if (!empty($form))
			$Form = fetch_form($form);

		$Form = eregi_replace('<txp:mem_message />',$message,$Form);

		$out = 	"<form action='{$_SERVER['REQUEST_URI']}' method='post'>".
				parse($Form).
				eInput('mem_user_workspace').sInput('save_user_profile').
				"</form>";
	}

	return doTag($out,$wraptag,$class);
}

function mem_profile($atts)
{
	global $mem_profile,$txp_user,$ign_user;

	if (isset($ign_user)) $txp_user = $ign_user;

	extract($atts);
	if (!is_array($mem_profile) && $txp_user)
		$mem_profile = safe_row('*',mem_get_user_table_name(),"name = '{$txp_user}'");

	if ($mem_profile)
		return array_key_exists($var,$mem_profile) ? $mem_profile[$var] : '';
	return '';
}
function mem_submit($atts)
{
	extract($atts);
	$class = isset($class) ? $class : 'smallerbox';
	$value = isset($value) ? $value : mem_self_gTxt('save');
	return fInput("submit",'save',htmlspecialchars($value),$class);
}
function mem_password_input($atts)
{
	global $mem_profile;
	extract($atts);
	$isize = isset($isize) ? $isize : 20;
	$class = isset($class) ? $class : 'edit';

	return fInput('password','new_pass','',$class);
}
function mem_realname_input($atts)
{
	global $mem_profile;
	extract($atts);
	$isize = isset($isize) ? $isize : 20;
	$class = isset($class) ? $class : 'edit';

	return fInput('text','RealName',htmlspecialchars($mem_profile['RealName']),$class);
}
function mem_email_input($atts)
{
	global $mem_profile;
	extract($atts);
	$isize = isset($isize) ? $isize : 20;
	$class = isset($class) ? $class : 'edit';

	return fInput('text','email',htmlspecialchars($mem_profile['email']),$class);
}
function mem_phone_input($atts)
{
	global $mem_profile;
	extract($atts);
	$isize = isset($isize) ? $isize : 20;
	$class = isset($class) ? $class : 'edit';

	return fInput('text','phone',htmlspecialchars($mem_profile['phone']),$class);
}
function mem_address_input($atts)
{
	global $mem_profile;
	extract($atts);
	$isize = isset($isize) ? $isize : 20;
	$class = isset($class) ? $class : 'edit';

	return '<textarea class="'.$class.'" name="address">'.htmlspecialchars($mem_profile['address']).'</textarea>';
}

function mem_self_user_count($atts)
{
	global $mem_self;

	extract(lAtts(array(
		'user_levels'	=> '0,1,2,3,4,5,6',
		'wraptag'	=> '',
		'class'		=> ''
	),$atts));

	if (!empty($user_levels) || $user_levels=='0')
		$user_levels = doSlash(split(',',$user_levels));
	else
		$user_levels = array($mem_self['new_user_priv']);

	$levels = join(',',$user_levels);
	$count = safe_field('COUNT(*)', mem_get_user_table_name(), "privs IN ({$levels})");

	return doTag($count,$wraptag,$class);
}
";s:3:"md5";s:32:"3ad880ab22f3caff1d083f1ad6118f05";}

TextPattern строить и жить помогает! Кстати, пишу плагины на заказ. ICQ 155-08-081. В асю, пожалуйста, по поводу заказов или платных консультаций (10$ час). Остальные вопросы в форум или на почту.

Неактивен

 

#7 07-12-2007 19:52:13

snowman
добро
Зарегистрирован: 11-03-2007
Сообщений: 41

Re: mem_self_register

Ну, вот хороший же плагин! Черт, ну почему не могу с ним совладать? Уже устал биться головой об стенку!!! Как бы я не ухищрялся, он у меня всеравно упорно регистрирует новых пользователей с привелегией "нет" вместо, например, "штатный писатель" или "внештатник"... Из-за этого плагином пользоваться просто не возможно - пропадает весь смысл. Ведь человек не сможет залогинится, пока я сам ему из админки не поменяю статус...

О том, что я выставлял эти опции в настройках, думаю и упоминать не стоит, я даже пытался ковырять сам код плагина, но это было на интуитивном уровне, ведь я совсем не знаю РНР... Люди добрые! Помогите. Может вы подскажете как заставить этот плагин забыть об уровне пользователей "нет" ( levels 0 ) ??

Если неохота ставить плагин, то вот код:

Код:

////////////////////////////////////////////////////////////
// Plugin mem_self_register
// Author: Michael Manfre (http://manfre.net/)
////////////////////////////////////////////////////////////

if (!function_exists('mem_set_pref')) {
    function mem_set_pref($name, $val, $event,  $type, $position=0, $html='text_input')
    {
        global $pref_cache;

        if ($pref_cache==null)
            $pref_cache = array();

        $args = func_get_args();
        $args['html'] = $html;
        $args['position'] = $position;
        $args['prefs_id'] = 1;

        $pref_cache[$name] = $args;

        extract(doSlash($args));

        if (!safe_row("*", 'txp_prefs', "name = '$name'") ) {
            return safe_insert('txp_prefs', "
                name  = '$name',
                val   = '$val',
                event = '$event',
                html  = '$html',
                type  = '$type',
                position = '$position',
                prefs_id = 1"
            );
        } else {
            return safe_update(    'txp_prefs', "
                                    val   = '$val',
                                    event = '$event',
                                    html  = '$html',
                                    type  = '$type',
                                    position = '$position'",
                                "name like '$name'");
        }
        return false;
    }
}

if (!function_exists('mem_get_pref')) {
    function mem_get_pref($name,$val='')
    {
        global $pref_cache;

        if ($pref_cache==null)
            $pref_cache = array();

        if (!in_array($name,$pref_cache) or $pref_cache[$name] === false) {
            $pref_cache[$name] = safe_row('*','txp_prefs',"name='$name'");
        } else {
            $pref_cache[$name] = false;
        }

        if (!empty($val) && in_array($val,$pref_cache[$name]))
            return $pref_cache[$name][$val];
        else
            return $pref_cache[$name];
    }
}

global $mem_self_lang;

if (!is_array($mem_self_lang))
{
    $mem_self_lang = array(
        'your_login_info'    =>    'Your Login Info',
        'admin_name'        =>    'Admin Name',
        'admin_email'        =>    'Admin Email',
        'password_sent_to'    =>    'Password Sent To',
        'error_adding_new_author'    =>    'Error adding new author',
        'greeting'            =>    'Hello',
        'your_password_is'    =>    'Your password is',
        'your_new_password'    =>    'Your new password',
        'password_changed'    =>    'Password changed',
        'password_change_failed'    =>    'Failed to change password',
        'log_in_at'            =>    'Log in at',
        'saved_user_profile'    =>    'Saved User Profile',
        'user_exists'        =>    'Username already exists. Please try another name',
    );
}

function mem_self_gTxt($name)
{
    global $mem_self_lang;

    $gtxt = gTxt($name);

    if ( strcmp($gtxt,$name) == 0 )
    {
        if ( array_key_exists($name,$mem_self_lang) )
            $gtxt = $mem_self_lang[$name];
    }

    return $gtxt;
}

global $event;

if (!isset($event)) $event = '';

if ($event != 'admin') {
    require_once txpath.'/include/txp_admin.php';

    global $levels;

    // copied from txp_admin.php
    $levels = array(
        0 => mem_self_gTxt('none'),
        6 => mem_self_gTxt('designer'),
        5 => mem_self_gTxt('freelancer'),
        4 => mem_self_gTxt('staff_writer'),
        3 => mem_self_gTxt('copy_editor'),
        2 => mem_self_gTxt('managing_editor'),
        1 => mem_self_gTxt('publisher')
    );

//-------------------------------------------------------------
    if (!function_exists('priv_levels')) {
        function priv_levels($item, $var) {
            global $levels;

            return selectInput($item, $levels, $var);
        }
    }
}


global $mem_self;

$mem_self = array(
                'admin_email'        =>    '',
                'admin_name'        =>    '',
                'new_user_priv'        =>    '0',
                'status'            =>    false,
                'status_message'    =>    'You are already registered.',
                'email_message'        =>    ''
            );

$mem_self['admin_email'] = mem_get_pref('mem_self_admin_email','val'); //safe_field('val','txp_prefs',"name='mem_self_admin_email'");
$mem_self['admin_name'] = mem_get_pref('mem_self_admin_name','val'); //safe_field('val','txp_prefs',"name='mem_self_admin_name'");
$mem_self['new_user_priv'] = mem_get_pref('mem_self_new_user_priv','val'); //safe_field('val','txp_prefs',"name='mem_self_new_user_priv'");

if ( @txpinterface == 'admin' ) {
    register_callback('mem_self_register','self-reg','', 1);
    if ($event=='self-reg') {
        // fake tabs when using them. Silences warnings from pageTop()
        register_tab('admin','self-reg','self-reg');

        include_once txpath.'/publish/taghandlers.php';
    }

    function mem_self_register($event, $step) {
        if ($event!='self-reg')
            return;

        pageTop('Self Registration','');

        if ($step == 'install') {
            echo mem_self_register_install();
        } else if ($step=='preinstall') {
            $mem_admin_name    = mem_get_pref('mem_self_admin_name');
            $mem_admin_email    = mem_get_pref('mem_self_admin_email');
            $mem_new_user_priv    = mem_get_pref('mem_self_new_user_priv');
            $mem_use_ign_db    = mem_get_pref('mem_self_use_ign_db');
            $mem_xtra_columns    = mem_get_extra_user_columns();

            $mem_admin_name = @$mem_admin_name ? $mem_admin_name['val'] : 'Admin';
            $mem_admin_email = @$mem_admin_email ? $mem_admin_email['val'] : 'Admin@yourdomain.com';
            $mem_new_use_priv = @$mem_new_use_priv ? $mem_new_use_priv['val'] : '0';

            $use_ign_input = '';
            // is ign_password_protect loaded on the system?
            if (load_plugin('ign_password_protect') || $mem_use_ign_db) {
                $mem_use_ign_db = $mem_use_ign_db ? $mem_use_ign_db['val'] : '0';
                $use_ign_input = yesnoradio('use_ign_db',$mem_use_ign_db);
            }

            $xtra_columns = mem_get_extra_user_columns();
            $has_address = in_array('address',$xtra_columns);
            $has_phone = in_array('phone',$xtra_columns);

            $add_address_input = yesnoradio('add_address','0');
            $add_phone_input = yesnoradio('add_phone','0');

            echo form(
                eInput('self-reg').sInput('install').
                startTable('edit') .
                    tr( fLabelCell('admin_name')    . tda(fInput('text','admin_name',$mem_admin_name,'edit')) ) .
                    tr( fLabelCell('admin_email')    . tda(fInput('text','admin_email',$mem_admin_email,'edit')) ) .
                    tr( fLabelCell('new_user_priv')    . tda(priv_levels('new_user_priv',$mem_new_use_priv)) ) .
                    tr( fLabelCell('use_ign_db')    . tda($use_ign_input) ) .
                    ($has_address ? '' : tr( fLabelCell('add_address_field') . tda($add_address_input) ) ) .
                    ($has_phone ? '' : tr( fLabelCell('add_phone_field') . tda($add_phone_input) ) ) .
                    tr( td() . td( fInput("submit", 'submit',mem_self_gTxt('install'),"Publish"), 2 ) ) .
                endTable()
                );
        } else {
            echo '<div><a href="?event=self-reg&step=preinstall">'.mem_self_gTxt('install').'</a></div>';
        }
    }


    function mem_self_register_install() {
        global $mem_self;

        extract(doSlash(gpsa(array(
            'admin_email',
            'admin_name',
            'new_user_priv',
            'use_ign_db',
            'add_address',
            'add_phone'
        ))));

        if (!isset($new_user_priv) || empty($new_user_priv)) $new_user_priv = '0';

        $log = array();

        if (!($rs=safe_field('val,html','txp_prefs',"name='mem_self_use_ign_db'"))) {
            if ( mem_set_pref('mem_self_use_ign_db',$use_ign_db,'self_reg',1,'yesnoradio')) {
                $log[] = "Added pref 'mem_self_use_ign_db'";
            } else {
                $log[] = "Failed to add pref 'mem_self_use_ign_db'. " . mysql_error();
            }
        } else {
            if ($rs['html'] != 'yesnoradio') {
                safe_update('txp_prefs',"html='yesnoradio'","name='mem_self_use_ign_db'");
            }
            $log[] = "Pref 'mem_self_use_ign_db' is already installed. Current value is '{$rs}'.";
        }

        $user_table = mem_get_user_table_name();

        $xtra_columns = mem_get_extra_user_columns();
        if ($add_address) {
            if (!in_array('address',$xtra_columns)) {
                if (safe_alter($user_table,"ADD `address` VARCHAR( 128 )")) {
                    $log[] = "Added column 'address' to user table '{$user_table}'";
                } else {
                    $log[] = "Failed to add column 'address' to user table '{$user_table}'. " . mysql_error();
                }
            } else {
                $log[] = "Table {$user_table} already has column 'address'";
            }
        }
        if ($add_phone) {
            if (!in_array('phone',$xtra_columns)) {
                if (safe_alter($user_table,"ADD `phone` VARCHAR( 32 )")) {
                    $log[] = "Added column 'phone' to user table '{$user_table}'";
                } else {
                    $log[] = "Failed to add column 'phone' to user table '{$user_table}'. " . mysql_error();
                }
            } else {
                $log[] = "Table {$user_table} already has column 'phone'";
            }
        }

        if (!($rs=safe_field('val','txp_prefs',"name='mem_self_admin_email'"))) {
            if ( mem_set_pref('mem_self_admin_email',$admin_email,'self_reg',1)) {
                $log[] = "Added pref 'mem_self_admin_email'";
            } else {
                $log[] = "Failed to add pref 'mem_self_admin_email'. " . mysql_error();
            }
        } else {
            $log[] = "Pref 'mem_self_admin_email' is already installed. Current value is '{$rs}'.";
        }
        if (!($rs=safe_field('val','txp_prefs',"name='mem_self_admin_name'"))) {
            if ( mem_set_pref('mem_self_admin_name',$admin_name,'self_reg',1)) {
                $log[] = "Added pref 'mem_self_admin_name'";
            } else {
                $log[] = "Failed to add pref 'mem_self_admin_name'. " . mysql_error();
            }
        } else {
            $log[] = "Pref 'mem_self_admin_name' is already installed. Current value is '{$rs}'.";
        }
        if (($rs=safe_field('val,html','txp_prefs',"name='mem_self_new_user_priv'")) === false) {
            if ( mem_set_pref('mem_self_new_user_priv',$new_user_priv,'self_reg',1,'priv_levels')) {
                $log[] = "Added pref 'mem_self_new_user_priv' with value of '{$new_user_priv}'";
                $mem_self['new_user_priv'] = $new_user_priv;
            } else {
                $log[] = "Failed to add pref 'mem_self_newuser_priv'. " . mysql_error();
            }
        } else {
            if ($rs['html'] != 'priv_levels')
                safe_update('txp_prefs',"html='priv_levels'","name='mem_self_new_user_priv'");

            $log[] = "Pref 'mem_self_new_user_priv' is already installed. Current value is '{$rs}'.";
        }

        // create default registration form
        $form_html = <<<EOF
<table>
<tr>
    <td>Full Name</td>
    <td><txp:mem_name_input /></td>
    <td><txp:mem_name_warn /></td>
</tr>
<tr>
    <td>Username</td>
    <td><txp:mem_user_input /></td>
    <td><txp:mem_user_warn /></td>
</tr>
<tr>
    <td>Email</td>
    <td><txp:mem_email_input /></td>
    <td><txp:mem_email_warn /></td>
</tr>
<tr>
    <td colspan="3"><txp:mem_submit /></td>
</tr>
</table>
EOF;

        $form = fetch('Form','txp_form','name','self_register_form');
        if (!$form) {
            if (safe_insert('txp_form',"name='self_register_form',type='misc',Form='{$form_html}'")) {
                $log[] = "Added form 'self_register_form'";
            } else {
                $log[] = "Failed to add form 'self_register_form'. " . mysql_error().br.
                    "You need to manually create a form template. Here is an example.".br.
                    '<textpattern style="width:300px;height:150px;">'.htmlspecialchars($form_html).'</textarea>';
            }
        } else {
            $log[] = "Found form 'self_register_form'. Skipping installation of default form.";
        }

        // create default successful registration form to show the user
        $form_html = <<<EOF
<h3>Account Created</h3>
<p>An email containing your password has been sent to <txp:mem_profile var="email" />.</p>
EOF;

        $form = fetch('Form','txp_form','name','self_register_success');
        if (!$form) {
            if (safe_insert('txp_form',"name='self_register_success',type='misc',Form='{$form_html}'")) {
                $log[] = "Added form 'self_register_success'";
            } else {
                $log[] = "Failed to add form 'self_register_success'. " . mysql_error().br.
                    "You need to manually create a form template. Here is an example.".br.
                    '<textpattern style="width:300px;height:150px;">'.htmlspecialchars($form_html).'</textarea>';
            }
        } else {
            $log[] = "Found form 'self_register_success'. Skipping installation of default form.";
        }

        // create default successful registration email form
        $form_html = <<<EOF
Dear <txp:mem_name />,

Thank you for registering at <txp:mem_siteurl />.

Your login name: <txp:mem_username />
Your password: <txp:mem_password />

If you have any questions please reply to this email address.

Sincerely,
<txp:mem_admin_name />
<txp:mem_admin_email />
EOF;

        $form = fetch('Form','txp_form','name','self_register_email');
        if (!$form) {
            if (safe_insert('txp_form',"name='self_register_email',type='misc',Form='{$form_html}'")) {
                $log[] = "Added form 'self_register_email'";
            } else {
                $log[] = "Failed to add form 'self_register_email'. " . mysql_error().br.
                    "You need to manually create a form template. Here is an example.".br.
                    '<textpattern style="width:300px;height:150px;">'.htmlspecialchars($form_html).'</textarea>';
            }
        } else {
            $log[] = "Found form 'self_register_form'. Skipping installation of default form.";
        }

        $tag_help = '<txp:mem_self_register_form form="self_register_form" />';
        $log[] = 'Example tag to use in your page template.'.br.
            '<textarea style="width:400px;height:40px;">'.htmlspecialchars($tag_help).'</textarea>';

        return doWrap($log,'ul','li');
    }
}

function mem_get_user_table_name() {
    $use_ign_db = mem_get_pref('mem_self_use_ign_db');

    $table_name = 'txp_users';

    if ($use_ign_db) {
        $ign_use_custom = mem_get_pref('ign_use_custom');
        if ($ign_use_custom && $ign_use_custom['val']=='1') {
            $ign_user_db = mem_get_pref('ign_user_db');
            if ($ign_user_db && !empty($ign_user_db['val']))
                $table_name = $ign_user_db['val'];
        }
    }
    return $table_name;
}

// -------------------------------------------------------------
function mem_self_register_form($atts,$thing='')
{
    global $txpac;

    $namewarn = $userwarn = $emailwarn = '';

    extract(doSlash(psa(array('event','step','name','email','username','address','phone','mem_self_register'))));

    extract(lAtts(array(
        'class'        => __FUNCTION__,
        'form'        => 'self_register_form',
        'success_form'    => 'self_register_success',
        'email_form'    => 'self_register_email',
        'wraptag'    => '',
        'isize'        => '25',
        'label'        => mem_self_gTxt('submit'),
        'namewarn'    => mem_self_gTxt('name_required'),
        'userwarn'    => mem_self_gTxt('user_required'),
        'emailwarn'    => mem_self_gTxt('email_required'),
    ),$atts));

    $name = trim($name);
    $username = trim($username);
    $email = trim($email);
    $phone = trim($phone);
    $address = trim($address);

    $saved = false;

    if ($event=='self-reg' && $step=='register') {
        if (!is_valid_form()) {
            $namewarn = empty($name) ? $namewarn : '';
            $userwarn = empty($username) ? $userwarn : '';
            // if all fields are non empty, then the email address failed for some reason.
            $emailwarn = empty($email) ? $emailwarn : (empty($namewarn) and empty($userwarn) ? $emailwarn : '');
        } else {

            $rs = safe_field('name',mem_get_user_table_name(),"name='{$username}'");

            if (empty($rs)) {
                mem_self_register_save();
                $saved = true;
            } else {
                // don't change $userwarn
                $namewarn = $emailwarn = '';
            }
        }
    } else {
        // don't show the warnings
        $namewarn = '';
        $userwarn = '';
        $emailwarn = '';
    }

    if (@$saved) {
        $Form = fetch_form($success_form);
        $out = parse($Form);
    } else {

        $Form = fetch_form($form);

        $vals = array(
            'name_warn'        => $namewarn,
            'user_warn'        => $userwarn,
            'email_warn'    => $emailwarn,
            'name_input'    => fInput('text','name',  $name, 'register_name_input','','',$isize,"0", 'mem_name_input'),
            'user_input'    => fInput('text','username', $username, 'register_user_input', '', '', $isize, "0", 'mem_user_input'),
            'email_input'    => fInput('text','email', $email,'register_email_input','','',$isize,"0", 'mem_email_input'),
            'submit'        => fInput('submit','submit',mem_self_gTxt($label),'button'),
            'phone_input'    => fInput('text','phone', $phone, 'register_phone_input', '', '', $isize, "0", 'mem_phone_input'),
            'address_input'    => fInput('text','address', $address, 'register_address_input', '', '', $isize, "0", 'mem_address_input'),
        );

        foreach ($vals as $a=>$b) {
            $Form = str_replace('<txp:mem_'.$a.' />',$b,$Form);
        }

        $action_url = $_SERVER['REQUEST_URI'];
        $qs = strpos($action_url,'?');
        if ($qs) $action_url = substr($action_url, 0, $qs);

        $out =    n.n."<form enctype='multipart/form-data' action='{$action_url}' method='post'>" .
                eInput('self-reg') . sInput('register') . hInput('email_form',$email_form) . hInput('mem_self_register','register') .
                parse($Form) .
                "</form>".n;
    }

    return doTag($out,$wraptag,$class);

}

function mem_get_extra_user_columns_insert_string() {
    $xtra_columns = mem_get_extra_user_columns();

    $xtra = '';

    foreach ($xtra_columns as $xcol) {
        $name = $xcol['Field'];
        $type = strtolower($xcol['Type']);
        $val = gps($name);

        if ( strstr($type,'int')
                || $type=='float'
                || $type=='decimal'
                || $type=='double'
                || $type=='bool' ) {
            // don't quote value
            $xtra .= ", {$name}=" . doSlash($val);
        } else {
            // quote value
            $xtra .= ", {$name}='" . doSlash($val) ."'";
        }
    }

    return $xtra;
}

function mem_get_extra_user_columns()
{
    static $default_columns = array('user_id','name','pass','RealName','email','privs','last_access','nonce');
    static $xtra_columns = false;

    if (is_array($xtra_columns))
        return $xtra_columns;

    $table_name = mem_get_user_table_name();
    $txpdesc = getRows('describe '.PFX. $table_name);

    $xtra_cols = array();

    $dcols = $default_columns;

    foreach($txpdesc as $r) {
        if ( !in_array($r['Field'], $default_columns) )
            $xtra_cols[] = $r;
    }

    return $xtra_cols;
}

// -------------------------------------------------------------
function mem_self_register_save()
{
    global $mem_self,$sitename,$mem_profile;

    extract(doSlash(psa(array('name','email','username','email_form','address','phone','mem_self_register','login_url'))));
    extract($mem_self);

    if ($mem_self_register != 'register') return '';

    $pw = generate_password(6);

    if (!$mem_profile) $mem_profile = array();

    $mem_profile['nonce'] = $nonce = md5( uniqid( rand(), true ) );

    $mem_profile['RealName'] = $name = trim($name);
    $mem_profile['email'] = $email = trim($email);
    $mem_profile['name'] = $username = trim($username);
    $mem_profile['privs'] = $new_user_priv;

    $xtra_columns = mem_get_extra_user_columns();

    foreach($xtra_columns as $c) {
        $c_name = trim( $c['Field'] );

        $mem_profile[$c_name] = gps($c_name);
    }

    $rs = false;

    $xtra = mem_get_extra_user_columns_insert_string();

    $rs = safe_insert(
        mem_get_user_table_name(),
        "privs    = '$new_user_priv',
         name     = '$username',
         email    = '$email',
         RealName = '$name',
         pass     =  password(lower('$pw')),
         nonce    = '$nonce'" . $xtra
    );

    if ($rs) {
        $mem_profile['user_id'] = $rs;
        $mem_profile['last_access'] = 0;

        if ($email_form) {
            $message = fetch('Form','txp_form','name',$email_form);

            if (is_array($admin_name))
                $admin_name = $admin_name['val'];
            if (is_array($admin_email))
                $admin_email = $admin_email['val'];

            if (empty($login_url))
                $login_url = rtrim(hu,'/').'/textpattern/index.php';

            $vals = array(
                'admin_name'    =>    $admin_name,
                'admin_email'    =>    $admin_email,
                'name'        =>    $name,
                'username'    =>    $username,
                'email'        =>    $email,
                'password'    =>    $pw,
                'sitename'    =>    $sitename,
                'loginurl'    =>    $login_url,
                'siteurl'    =>    hu,
                'address'    =>    $address,
                'phone'        =>    $phone
            );

            foreach ($vals as $a=>$b) {
                @$message = str_replace('<txp:mem_'.$a.' />',$b,$message);
            }

            $message = parse($message);

            $emailbody = "From: {$admin_name} <{$admin_email}>\r\n"
                ."Bcc: {$admin_email}\r\n"
                ."Reply-To: {$admin_email}\r\n"
                ."Content-Transfer-Encoding: 8bit\r\n"
                ."Content-Type: text/plain; charset=\"UTF-8\"\r\n";

            $sent = mail($email, "[$sitename] ".mem_self_gTxt('your_login_info'), $message, $emailbody);

            $mem_self['email_status'] = $sent;
            $mem_self['email_message'] = $message;

            if ($sent) {
                $cookietime = time() + (365*24*3600);
                setcookie("txp_self_registered", "1",  $cookietime, "/");

                $mem_self['status_message'] = mem_self_gTxt('password_sent_to').sp.$email;
            } else {
                // failed to send email
            }
        }
    } else {
        $mem_self['status_message'] = mem_self_gTxt('error_adding_new_author');
    }
}

// -------------------------------------------------------------
function self_register_email_message($atts)
{
    global $mem_self;
    return $mem_self['email_message'];
}

// -------------------------------------------------------------
function self_register_status_message($atts)
{
    global $mem_self;
    return $mem_self['status_message'];
}


// -------------------------------------------------------------
function if_message_sent($atts,$thing)
{
    global $mem_self;
    $condition = ($mem_self['email_status']);
    return parse(EvalElse($thing, $condition));
}

// -------------------------------------------------------------
function if_self_registered($atts,$thing)
{
    global $mem_self,$txp_user;
    $condition = ($mem_self['status'] or $mem_self['form_valid'] or !empty($_COOKIE['txp_self_registered']) or (isset($txp_user) and !empty($txp_user)) );
    return parse(EvalElse($thing, $condition));
}

// added to txplib_misc
if (!function_exists('is_valid_email')) {
function is_valid_email($email)
{
    $addr = explode('@',$email);

    $host = $addr[1];

    if ($host != gethostbyname($host) and eregi("^[0-9a-z]([-_.~]?[0-9a-z])*$",$addr[0]))
        return true;

    return false;
}
}

function is_valid_form()
{
    extract(doSlash(psa(array('name','email','username','mem_self_register'))));

    $name = trim($name);
    $email = trim($email);
    $username = trim($username);

    if ($mem_self_register=='register') {
        if (!(empty($name) || empty($username) || empty($email)) && is_valid_email($email)) {
            return true;
        }
    }

    return false;
}



////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////
// User Side Profile and Password Change Forms
// -------------------------------------------------------------
function mem_change_password_form($atts,$thing='')
{
    return mem_change_pass_form($atts,$thing);
}
function mem_change_pass_form($atts,$thing='')
{
    global $ign_user,$txp_user,$sitename,$mem_profile;

    extract(lAtts(array(
        'class'        => 'mem_password_form',
        'wraptag'    => '',
        'form'        => '',
        'form_mail'    => ''
    ),$atts));

    $out = '';

    if (isset($ign_user)) $txp_user = $ign_user;

    $step = gps('step');

    if (isset($step) && $step=='mem_change_pass') {
        $new_pass = gps('new_pass');

        $rs = safe_update(
            mem_get_user_table_name(),
            "pass = password(lower('$new_pass'))",
            "name='$txp_user'"
        );

        if ($rs) {

            // successful
            $mem_profile = safe_row('*',mem_get_user_table_name(),"name = '{$txp_user}'");

            if ($mem_profile) {
                $mem_profile['new_pass'] = $new_pass;

                if (!empty($form_mail))
                    $message = fetch_form($form_mail);
                if (empty($message)) {
                    $message = mem_self_gTxt('greeting').' <txp:mem_realname />,'."\r\n".
                        mem_self_gTxt('your_password_is').": <txp:mem_password />\r\n"."\r\n".
                        mem_self_gTxt('log_in_at').' '.hu.'textpattern/index.php';
                }

                $vals = array(
                    'realname'    =>    $mem_profile['RealName'],
                    'password'    =>    $mem_profile['new_pass'],
                );

                foreach ($vals as $a=>$b) {
                    $message = str_replace('<txp:mem_'.$a.' />',$b,$message);
                }

                $message = parse($message);

                // email password
                if (txpMail($mem_profile['email'], "[$sitename] ".mem_self_gTxt('your_new_password'), $message))
                    $out = mem_self_gTxt('password_changed');
                else
                    $out = mem_self_gTxt('password_change_failed');
            } else return mysql_error();
        } else {
            return mysql_error();
        }
    } else {
        $Form = $thing;
        if (!empty($form))
            $Form = fetch_form($form);
        if (empty($Form)) {
            $Form = "<h3>Change Password</h3><div><txp:mem_password_input /><txp:mem_submit /></div>";
        }
        $out =     "<form action='{$_SERVER['REQUEST_URI']}' method='post'>".
                parse($Form).
                eInput('mem_user_workspace').sInput('mem_change_pass').
                "</form>";

//                graf(mem_self_gTxt('new_password').' '.fInput('password','new_pass','','edit','','','20','1').

    }

    return $out;
}

// -------------------------------------------------------------
function mem_user_edit_form($atts, $thing)
{
    global $txpcfg,$txp_user,$ign_user,$mem_profile;

    if (isset($ign_user)) $txp_user = $ign_user;

    extract(lAtts(array(
        'class'        => 'mem_uedit_form',
        'wraptag'    => '',
        'form'        => ''
        ), $atts));

    $out = '';
    $message = '';

    $step = gps('step');
    $new_pass = gps('new_pass');

    if (isset($step) && $step=='save_user_profile') {
        extract(gpsa(array('email','name','RealName','address','phone')));

        $xtra = mem_get_extra_user_columns_insert_string();

        $rs = safe_update(mem_get_user_table_name(),
            "email = '{$email}', RealName = '{$RealName}'" . $xtra,
            "name = '{$txp_user}'");

        if ($rs) {
            $message = mem_self_gTxt('saved_user_profile');
        } else {
            $message = mysql_error();
        }
    }

    $mem_profile = safe_row('*',mem_get_user_table_name(),"name = '{$txp_user}'");

    if ($mem_profile) {
        $Form = $thing;
        if (!empty($form))
            $Form = fetch_form($form);

        $Form = eregi_replace('<txp:mem_message />',$message,$Form);

        $out =     "<form action='{$_SERVER['REQUEST_URI']}' method='post'>".
                parse($Form).
                eInput('mem_user_workspace').sInput('save_user_profile').
                "</form>";
    }

    return doTag($out,$wraptag,$class);
}

function mem_profile($atts)
{
    global $mem_profile,$txp_user,$ign_user;

    if (isset($ign_user)) $txp_user = $ign_user;

    extract($atts);
    if (!is_array($mem_profile) && $txp_user)
        $mem_profile = safe_row('*',mem_get_user_table_name(),"name = '{$txp_user}'");

    if ($mem_profile)
        return array_key_exists($var,$mem_profile) ? $mem_profile[$var] : '';
    return '';
}
function mem_submit($atts)
{
    extract($atts);
    $class = isset($class) ? $class : 'smallerbox';
    $value = isset($value) ? $value : mem_self_gTxt('save');
    return fInput("submit",'save',htmlspecialchars($value),$class);
}
function mem_password_input($atts)
{
    global $mem_profile;
    extract($atts);
    $isize = isset($isize) ? $isize : 20;
    $class = isset($class) ? $class : 'edit';

    return fInput('password','new_pass','',$class);
}
function mem_realname_input($atts)
{
    global $mem_profile;
    extract($atts);
    $isize = isset($isize) ? $isize : 20;
    $class = isset($class) ? $class : 'edit';

    return fInput('text','RealName',htmlspecialchars($mem_profile['RealName']),$class);
}
function mem_email_input($atts)
{
    global $mem_profile;
    extract($atts);
    $isize = isset($isize) ? $isize : 20;
    $class = isset($class) ? $class : 'edit';

    return fInput('text','email',htmlspecialchars($mem_profile['email']),$class);
}
function mem_phone_input($atts)
{
    global $mem_profile;
    extract($atts);
    $isize = isset($isize) ? $isize : 20;
    $class = isset($class) ? $class : 'edit';

    return fInput('text','phone',htmlspecialchars($mem_profile['phone']),$class);
}
function mem_address_input($atts)
{
    global $mem_profile;
    extract($atts);
    $isize = isset($isize) ? $isize : 20;
    $class = isset($class) ? $class : 'edit';

    return '<textarea class="'.$class.'" name="address">'.htmlspecialchars($mem_profile['address']).'</textarea>';
}

function mem_self_user_count($atts)
{
    global $mem_self;

    extract(lAtts(array(
        'user_levels'    => '0,1,2,3,4,5,6',
        'wraptag'    => '',
        'class'        => ''
    ),$atts));

    if (!empty($user_levels) || $user_levels=='0')
        $user_levels = doSlash(split(',',$user_levels));
    else
        $user_levels = array($mem_self['new_user_priv']);

    $levels = join(',',$user_levels);
    $count = safe_field('COUNT(*)', mem_get_user_table_name(), "privs IN ({$levels})");

    return doTag($count,$wraptag,$class);
}

Неактивен

 

#8 07-12-2007 20:25:41

snowman
добро
Зарегистрирован: 11-03-2007
Сообщений: 41

Re: mem_self_register

Дамы и господа! Всё отменяется! smile Ларчик, оказывается, сука просто открывался! Потратил 3 часа мучая этот плагин, потом погуглил, на считанные минуты нашел и поставил новую версию плагина ( 0.8.5 вместо той 0.8.3 что в этом топике) и плагин стал как родной! ))))) всё работает

Неактивен

 

#9 08-12-2007 20:02:03

Evgeny
ять
Зарегистрирован: 15-03-2005
Сообщений: 1869

Re: mem_self_register

snowman написал:

погуглил, на считанные минуты нашел и поставил новую версию плагина ( 0.8.5 вместо той 0.8.3 что в этом топике) и плагин стал как родной! ))))) всё работает

Кинь ссылку на свежую версию, пожалуйста.

Неактивен

 

#10 08-12-2007 20:05:54

AngryCAT
ферт
Откуда: Германия
Зарегистрирован: 18-04-2006
Сообщений: 486
Вебсайт

Re: mem_self_register

На сайте автора всё лежит


TextPattern строить и жить помогает! Кстати, пишу плагины на заказ. ICQ 155-08-081. В асю, пожалуйста, по поводу заказов или платных консультаций (10$ час). Остальные вопросы в форум или на почту.

Неактивен

 

#11 10-12-2007 15:15:57

snowman
добро
Зарегистрирован: 11-03-2007
Сообщений: 41

Re: mem_self_register

AngryCAT написал:

На сайте автора всё лежит

да, всё верно. Оттуда брал

Неактивен

 

#12 31-07-2008 12:40:58

deXes
буки
Зарегистрирован: 30-07-2008
Сообщений: 7

Re: mem_self_register

А я не догнал, как его установить sad Нету руководства хотя бы на английском? Я только начал изучать TP и вот решил сначала обхавестись всеми необходимыми плагинами, а потом сверастать smile Я вот скопировал этот код в окошко на странице плагинов, применил. Зашел на сайт, а там вот такая строка:

При загрузке модуля произошла ошибка: mem_self_register -> User_Error: Unable to include required plugin "mem_form" on line 448

Как я понял надо еще дорабатывать код шаблонов или создать файл с формой smile

Неактивен

 

#13 08-01-2009 10:33:47

Calm
добро
Зарегистрирован: 03-01-2009
Сообщений: 41

Re: mem_self_register

Чтобы mem_self_register применять, надо установить плагин mem_form.

Пытаюсь использовать mem_self_register версии 0.9.1. Документация действительно отстойная. Упоминаются тэги, которых в коде нет. Видимо в хелпе остались следы прошлых версий. На сайте автора плагина и вовсе написано - смотрите хелп в админке.

Неактивен

 

#14 03-06-2009 21:33:41

Xeon
глаголь
Зарегистрирован: 03-06-2009
Сообщений: 36

Re: mem_self_register

Отбой тревоги, справился сам ^_^

Отредактированно Xeon (03-06-2009 21:39:48)

Неактивен

 

#15 03-06-2009 21:56:36

Xeon
глаголь
Зарегистрирован: 03-06-2009
Сообщений: 36

Re: mem_self_register

А, нет, оказывается не справился, при поптыки устоновить плагин mem_form
http://manfre.net/file_download/32
cms мне пишет: "Неправильно оформленный или пустой код плагина"
В чём может быть проблемма?
UPD:
Плагин установил, оба запустились и работают тольо вот форма для реги на странице не появилась... Что ещё нужно сделать?
Пониманию что надо вставить код форм на страницу но какой именно и куда что бы всё работалло правильно не знаю...

Отредактированно Xeon (03-06-2009 22:14:04)

Неактивен

 

#16 31-08-2009 22:25:27

Gerich
земля
Зарегистрирован: 07-09-2008
Сообщений: 100

Re: mem_self_register

Вот этот код нужно вставить в нужном месте страницы. Также после установки плагина были созданы три формы, которые можно редактировать.

Код:

<txp:mem_self_register_form form="self_register_form" email_form="self_register_email" subject="[site.ru] Информация о вашем аккаунте" />

Неактивен

 

#17 22-09-2009 13:27:58

itshaman
слово
Откуда: Омск
Зарегистрирован: 03-06-2009
Сообщений: 395
Вебсайт

Re: mem_self_register

Gerich можно поподробнее. После установки двух нужных плагинов у меня не добавились две формы.
Если Вы устанавливали, можете ли Вы описать процесс установки.

Приведенный Вами код у меня не выводит ничего

Xeon
Скачайте не *.txt, а *.gz.txt
Уменя добавилось

Отредактированно itshaman (22-09-2009 13:29:25)


Помогу сделать Ваш сайт лучше! Принимаю Webmoney, PayPal, рубли, доллары, печеньки

Неактивен

 

#18 07-11-2009 20:12:53

retroman
веди
Зарегистрирован: 06-11-2009
Сообщений: 18

Re: mem_self_register

Добрый вечер, Уважаемые.
А не мог бы кто нибудь, кто успешно установил этот плагин пошагово проинструктировать новичка? То есть установить то я установил,  а вот воплотить систему регистрации пользователей с уже установленным плагином как то не соображу как. Понимаю, что видимо нужно появившиеся после его установки новые формы вывести как то в нужном месте шаблона?  Но что, как и куда выводить?

Неактивен

 

#19 03-03-2011 07:04:57

Skrishi
есть
Зарегистрирован: 26-01-2011
Сообщений: 50

Неактивен

 

Board footer

RSS   Rambler's Top100
Powered by PunBB
Textpattern.ru