Discuz的勋章颁发有一定问题,如果给用户颁发一个勋章,有效期30天,那么在用户的勋章还有5天到期的时候再次给用户颁发这个勋章,那么会是一个全新的有效期,即30天。
通过分析源码发现,给用户颁发一次勋章就会往form_medallog表里插入一条记录,其中expiration字段代表有效期,,大体思路有了,在颁发勋章操作里,插入新的勋章前,先查找表里该用户已经有的这个勋章是否过了有效期,如果没有,那么用这个有效期减去当前时间戳得到上个勋章剩余的有效期,插入新的勋章的时候,把这个剩余有效期添加进去,代码其实很简单。
修改的文件为
source/admincp/admincp_members.php- foreach($medalsnewarray as $medalnewarray) {
- $sql = "select * from ".DB::table('forum_medallog')." where uid = {$medalnew['uid']} and medalid = {$medalnewarray['medalid']} order by id desc limit 1";
- $lastmedal = DB::fetch_first($sql);
- // 旧勋章未到期的时间
- $lasttime = $lastmedal['expiration'] > TIMESTAMP ? $lastmedal['expiration'] - TIMESTAMP : 0;
-
- $data = array(
- 'uid' => $medalnew['uid'],
- 'medalid' => $medalnewarray['medalid'],
- 'type' => 0,
- 'dateline' => $_G['timestamp'],
- 'expiration' => $medalnewarray['expiration'] + $lasttime,
- 'status' => $medalnewarray['status'],
- );
- C::t('forum_medallog')->insert($data);
- C::t('common_member_medal')->insert(array('uid' => $medalnew['uid'], 'medalid' => $medalnewarray['medalid']), 0, 1);
- }
复制代码 |
|
|