friendica/mod/invite.php

110 lines
2.7 KiB
PHP
Raw Normal View History

2010-07-29 01:28:39 +02:00
<?php
2010-12-10 13:04:35 +01:00
/**
* module: invite.php
*
* send email invitations to join social network
*
*/
2010-07-29 01:28:39 +02:00
function invite_post(&$a) {
2010-12-10 13:04:35 +01:00
2010-07-29 01:28:39 +02:00
if(! local_user()) {
notice( t('Permission denied.') . EOL);
return;
}
2010-12-10 13:04:35 +01:00
$recips = ((x($_POST,'recipients')) ? explode("\n",$_POST['recipients']) : array());
$message = ((x($_POST,'message')) ? notags(trim($_POST['message'])) : '');
2010-07-29 01:28:39 +02:00
$total = 0;
2011-07-18 06:12:31 +02:00
if(get_config('system','invitation_only')) {
2011-07-18 01:08:47 +02:00
$invonly = true;
$x = get_pconfig(local_user(),'system','invites_remaining');
if((! $x) && (! is_site_admin()))
return;
}
2010-07-29 01:28:39 +02:00
foreach($recips as $recip) {
$recip = trim($recip);
if(! valid_email($recip)) {
2011-03-11 00:22:21 +01:00
notice( sprintf( t('%s : Not a valid email address.'), $recip) . EOL);
2010-07-29 01:28:39 +02:00
continue;
}
2011-07-18 01:08:47 +02:00
if($invonly && ($x || is_site_admin())) {
$code = autoname(8) . srand(1000,9999);
$nmessage = str_replace('$invite_code',$code,$message);
2011-07-18 06:12:31 +02:00
$r = q("INSERT INTO `register` (`hash`,`created`) VALUES ('%s', '%s') ",
dbesc($code),
dbesc(datetime_convert())
);
2011-07-18 01:08:47 +02:00
if(! is_site_admin()) {
$x --;
if($x >= 0)
2011-07-18 06:12:31 +02:00
set_pconfig(local_user(),'system','invites_remaining',$x);
2011-07-18 01:08:47 +02:00
else
return;
}
}
else
$nmessage = $message;
2010-07-29 01:28:39 +02:00
2011-05-24 05:30:37 +02:00
$res = mail($recip, sprintf( t('Please join my network on %s'), $a->config['sitename']),
2011-07-18 01:08:47 +02:00
$nmessage,
2011-04-15 02:13:13 +02:00
"From: " . $a->user['email'] . "\n"
. 'Content-type: text/plain; charset=UTF-8' . "\n"
. 'Content-transfer-encoding: 8bit' );
2010-07-29 01:28:39 +02:00
if($res) {
$total ++;
}
else {
2011-03-11 00:22:21 +01:00
notice( sprintf( t('%s : Message delivery failed.'), $recip) . EOL);
2010-07-29 01:28:39 +02:00
}
}
2011-03-13 13:50:44 +01:00
notice( sprintf( tt("%d message sent.", "%d messages sent.", $total) , $total) . EOL);
2010-09-09 05:14:17 +02:00
return;
2010-07-29 01:28:39 +02:00
}
function invite_content(&$a) {
2010-12-10 13:04:35 +01:00
2010-07-29 01:28:39 +02:00
if(! local_user()) {
notice( t('Permission denied.') . EOL);
return;
}
2011-05-11 13:37:13 +02:00
$tpl = get_markup_template('invite.tpl');
2011-07-18 01:08:47 +02:00
$invonly = false;
2011-07-18 06:12:31 +02:00
if(get_config('system','invitation_only')) {
2011-07-18 01:08:47 +02:00
$invonly = true;
$x = get_pconfig(local_user(),'system','invites_remaining');
if((! $x) && (! is_site_admin())) {
notice( t('You have no more invitations available') . EOL);
return '';
}
}
2010-07-29 01:28:39 +02:00
$o = replace_macros($tpl, array(
'$invite' => t('Send invitations'),
'$addr_text' => t('Enter email addresses, one per line:'),
'$msg_text' => t('Your message:'),
2011-03-11 00:22:21 +01:00
'$default_message' => sprintf(t('Please join my social network on %s'), $a->config['sitename']) . "\r\n" . "\r\n"
2011-01-24 12:08:20 +01:00
. t('To accept this invitation, please visit:') . "\r\n" . "\r\n" . $a->get_baseurl()
2011-07-18 01:08:47 +02:00
. "\r\n" . "\r\n" . (($invonly) ? t('You will need to supply this invitation code: $invite_code') . "\r\n" . "\r\n" : '') .t('Once you have registered, please connect with me via my profile page at:')
2011-01-24 12:08:20 +01:00
. "\r\n" . "\r\n" . $a->get_baseurl() . '/profile/' . $a->user['nickname'] ,
2010-07-29 01:28:39 +02:00
'$submit' => t('Submit')
));
return $o;
}