invite system
This commit is contained in:
parent
43110db749
commit
1fa2231c20
|
@ -1,5 +1,8 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
require_once('include/salmon.php');
|
||||||
|
|
||||||
function zot_get($url,$args) {
|
function zot_get($url,$args) {
|
||||||
$argstr = '';
|
$argstr = '';
|
||||||
foreach($args as $k => $v) {
|
foreach($args as $k => $v) {
|
||||||
|
|
|
@ -13,7 +13,7 @@ function contacts_init(&$a) {
|
||||||
|
|
||||||
$inv = '<div class="side-link" id="side-invite-link" ><a href="invite" >' . t("Invite Friends") . '</a></div>';
|
$inv = '<div class="side-link" id="side-invite-link" ><a href="invite" >' . t("Invite Friends") . '</a></div>';
|
||||||
|
|
||||||
if(get_config('system','invitations_only')) {
|
if(get_config('system','invitation_only')) {
|
||||||
$x = get_pconfig(local_user(),'system','invites_remaining');
|
$x = get_pconfig(local_user(),'system','invites_remaining');
|
||||||
if($x || is_site_admin()) {
|
if($x || is_site_admin()) {
|
||||||
$a->page['aside'] .= '<div class="side-link" id="side-invite-remain">'
|
$a->page['aside'] .= '<div class="side-link" id="side-invite-remain">'
|
||||||
|
|
|
@ -20,7 +20,7 @@ function invite_post(&$a) {
|
||||||
|
|
||||||
$total = 0;
|
$total = 0;
|
||||||
|
|
||||||
if(get_config('system','invitations_only')) {
|
if(get_config('system','invitation_only')) {
|
||||||
$invonly = true;
|
$invonly = true;
|
||||||
$x = get_pconfig(local_user(),'system','invites_remaining');
|
$x = get_pconfig(local_user(),'system','invites_remaining');
|
||||||
if((! $x) && (! is_site_admin()))
|
if((! $x) && (! is_site_admin()))
|
||||||
|
@ -39,12 +39,16 @@ function invite_post(&$a) {
|
||||||
if($invonly && ($x || is_site_admin())) {
|
if($invonly && ($x || is_site_admin())) {
|
||||||
$code = autoname(8) . srand(1000,9999);
|
$code = autoname(8) . srand(1000,9999);
|
||||||
$nmessage = str_replace('$invite_code',$code,$message);
|
$nmessage = str_replace('$invite_code',$code,$message);
|
||||||
// store in db
|
|
||||||
|
$r = q("INSERT INTO `register` (`hash`,`created`) VALUES ('%s', '%s') ",
|
||||||
|
dbesc($code),
|
||||||
|
dbesc(datetime_convert())
|
||||||
|
);
|
||||||
|
|
||||||
if(! is_site_admin()) {
|
if(! is_site_admin()) {
|
||||||
$x --;
|
$x --;
|
||||||
if($x >= 0)
|
if($x >= 0)
|
||||||
set_pconfig(local_user(),'system','invites_remaining,$x);
|
set_pconfig(local_user(),'system','invites_remaining',$x);
|
||||||
else
|
else
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -81,7 +85,7 @@ function invite_content(&$a) {
|
||||||
$tpl = get_markup_template('invite.tpl');
|
$tpl = get_markup_template('invite.tpl');
|
||||||
$invonly = false;
|
$invonly = false;
|
||||||
|
|
||||||
if(get_config('system','invitations_only')) {
|
if(get_config('system','invitation_only')) {
|
||||||
$invonly = true;
|
$invonly = true;
|
||||||
$x = get_pconfig(local_user(),'system','invites_remaining');
|
$x = get_pconfig(local_user(),'system','invites_remaining');
|
||||||
if((! $x) && (! is_site_admin())) {
|
if((! $x) && (! is_site_admin())) {
|
||||||
|
|
|
@ -32,7 +32,11 @@ function register_post(&$a) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$using_invites = get_config('system','invitation_only');
|
||||||
|
$num_invites = get_config('system','number_invites');
|
||||||
|
|
||||||
|
|
||||||
|
$invite_id = ((x($_POST,'invite_id')) ? notags(trim($_POST['invite_id'])) : '');
|
||||||
$username = ((x($_POST,'username')) ? notags(trim($_POST['username'])) : '');
|
$username = ((x($_POST,'username')) ? notags(trim($_POST['username'])) : '');
|
||||||
$nickname = ((x($_POST,'nickname')) ? notags(trim($_POST['nickname'])) : '');
|
$nickname = ((x($_POST,'nickname')) ? notags(trim($_POST['nickname'])) : '');
|
||||||
$email = ((x($_POST,'email')) ? notags(trim($_POST['email'])) : '');
|
$email = ((x($_POST,'email')) ? notags(trim($_POST['email'])) : '');
|
||||||
|
@ -43,6 +47,19 @@ function register_post(&$a) {
|
||||||
$netpublish = ((strlen(get_config('system','directory_submit_url'))) ? $publish : 0);
|
$netpublish = ((strlen(get_config('system','directory_submit_url'))) ? $publish : 0);
|
||||||
|
|
||||||
$tmp_str = $openid_url;
|
$tmp_str = $openid_url;
|
||||||
|
|
||||||
|
if($using_invites) {
|
||||||
|
if(! $invite_id) {
|
||||||
|
notice( t('An invitation is required.') . EOL);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
$r = q("select * from register where `hash` = '%s' limit 1", dbesc($invite_id));
|
||||||
|
if(! results($r)) {
|
||||||
|
notice( t('Invitation could not be verified.') . EOL);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if((! x($username)) || (! x($email)) || (! x($nickname))) {
|
if((! x($username)) || (! x($email)) || (! x($nickname))) {
|
||||||
if($openid_url) {
|
if($openid_url) {
|
||||||
if(! validate_url($tmp_str)) {
|
if(! validate_url($tmp_str)) {
|
||||||
|
@ -329,6 +346,12 @@ function register_post(&$a) {
|
||||||
|
|
||||||
|
|
||||||
if( $a->config['register_policy'] == REGISTER_OPEN ) {
|
if( $a->config['register_policy'] == REGISTER_OPEN ) {
|
||||||
|
|
||||||
|
if($using_invites && $invite_id) {
|
||||||
|
q("delete * from register where hash = '%s' limit 1", dbesc($invite_id));
|
||||||
|
set_pconfig($newuid,'system','invites_remaining',$num_invites);
|
||||||
|
}
|
||||||
|
|
||||||
$email_tpl = get_intltext_template("register_open_eml.tpl");
|
$email_tpl = get_intltext_template("register_open_eml.tpl");
|
||||||
$email_tpl = replace_macros($email_tpl, array(
|
$email_tpl = replace_macros($email_tpl, array(
|
||||||
'$sitename' => $a->config['sitename'],
|
'$sitename' => $a->config['sitename'],
|
||||||
|
@ -376,6 +399,10 @@ function register_post(&$a) {
|
||||||
else
|
else
|
||||||
push_lang('en');
|
push_lang('en');
|
||||||
|
|
||||||
|
if($using_invites && $invite_id) {
|
||||||
|
q("delete * from register where hash = '%s' limit 1", dbesc($invite_id));
|
||||||
|
set_pconfig($newuid,'system','invites_remaining',$num_invites);
|
||||||
|
}
|
||||||
|
|
||||||
$email_tpl = get_intltext_template("register_verify_eml.tpl");
|
$email_tpl = get_intltext_template("register_verify_eml.tpl");
|
||||||
$email_tpl = replace_macros($email_tpl, array(
|
$email_tpl = replace_macros($email_tpl, array(
|
||||||
|
@ -434,6 +461,7 @@ function register_content(&$a) {
|
||||||
$openid_url = ((x($_POST,'openid_url')) ? $_POST['openid_url'] : ((x($_GET,'openid_url')) ? $_GET['openid_url'] : ''));
|
$openid_url = ((x($_POST,'openid_url')) ? $_POST['openid_url'] : ((x($_GET,'openid_url')) ? $_GET['openid_url'] : ''));
|
||||||
$nickname = ((x($_POST,'nickname')) ? $_POST['nickname'] : ((x($_GET,'nickname')) ? $_GET['nickname'] : ''));
|
$nickname = ((x($_POST,'nickname')) ? $_POST['nickname'] : ((x($_GET,'nickname')) ? $_GET['nickname'] : ''));
|
||||||
$photo = ((x($_POST,'photo')) ? $_POST['photo'] : ((x($_GET,'photo')) ? hex2bin($_GET['photo']) : ''));
|
$photo = ((x($_POST,'photo')) ? $_POST['photo'] : ((x($_GET,'photo')) ? hex2bin($_GET['photo']) : ''));
|
||||||
|
$invite_id = ((x($_POST,'invite_id')) ? $_POST['invite_id'] : ((x($_GET,'invite_id')) ? $_GET['invite_id'] : ''));
|
||||||
|
|
||||||
$noid = get_config('system','no_openid');
|
$noid = get_config('system','no_openid');
|
||||||
|
|
||||||
|
@ -476,6 +504,10 @@ function register_content(&$a) {
|
||||||
$o = get_markup_template("register.tpl");
|
$o = get_markup_template("register.tpl");
|
||||||
$o = replace_macros($o, array(
|
$o = replace_macros($o, array(
|
||||||
'$oidhtml' => $oidhtml,
|
'$oidhtml' => $oidhtml,
|
||||||
|
'$invitations' => get_config('system','invitation_only'),
|
||||||
|
'$invite_desc' => t('Membership on this site is by invitation only.'),
|
||||||
|
'$invite_label' => t('Your invitation ID: '),
|
||||||
|
'$invite_id' => $invite_id,
|
||||||
'$realpeople' => $realpeople,
|
'$realpeople' => $realpeople,
|
||||||
'$regtitle' => t('Registration'),
|
'$regtitle' => t('Registration'),
|
||||||
'$registertext' =>((x($a->config,'register_text'))
|
'$registertext' =>((x($a->config,'register_text'))
|
||||||
|
|
|
@ -16,6 +16,17 @@
|
||||||
</div>
|
</div>
|
||||||
<div id="register-openid-end" ></div>
|
<div id="register-openid-end" ></div>
|
||||||
|
|
||||||
|
{{ if $invitations }}
|
||||||
|
|
||||||
|
<p id="register-invite-desc">$invite_desc</p>
|
||||||
|
<div id="register-invite-wrapper" >
|
||||||
|
<label for="register-invite" id="label-register-invite" >$invite_label</label>
|
||||||
|
<input type="text" maxlength="60" size="32" name="invite_id" id="register-invite" value="$invite_id" >
|
||||||
|
</div>
|
||||||
|
<div id="register-name-end" ></div>
|
||||||
|
|
||||||
|
{{ endif }}
|
||||||
|
|
||||||
|
|
||||||
<div id="register-name-wrapper" >
|
<div id="register-name-wrapper" >
|
||||||
<label for="register-name" id="label-register-name" >$namelabel</label>
|
<label for="register-name" id="label-register-name" >$namelabel</label>
|
||||||
|
|
Loading…
Reference in a new issue