spacecp_invite.php 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. <?php
  2. /**
  3. * [Discuz!] (C)2001-2099 Comsenz Inc.
  4. * This is NOT a freeware, use is subject to license terms
  5. *
  6. * $Id: spacecp_invite.php 25042 2011-10-24 03:27:47Z zhengqingpeng $
  7. */
  8. if(!defined('IN_DISCUZ')) {
  9. exit('Access Denied');
  10. }
  11. $creditid = 0;
  12. $creditnum = $_G['group']['inviteprice'];
  13. if($_G['setting']['creditstrans']) {
  14. $creditid = intval($_G['setting']['creditstransextra'][6] ? $_G['setting']['creditstransextra'][6] : $_G['setting']['creditstrans']);
  15. } elseif($creditnum) {
  16. showmessage('trade_credit_invalid', '', array(), array('return' => 1));
  17. }
  18. space_merge($space, 'count');
  19. $baseurl = 'home.php?mod=spacecp&ac=invite';
  20. $siteurl = getsiteurl();
  21. $maxcount = 50;
  22. $config = $_G['setting']['inviteconfig'];
  23. $creditname = $config['inviterewardcredit'];
  24. $allowinvite = ($_G['setting']['regstatus'] > 1 && $creditname && $_G['group']['allowinvite']) ? 1 : 0;
  25. $unit = $_G['setting']['extcredits'][$creditname]['unit'];
  26. $credittitle = $_G['setting']['extcredits'][$creditname]['title'];
  27. $creditname = 'extcredits'.$creditname;
  28. $inviteurl = $invite_code = '';
  29. $appid = empty($_GET['app']) ? 0 : intval($_GET['app']);
  30. $creditkey = 'extcredits'.$creditid;
  31. $extcredits = $_G['setting']['extcredits'][$creditid];
  32. $mailvar = array(
  33. 'avatar' => avatar($space['uid'], 'middle'),
  34. 'uid' => $space['uid'],
  35. 'username' => $space['username'],
  36. 'sitename' => $_G['setting']['sitename'],
  37. 'siteurl' => $siteurl
  38. );
  39. $appinfo = array();
  40. if($appid) {
  41. $appinfo = C::t('common_myapp')->fetch($appid);
  42. if($appinfo) {
  43. $inviteapp = "&amp;app=$appid";
  44. $mailvar['appid'] = $appid;
  45. $mailvar['appname'] = $appinfo['appname'];
  46. } else {
  47. $appid = 0;
  48. }
  49. }
  50. if(!$creditnum) {
  51. $inviteurl = getinviteurl(0, 0, $appid);
  52. }
  53. if(!$allowinvite) {
  54. showmessage('close_invite', '', array(), $_G['inajax'] ? array('showdialog'=>1, 'showmsg' => true, 'closetime' => true) : array());
  55. }
  56. if(submitcheck('emailinvite')) {
  57. if(!$_G['group']['allowmailinvite']) {
  58. showmessage('mail_invite_not_allow', $baseurl);
  59. }
  60. $_POST['email'] = str_replace("\n", ',', $_POST['email']);
  61. $newmails = array();
  62. $mails = explode(",", $_POST['email']);
  63. foreach ($mails as $value) {
  64. $value = trim($value);
  65. if(isemail($value)) {
  66. $newmails[] = $value;
  67. }
  68. }
  69. $newmails = array_unique($newmails);
  70. $invitenum = count($newmails);
  71. if($invitenum < 1) {
  72. showmessage('mail_can_not_be_empty', $baseurl);
  73. }
  74. $msetarr = array();
  75. if($creditnum) {
  76. $allcredit = $invitenum * $creditnum;
  77. if($space[$creditkey] < $allcredit) {
  78. showmessage('mail_credit_inadequate', $baseurl);
  79. }
  80. foreach($newmails as $value) {
  81. $code = strtolower(random(6));
  82. $setarr = array(
  83. 'uid' => $_G['uid'],
  84. 'code' => $code,
  85. 'email' => daddslashes($value),
  86. 'type' => 1,
  87. 'appid' => $appid,
  88. 'inviteip' => $_G['clientip'],
  89. 'dateline' => $_G['timestamp'],
  90. 'status' => 3,
  91. 'endtime' => ($_G['group']['maxinviteday']?($_G['timestamp']+$_G['group']['maxinviteday']*24*3600):0)
  92. );
  93. $id = C::t('common_invite')->insert($setarr, true);
  94. $mailvar['inviteurl'] = getinviteurl($id, $code, $appid);
  95. createmail($value, $mailvar);
  96. }
  97. updatemembercount($_G['uid'], array($creditkey => "-$allcredit"));
  98. } else {
  99. $mailvar['inviteurl'] = $inviteurl;
  100. foreach($newmails as $value) {
  101. createmail($value, $mailvar);
  102. }
  103. }
  104. showmessage('send_result_succeed',$baseurl);
  105. } else if(submitcheck('invitesubmit')) {
  106. $invitenum = intval($_POST['invitenum']);
  107. if($invitenum < 1) $invitenum = 1;
  108. if($_G['group']['maxinvitenum']) {
  109. $daytime = $_G['timestamp'] - 24*3600;
  110. $invitecount = C::t('common_invite')->count_by_uid_dateline($_G['uid'], $daytime);
  111. if($invitecount + $invitenum > $_G['group']['maxinvitenum']) {
  112. showmessage('max_invitenum_error', NULL, array('maxnum'=>$_G['group']['maxinvitenum']), array('showdialog'=>1, 'showmsg' => true, 'closetime' => true));
  113. }
  114. }
  115. $allcredit = $invitenum * $creditnum;
  116. if($space[$creditkey] < $allcredit) {
  117. showmessage('mail_credit_inadequate', $baseurl, array(), array('showdialog'=>1, 'showmsg' => true, 'closetime' => true));
  118. }
  119. $havecode = false;
  120. $dateline = $_G['timestamp'];
  121. for($i=0; $i<$invitenum; $i++) {
  122. $code = strtolower(random(6));
  123. $havecode = true;
  124. $invitedata = array(
  125. 'uid' => $_G['uid'],
  126. 'code' => $code,
  127. 'dateline' => $dateline,
  128. 'endtime' => $_G['group']['maxinviteday'] ? ($_G['timestamp']+$_G['group']['maxinviteday']*24*3600) : 0,
  129. 'inviteip' => $_G['clientip']
  130. );
  131. C::t('common_invite')->insert($invitedata);
  132. }
  133. if($havecode) {
  134. require_once libfile('class/credit');
  135. $creditobj = new credit();
  136. $creditobj->updatemembercount(array($creditkey=>0-$allcredit), $_G['uid']);
  137. }
  138. showmessage('do_success', $baseurl, array('deduction' => $allcredit, 'dateline' => $dateline), array('showdialog'=>1, 'showmsg' => true, 'closetime' => true, 'return' => false));
  139. }
  140. if($_GET['op'] == 'resend') {
  141. $id = $_GET['id'] ? intval($_GET['id']) : 0;
  142. if(submitcheck('resendsubmit')) {
  143. if(empty($id)) {
  144. showmessage('send_result_resend_error', $baseurl);
  145. }
  146. if($value = C::t('common_invite')->fetch_by_id_uid($id, $_G['uid'])) {
  147. if($creditnum) {
  148. $inviteurl = getinviteurl($value['id'], $value['code'], $value['appid']);
  149. }
  150. $mailvar['inviteurl'] = $inviteurl;
  151. createmail($value['email'], $mailvar);
  152. showmessage('send_result_succeed', dreferer(), array('id' => $id), array('showdialog'=>1, 'showmsg' => true, 'closetime' => true));
  153. } else {
  154. showmessage('send_result_resend_error', $baseurl, array(), array('showdialog'=>1, 'showmsg' => true, 'closetime' => true));
  155. }
  156. }
  157. } elseif($_GET['op'] == 'delete') {
  158. $id = $_GET['id'] ? intval($_GET['id']) : 0;
  159. if(empty($id)) {
  160. showmessage('there_is_no_record_of_invitation_specified', $baseurl);
  161. }
  162. if($value = C::t('common_invite')->fetch_by_id_uid($id, $_G['uid'])) {
  163. if(submitcheck('deletesubmit')) {
  164. C::t('common_invite')->delete($id);
  165. showmessage('do_success', dreferer(), array('id' => $id), array('showdialog'=>1, 'showmsg' => true, 'closetime' => true));
  166. }
  167. } else {
  168. showmessage('there_is_no_record_of_invitation_specified', $baseurl, array(), array('showdialog'=>1, 'showmsg' => true, 'closetime' => true));
  169. }
  170. } elseif ($_GET['op'] == 'showinvite') {
  171. foreach(C::t('common_invite')->fetch_all_by_uid($_G['uid']) as $value) {
  172. if(!$value['fuid'] && !$value['type']) {
  173. $inviteurl = getinviteurl($value['id'], $value['code'], $value['appid']);
  174. $list[$value[code]] = $inviteurl;
  175. }
  176. }
  177. } else {
  178. $list = $flist = $dels = array();
  179. $invitedcount = $count = 0;
  180. foreach(C::t('common_invite')->fetch_all_by_uid($_G['uid']) as $value) {
  181. if($value['fuid']) {
  182. $flist[] = $value;
  183. $invitedcount++;
  184. } else {
  185. if($_G['timestamp'] > $value['endtime']) {
  186. $dels[] = $value['id'];
  187. continue;
  188. }
  189. $inviteurl = getinviteurl($value['id'], $value['code'], $value['appid']);
  190. if($value['type']) {
  191. $maillist[] = array(
  192. 'email' => $value['email'],
  193. 'url' => $inviteurl,
  194. 'id' => $value['id']
  195. );
  196. } else {
  197. $list[$value[code]] = $inviteurl;
  198. $count++;
  199. }
  200. }
  201. }
  202. if($dels) {
  203. C::t('common_invite')->delete($dels);
  204. }
  205. $uri = $_SERVER['REQUEST_URI']?$_SERVER['REQUEST_URI']:($_SERVER['PHP_SELF']?$_SERVER['PHP_SELF']:$_SERVER['SCRIPT_NAME']);
  206. $uri = substr($uri, 0, strrpos($uri, '/')+1);
  207. $actives = array('invite'=>' class="a"');
  208. }
  209. $navtitle = lang('core', 'title_invite_friend');
  210. include template('home/spacecp_invite');
  211. function createmail($mail, $mailvar) {
  212. global $_G, $space, $appinfo;
  213. $mailvar['saymsg'] = empty($_POST['saymsg'])?'':getstr($_POST['saymsg'], 500);
  214. require_once libfile('function/mail');
  215. $subject = lang('spacecp', $appinfo?'app_invite_subject':'invite_subject', $mailvar);
  216. $message = lang('spacecp', $appinfo?'app_invite_massage':'invite_massage', $mailvar);
  217. if(!sendmail($mail, $subject, $message)) {
  218. runlog('sendmail', "$mail sendmail failed.");
  219. }
  220. }
  221. function getinviteurl($inviteid, $invitecode, $appid) {
  222. global $_G;
  223. if($inviteid && $invitecode) {
  224. $inviteurl = getsiteurl()."home.php?mod=invite&amp;id={$inviteid}&amp;c={$invitecode}";
  225. } else {
  226. $invite_code = space_key($_G['uid'], $appid);
  227. $inviteapp = $appid?"&amp;app=$appid":'';
  228. $inviteurl = getsiteurl()."home.php?mod=invite&amp;u=$_G[uid]&amp;c=$invite_code{$inviteapp}";
  229. }
  230. return $inviteurl;
  231. }
  232. ?>