ugc_helper.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: stanley-king
  5. * Date: 2017/7/5
  6. * Time: 下午6:34
  7. */
  8. require_once(BASE_ROOT_PATH . '/helper/user_session/storage.php');
  9. require_once(BASE_ROOT_PATH . '/helper/ugc/generator.php');
  10. require_once(BASE_ROOT_PATH . '/helper/ugc/content.php');
  11. require_once(BASE_ROOT_PATH . '/helper/ugc/answer.php');
  12. require_once(BASE_ROOT_PATH . '/helper/ugc/comments.php');
  13. require_once(BASE_ROOT_PATH . '/helper/ugc/special.php');
  14. require_once(BASE_ROOT_PATH . '/helper/ugc/setting.php');
  15. require_once(BASE_ROOT_PATH . '/helper/ugc/category.php');
  16. require_once(BASE_ROOT_PATH . '/helper/search/tcp_client.php');
  17. require_once(BASE_ROOT_PATH . '/helper/bonus_helper.php');
  18. require_once(BASE_ROOT_PATH . '/helper/predeposit_helper.php');
  19. require_once(BASE_ROOT_PATH . '/helper/relation_helper.php');
  20. require_once(BASE_ROOT_PATH . '/helper/tools/fast_image.php');
  21. use ugc\special_vote;
  22. use ugc\special;
  23. use ugc\special_answer;
  24. use ugc\special_submitor;
  25. use ugc\special_support;
  26. class ugc_helper
  27. {
  28. const public_all = 0;
  29. const protected_self = 1;
  30. const private_self = 2;
  31. public static function crate_special($data,&$err)
  32. {
  33. $generator = new ugc\generator();
  34. $special = $generator->crate_special($data,$err);
  35. return $special;
  36. }
  37. public static function pub_special($special_id,$setting,&$err)
  38. {
  39. $mod_special = Model('mb_special');
  40. $special_info = $mod_special->getMbSpecialByID($special_id,'*',true);
  41. if(empty($special_info)) {
  42. $err = ['code' => errcode::ErrParamter,'msg' => "该专题不存在"];
  43. return false;
  44. }
  45. $special = new ugc\special($special_info);
  46. if($special->published()) {
  47. $err = ['code' => errcode::ErrParamter,'msg' => "文章发布之后,不可以编辑."];
  48. return false;
  49. }
  50. $setting = new ugc\setting($setting,$special);
  51. $rule = $setting->format();
  52. $rule['pubtime'] = time();
  53. $rule['state'] = 0;
  54. $ret = $mod_special->editUserSpecial($special_id,['special_id' => $special_id,'member_id' => session_helper::memberid()],$rule);
  55. if($ret != false)
  56. {
  57. $type = $setting->reader_type();
  58. if($type != ugc\setting::mine_type) {
  59. $spid = intval($special_id);
  60. QueueClient::push('onAsyncUgcPublish',['special_id'=> $spid]);
  61. }
  62. }
  63. return $ret;
  64. }
  65. public static function del_special($special_id,&$err)
  66. {
  67. $mod_special = Model('mb_special');
  68. $special_info = $mod_special->getMbSpecialByID($special_id,'*',true);
  69. if(empty($special_info)) {
  70. $err = ['code' => errcode::ErrParamter,'msg' => "该专题不存在"];
  71. return false;
  72. }
  73. $special = new ugc\special($special_info);
  74. if($special->memberid() != session_helper::memberid()) {
  75. $err = ['code' => errcode::ErrSpecial,'msg' => "您不能删除该内容"];
  76. return false;
  77. }
  78. $ret = $mod_special->delMbSpecialByID($special_id);
  79. if($ret != false) {
  80. $type = $special->reader_type();
  81. $spid = intval($special_id);
  82. QueueClient::push('onAsyncUgcDel',['user_id' => session_helper::memberid(),'specials'=> array(['type' => $type,'spid' => $spid])]);
  83. return $ret;
  84. } else {
  85. $err = ['code' => errcode::ErrSpecial,'msg' => "删除失败"];
  86. return false;
  87. }
  88. }
  89. public static function subscribe($memberid,$special_id)
  90. {
  91. $mod_special = Model('mb_special');
  92. $special_info = $mod_special->getMbSpecialByID($special_id,'*',true);
  93. $special = new special($special_info);
  94. $author = $special->memberid();
  95. return relation_helper::onSubscribe($memberid,$author);
  96. }
  97. public static function submit($special_id,$options,&$err)
  98. {
  99. $mod_special = Model('mb_special');
  100. $special_info = $mod_special->getMbSpecialByID($special_id,'*',true);
  101. $special = new special($special_info);
  102. $vote_single = $special->vote_single();
  103. $submitor = new special_submitor($special_id,$vote_single);
  104. if($submitor->submited()) {
  105. $err = ['code' => errcode::ErrSpecial,'msg' => "您已经提交过"];
  106. return false;
  107. } else {
  108. $submitor->submit();
  109. }
  110. if(!empty($options))
  111. {
  112. $vote = $options['vote'];
  113. $answers = $options['question'];
  114. } else {
  115. $vote = false;
  116. $answers = false;
  117. }
  118. $answer_diff = [];
  119. $vote_result = [];
  120. $num = 0;
  121. if($special->has_vote() || $special->has_question())
  122. {
  123. if($special->has_vote() && $vote != false)
  124. {
  125. $voter = new special_vote($special->special_id());
  126. $vote_result = $voter->vote($vote,$vote_num);
  127. if($vote_result == false) {
  128. return false;
  129. } else {
  130. $num += $vote_num;
  131. $bonus_type = 0;
  132. }
  133. }
  134. if($special->has_question() && $answers != false)
  135. {
  136. $answor = new special_answer($special);
  137. $correct_num = $answor->answer($answers,$answor_id);
  138. if($answor_id == false) {
  139. $err = ['code' => errcode::ErrSpecial,'msg' => "您已经答过题了,不能再答"];
  140. return false;
  141. }
  142. $num += $correct_num;
  143. $answer_diff = $answor->diff();
  144. $bonus_type = 1;
  145. }
  146. }
  147. else {
  148. $num = 1;
  149. $bonus_type = 2;
  150. }
  151. $type_sn = "";
  152. $amount = 0.0;
  153. $rule = $special->submit_rule();
  154. if($rule != false && $num > 0)
  155. {
  156. $type_sn = $rule->make_bonus($num,$amount,$bonus_rate);
  157. if(isset($answor_id) && $type_sn != false) {
  158. Model()->table('special_answer')->where(['spanswer_id' => $answor_id])->update(['amount' => $amount,'bonus_rate' => $bonus_rate]);
  159. }
  160. }
  161. QueueClient::push('onAsyncUgcSubmit',['special_id' => $special_id,'user_id' => session_helper::memberid()]);
  162. return ['vote_result' => $vote_result,'answer_diff' => $answer_diff,'type_sn' => $type_sn,'num' => $num,'amount' => $amount,'bonus_type' => $bonus_type];
  163. }
  164. public static function support_special($special_id,$comment_id)
  165. {
  166. $supporter = new special_support($special_id,$comment_id);
  167. if($supporter->supported()) {
  168. $supporter->unsupport();
  169. $supported = false;
  170. } else {
  171. $supporter->support();
  172. $supported = true;
  173. }
  174. if($supported) {
  175. QueueClient::push('onAsyncUgcSupport',['special_id' => $special_id,'comment_id' => $comment_id,'user_id' => session_helper::memberid()]);
  176. }
  177. return $supported;
  178. }
  179. public static function appreciate($special_id,$rate,$money,$bless)
  180. {
  181. $mod_special = Model('mb_special');
  182. $special_info = $mod_special->getMbSpecialByID($special_id,'*',true);
  183. $special = new special($special_info);
  184. $toid = $special->memberid();
  185. $senderid = session_helper::memberid();
  186. return account_helper::appreciate($senderid,$rate,$money,$toid,$bless);
  187. }
  188. public static function categories()
  189. {
  190. return ugc\category::instance()->categories();
  191. }
  192. public static function category_title($category_id) {
  193. return ugc\category::instance()->title($category_id);
  194. }
  195. public static function init_server()
  196. {
  197. $initer = new ugciniter();
  198. $initer->init_special();
  199. $initer->init_fellows();
  200. }
  201. public static function send_reward()
  202. {
  203. }
  204. }
  205. class ugciniter
  206. {
  207. public function init_fellows()
  208. {
  209. $i = 0;
  210. while (true)
  211. {
  212. $start = $i * 1000;
  213. $items = Model()->table('member')->field('member_id,inviter_id')->order('member_id asc')->limit("{$start},1000")->select();
  214. if(empty($items)) {
  215. return;
  216. }
  217. $i++;
  218. foreach ($items as $item) {
  219. $this->add_follow($item['member_id'],$item['inviter_id']);
  220. }
  221. }
  222. }
  223. private function add_follow($member_id, $inviter_id)
  224. {
  225. $member_id = intval($member_id);
  226. $inviter_id = intval($inviter_id);
  227. if($inviter_id > 0) {
  228. search\relation_client::instance()->add_follow(array('user_id' => $member_id,'friends'=>[$inviter_id]));
  229. search\relation_client::instance()->add_follow(array('user_id' => $inviter_id,'friends'=>[$member_id]));
  230. }
  231. if($member_id > 0)
  232. {
  233. $iRelation = new \relation\mem_relation($member_id);
  234. $follows = $iRelation->subscriber();
  235. $uids = [];
  236. foreach ($follows as $val)
  237. {
  238. $uid = intval($val);
  239. if($uid > 0) {
  240. $uids[] = $uid;
  241. }
  242. }
  243. if(!empty($uids)) {
  244. search\relation_client::instance()->add_follow(array('user_id' => $member_id,'friends' => $uids));
  245. }
  246. }
  247. if($member_id > 0)
  248. {
  249. $mod_member = Model('member');
  250. $items = $mod_member->getMemberList(['inviter_id' => $member_id],'member_id');
  251. $uids = [];
  252. foreach ($items as $val) {
  253. $uid = intval($val['member_id']);
  254. if($uid > 0) {
  255. $uids[] = $uid;
  256. }
  257. }
  258. if(!empty($uids)) {
  259. search\relation_client::instance()->add_follow(array('user_id' => $member_id,'friends' => $uids));
  260. }
  261. }
  262. }
  263. public function init_special()
  264. {
  265. $i = 0;
  266. while (true)
  267. {
  268. $start = $i * 1000;
  269. $items = Model()->table('mb_special')->where(['from_user' => 1,'state' => 0])->field('special_id,member_id,reader_type')->order('member_id asc')->limit("{$start},1000")->select();
  270. if(empty($items)) {
  271. return;
  272. }
  273. $i++;
  274. foreach ($items as $item) {
  275. $this->add_special($item);
  276. }
  277. }
  278. }
  279. private function add_special($item)
  280. {
  281. $user_id = intval($item['member_id']);
  282. $special_id = intval($item['special_id']);
  283. $reader_type = intval($item['reader_type']);
  284. if($user_id >0 && $special_id > 0 && $reader_type != ugc_helper::private_self) {
  285. search\relation_client::instance()->add_special(array('user_id' => $user_id,'specials'=> [['type' => $reader_type,'spid' => $special_id]]));
  286. }
  287. }
  288. }