]> git.mxchange.org Git - friendica.git/commitdiff
invite system
authorFriendika <info@friendika.com>
Mon, 18 Jul 2011 04:12:31 +0000 (21:12 -0700)
committerFriendika <info@friendika.com>
Mon, 18 Jul 2011 04:12:31 +0000 (21:12 -0700)
include/zotfns.php
mod/contacts.php
mod/invite.php
mod/register.php
view/register.tpl

index 1ec39aefca2329e2e25f547c7fd8246b01a0d477..b695b6fcb6473164b60eefd2b2045f3769f63745 100644 (file)
@@ -1,5 +1,8 @@
 <?php
 
+
+require_once('include/salmon.php');
+
 function zot_get($url,$args) {
        $argstr = '';
        foreach($args as $k => $v) {
index 388bf08e6389499de19974567dd7808772b7f32f..2fc01a0d8bee9d73fa58960e64e9b68b3c02e022 100644 (file)
@@ -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>';
 
-       if(get_config('system','invitations_only')) {
+       if(get_config('system','invitation_only')) {
                $x = get_pconfig(local_user(),'system','invites_remaining');
                if($x || is_site_admin()) {
                        $a->page['aside'] .= '<div class="side-link" id="side-invite-remain">' 
index 5a67454361c1f315b7508d1dfd9cee23117d4fbf..d4eb9c5ef17b59cd539d56913d7278af01107076 100644 (file)
@@ -20,7 +20,7 @@ function invite_post(&$a) {
 
        $total = 0;
 
-       if(get_config('system','invitations_only')) {
+       if(get_config('system','invitation_only')) {
                $invonly = true;
                $x = get_pconfig(local_user(),'system','invites_remaining');
                if((! $x) && (! is_site_admin()))
@@ -39,12 +39,16 @@ function invite_post(&$a) {
                if($invonly && ($x || is_site_admin())) {
                        $code = autoname(8) . srand(1000,9999);
                        $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()) {
                                $x --;
                                if($x >= 0)
-                                       set_pconfig(local_user(),'system','invites_remaining,$x);
+                                       set_pconfig(local_user(),'system','invites_remaining',$x);
                                else
                                        return;
                        }
@@ -81,7 +85,7 @@ function invite_content(&$a) {
        $tpl = get_markup_template('invite.tpl');
        $invonly = false;
 
-       if(get_config('system','invitations_only')) {
+       if(get_config('system','invitation_only')) {
                $invonly = true;
                $x = get_pconfig(local_user(),'system','invites_remaining');
                if((! $x) && (! is_site_admin())) {
index 5fac9d79ce94c77c0206bca04c62093650b769b4..549d07a91896b58a6c3185885327124a5f9aa986 100644 (file)
@@ -32,7 +32,11 @@ function register_post(&$a) {
                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']))   : '');
        $nickname   = ((x($_POST,'nickname'))   ? notags(trim($_POST['nickname']))   : '');
        $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);
                
        $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($openid_url) {
                        if(! validate_url($tmp_str)) {
@@ -329,6 +346,12 @@ function register_post(&$a) {
 
 
        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 = replace_macros($email_tpl, array(
                                '$sitename' => $a->config['sitename'],
@@ -376,6 +399,10 @@ function register_post(&$a) {
                else
                        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 = 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']            : ''));
        $nickname     = ((x($_POST,'nickname'))     ? $_POST['nickname']     : ((x($_GET,'nickname'))     ? $_GET['nickname']              : ''));
        $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');
 
@@ -476,6 +504,10 @@ function register_content(&$a) {
        $o = get_markup_template("register.tpl");
        $o = replace_macros($o, array(
                '$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,
                '$regtitle'  => t('Registration'),
                '$registertext' =>((x($a->config,'register_text'))
index ac8388de4459cc0b2562239cf786e6c61f09d26f..16e8ba76753c02c291374613018dee1d0419c6f4 100644 (file)
        </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" >
                <label for="register-name" id="label-register-name" >$namelabel</label>