package com.yeshi.fanli.service.impl.hongbao;
|
|
import java.io.Serializable;
|
import java.text.SimpleDateFormat;
|
import java.util.ArrayList;
|
import java.util.Calendar;
|
import java.util.Date;
|
import java.util.List;
|
import java.util.Map;
|
|
import javax.annotation.Resource;
|
|
import org.hibernate.HibernateException;
|
import org.hibernate.Query;
|
import org.hibernate.SQLQuery;
|
import org.hibernate.Session;
|
import org.springframework.orm.hibernate4.HibernateCallback;
|
import org.springframework.stereotype.Service;
|
import org.springframework.transaction.annotation.Transactional;
|
import org.yeshi.utils.NumberUtil;
|
|
import com.yeshi.fanli.dao.mybatis.ThreeSaleMapper;
|
import com.yeshi.fanli.dao.mybatis.UserInfoMapper;
|
import com.yeshi.fanli.dao.user.ThreeSaleDao;
|
import com.yeshi.fanli.entity.bus.user.ThreeSale;
|
import com.yeshi.fanli.entity.bus.user.ThreeSaleExtraInfo;
|
import com.yeshi.fanli.entity.bus.user.UserInfo;
|
import com.yeshi.fanli.exception.ThreeSaleException;
|
import com.yeshi.fanli.service.inter.config.InviteGetMoneyService;
|
import com.yeshi.fanli.service.inter.hongbao.HongBaoManageService;
|
import com.yeshi.fanli.service.inter.hongbao.ThreeSaleSerivce;
|
import com.yeshi.fanli.service.inter.msg.MsgInviteDetailService;
|
import com.yeshi.fanli.service.inter.msg.UserInviteMsgNotificationService;
|
import com.yeshi.fanli.service.inter.user.UserInfoService;
|
import com.yeshi.fanli.util.Constant;
|
import com.yeshi.fanli.util.StringUtil;
|
|
import net.sf.json.JSONArray;
|
import net.sf.json.JSONObject;
|
|
@Service
|
public class ThreeSaleSerivceImpl implements ThreeSaleSerivce {
|
|
@Resource
|
private ThreeSaleDao dao;
|
|
@Resource
|
private HongBaoManageService hongBaoManageService;
|
|
@Resource
|
private UserInfoService userInfoService;
|
|
@Resource
|
private InviteGetMoneyService inviteGetMoneyService;
|
|
@Resource
|
private UserInfoMapper userInfoMapper;
|
|
@Resource
|
private ThreeSaleMapper threeSaleMapper;
|
|
@Resource
|
private UserInviteMsgNotificationService userInviteMsgNotificationService;
|
|
@Resource
|
private MsgInviteDetailService msgInviteDetailService;
|
|
public UserInfo getBoss(final long uid) {
|
return (UserInfo) dao.excute(new HibernateCallback<UserInfo>() {
|
public UserInfo doInHibernate(Session session) throws HibernateException {
|
Query query = session.createQuery("select ts.boss FROM ThreeSale ts where ts.worker.id = ?");
|
query.setParameter(0, uid);
|
List<UserInfo> list = query.list();
|
if (list.size() > 0) {
|
return list.get(0);
|
}
|
return null;
|
}
|
});
|
}
|
|
public int findInviteCount(final long id) {
|
|
return (Integer) dao.excute(new HibernateCallback<Integer>() {
|
|
public Integer doInHibernate(Session session) throws HibernateException {
|
SQLQuery query = session.createSQLQuery(
|
"SELECT COUNT(*) from `yeshi_ec_threesale` t1 RIGHT JOIN (SELECT t2.`worker_id` AS worker_id FROM `yeshi_ec_threesale` t2 WHERE t2.`boss_id`=? ) t3 ON t1.`boss_id`=t3.worker_id WHERE t1.`boss_id`=t3.worker_id ");
|
query.setParameter(0, id);
|
SQLQuery query2 = session
|
.createSQLQuery("SELECT COUNT(*) from `yeshi_ec_threesale` t4 WHERE t4.`boss_id`=?");
|
query2.setParameter(0, id);
|
int int1 = Integer.parseInt(query.uniqueResult() + "");
|
int int2 = Integer.parseInt(query2.uniqueResult() + "");
|
return int1 + int2;
|
}
|
});
|
}
|
|
@Transactional
|
public void bind(UserInfo invitee, UserInfo inviter) throws ThreeSaleException {
|
if (invitee == null || inviter == null)
|
throw new ThreeSaleException(1, "用户信息为空");
|
if (invitee.getId() == null)// 该用户还不存在
|
{
|
// 保存用户
|
UserInfo inviteeUser = userInfoService.addUser(invitee, Constant.APPID);
|
if (inviteeUser == null)
|
throw new ThreeSaleException(2, "创建用户失败");
|
// 保存关系
|
ThreeSale threeSale = new ThreeSale();
|
threeSale.setBoss(inviter);
|
threeSale.setCreateTime(java.lang.System.currentTimeMillis());
|
threeSale.setExpire(ThreeSale.EXPIRE_NORMAL);
|
threeSale.setState(false);
|
threeSale.setUpdateTime(java.lang.System.currentTimeMillis());
|
threeSale.setWorker(inviteeUser);
|
threeSaleMapper.insertSelective(threeSale);
|
|
List<ThreeSale> listExpire = threeSaleMapper.getExpireRecord(inviter.getId(), inviteeUser.getId());
|
if (listExpire != null && listExpire.size() > 0) {
|
// 删除失效
|
for (ThreeSale saleExpire : listExpire) {
|
msgInviteDetailService.deleteByThreeSale(saleExpire);
|
}
|
// 删除已失效关系
|
threeSaleMapper.deleteExpireRecord(inviter.getId(), inviteeUser.getId());
|
}
|
|
// 创建通知
|
userInviteMsgNotificationService.inviteScan(inviter.getId(), threeSale);
|
|
} else {// 是已经存在的用户
|
|
// 用户已经存在我们的用户库中
|
if (invitee.getLastLoginTime() == null || invitee.getLastLoginTime() == 0L) {
|
// 用户未登录
|
int outOfDateCount = 0;// 过期数量
|
// 查询邀请关系
|
List<ThreeSale> list = listByWorkerId(invitee.getId());
|
if (list != null && list.size() > 0) {
|
for (ThreeSale ts : list) {
|
if (!ts.getState() && ts.getExpire() == ThreeSale.EXPIRE_OUTOFDATE) {
|
outOfDateCount++;
|
}
|
}
|
// 全部是失效状态
|
if (outOfDateCount == list.size()) {
|
// 可以确定关系
|
ThreeSale threeSale = new ThreeSale();
|
threeSale.setBoss(inviter);
|
threeSale.setCreateTime(java.lang.System.currentTimeMillis());
|
threeSale.setExpire(ThreeSale.EXPIRE_NORMAL);
|
threeSale.setState(false);
|
threeSale.setUpdateTime(java.lang.System.currentTimeMillis());
|
threeSale.setWorker(invitee);
|
threeSaleMapper.insertSelective(threeSale);
|
|
// 删除已失效关系
|
threeSaleMapper.deleteExpireRecord(inviter.getId(), invitee.getId());
|
|
List<ThreeSale> listExpire = threeSaleMapper.getExpireRecord(inviter.getId(), invitee.getId());
|
if (listExpire != null && listExpire.size() > 0) {
|
// 删除历史通知
|
for (ThreeSale saleExpire : listExpire) {
|
msgInviteDetailService.deleteByThreeSale(saleExpire);
|
}
|
// 删除已失效关系
|
threeSaleMapper.deleteExpireRecord(inviter.getId(), invitee.getId());
|
}
|
|
userInviteMsgNotificationService.inviteScan(inviter.getId(), threeSale);
|
// threeSaleSerivce.bind(invitee, inviter);
|
|
} else {
|
// 还存在有效的邀请,则不做处理
|
}
|
} else {
|
// 用户未登录,又不存在邀请关系,不做处理
|
}
|
} else {
|
// 已经登录,不做处理
|
}
|
}
|
}
|
|
@Transactional
|
public void effective(UserInfo invitee) {
|
List<ThreeSale> list = dao.list("from ThreeSale ts where ts.worker.id = ? and ts.state=0 and ts.expire=0",
|
new Serializable[] { invitee.getId() });
|
if (list.size() > 0) {
|
ThreeSale threeSale = list.get(0);
|
UserInfo inviter = threeSale.getBoss();
|
threeSale.setState(true);
|
threeSale.setSucceedTime(System.currentTimeMillis());
|
dao.update(threeSale);
|
if (inviter != null)
|
reComputeUserRank(inviter.getId());
|
// 通知
|
userInviteMsgNotificationService.inviteSuccess(inviter.getId(), threeSale);
|
// }
|
// });
|
}
|
}
|
|
@Transactional
|
public void validateTwentyFour() {
|
dao.excute(new HibernateCallback() {
|
@Override
|
public Object doInHibernate(Session session) throws HibernateException {
|
long currentTimeMillis = System.currentTimeMillis();
|
Query query = session
|
.createQuery("delete from ThreeSale ts where ts.state = ? and (?-ts.createTime) > 86400000");
|
query.setParameter(0, false);
|
query.setParameter(1, currentTimeMillis);
|
query.executeUpdate();
|
return null;
|
}
|
});
|
}
|
|
@Transactional
|
public void validate365() {
|
dao.excute(new HibernateCallback() {
|
@Override
|
public Object doInHibernate(Session session) throws HibernateException {
|
long currentTimeMillis = System.currentTimeMillis();
|
Query query = session.createQuery("delete from ThreeSale ts where (?-ts.createTime) > 31536000000");
|
query.setParameter(0, currentTimeMillis);
|
query.executeUpdate();
|
return null;
|
}
|
});
|
}
|
|
@SuppressWarnings("unchecked")
|
@Override
|
public List<UserInfo> getFirstUsers(Long uid, int page) {
|
return (List<UserInfo>) dao.excute(new HibernateCallback<List<UserInfo>>() {
|
|
@Override
|
public List<UserInfo> doInHibernate(Session session) throws HibernateException {
|
Query query = session
|
.createSQLQuery(
|
"SELECT u.* FROM `yeshi_ec_threesale` t LEFT JOIN `yeshi_ec_user` u ON u.`id`=t.`worker_id` WHERE t.`boss_id`=? ORDER BY t.`createtime` DESC")
|
.addEntity(UserInfo.class);
|
query.setParameter(0, uid);
|
query.setFirstResult((page - 1) * Constant.PAGE_SIZE).setMaxResults(Constant.PAGE_SIZE);
|
return query.list();
|
}
|
});
|
|
}
|
|
@SuppressWarnings("unchecked")
|
@Override
|
public List<UserInfo> getSecondUsers(Long uid, int page) {
|
return (List<UserInfo>) dao.excute(new HibernateCallback<List<UserInfo>>() {
|
|
@Override
|
public List<UserInfo> doInHibernate(Session session) throws HibernateException {
|
Query query = session
|
.createSQLQuery(
|
"SELECT u.* FROM `yeshi_ec_threesale` t LEFT JOIN yeshi_ec_threesale t1 ON t1.`boss_id`=t.`worker_id` LEFT JOIN `yeshi_ec_user` u ON u.`id`=t1.`worker_id` WHERE t.`boss_id`=? AND u.`id` IS NOT NULL GROUP BY u.`id` ORDER BY t.`createtime` DESC")
|
.addEntity(UserInfo.class);
|
query.setParameter(0, uid);
|
query.setFirstResult((page - 1) * Constant.PAGE_SIZE).setMaxResults(Constant.PAGE_SIZE);
|
return query.list();
|
}
|
});
|
}
|
|
@Override
|
public List<ThreeSale> getLastestThreeSaleList(int page, String key) {
|
if (NumberUtil.isNumeric(key)) {
|
Long uid = Long.parseLong(key);
|
int start = (page - 1) * Constant.PAGE_SIZE;
|
List<ThreeSale> list = dao.list(
|
"from ThreeSale ts where ts.boss.nickName like ? or ts.boss.id = ? or ts.worker.nickName like ? or ts.worker.id = ? order by ts.createTime desc",
|
start, Constant.PAGE_SIZE, new Serializable[] { "%" + key + "%", uid, "%" + key + "%", uid });
|
return list;
|
}
|
int start = (page - 1) * Constant.PAGE_SIZE;
|
List<ThreeSale> list = dao.list(
|
"from ThreeSale ts where ts.boss.nickName like ? or ts.worker.nickName like ? order by ts.createTime desc",
|
start, Constant.PAGE_SIZE, new Serializable[] { "%" + key + "%", "%" + key + "%" });
|
return list;
|
|
}
|
|
@Override
|
public int getLastestThreeSaleCount(String key) {
|
if (NumberUtil.isNumeric(key)) {
|
long lk = Long.parseLong(key);
|
return (int) dao.getCount(
|
"select count(*) from ThreeSale ts where ts.boss.id = ? or ts.worker.id = ? or ts.boss.nickName like ? or ts.worker.nickName like ?",
|
new Serializable[] { lk, lk, "%" + key + "%", "%" + key + "%" });
|
}
|
Long lcount = dao.getCount(
|
"select count(*) from ThreeSale ts where ts.boss.nickName like ? or ts.worker.nickName like ?",
|
new Serializable[] { "%" + key + "%", "%" + key + "%" });
|
return lcount.intValue();
|
|
}
|
|
@Override
|
public long getFirstUsersCount(Long uid) {
|
return (Long) dao.excute(new HibernateCallback<Long>() {
|
|
@Override
|
public Long doInHibernate(Session session) throws HibernateException {
|
Query query = session.createSQLQuery(
|
"SELECT count(u.id) FROM `yeshi_ec_threesale` t LEFT JOIN `yeshi_ec_user` u ON u.`id`=t.`worker_id` WHERE t.`boss_id`=?");
|
query.setParameter(0, uid);
|
Object count = query.uniqueResult();
|
return Long.parseLong(count + "");
|
}
|
});
|
}
|
|
@Override
|
public long getSecondUsersCount(Long uid) {
|
return (Long) dao.excute(new HibernateCallback<Long>() {
|
|
@Override
|
public Long doInHibernate(Session session) throws HibernateException {
|
Query query = session.createSQLQuery(
|
"SELECT count(1) FROM `yeshi_ec_threesale` t LEFT JOIN yeshi_ec_threesale t1 ON t1.`boss_id`=t.`worker_id` LEFT JOIN `yeshi_ec_user` u ON u.`id`=t1.`worker_id` WHERE t.`boss_id`=? AND u.`id` IS NOT NULL");
|
query.setParameter(0, uid);
|
Object count = query.uniqueResult();
|
return Long.parseLong(count + "");
|
}
|
});
|
}
|
|
@Override
|
public void reComputeUserRank(Long uid) {
|
int myFirstTeamCount = inviteGetMoneyService.myFirstTeamCount(uid + "");
|
int mySecondTeamCount = inviteGetMoneyService.mySecondTeamCount(uid + "");
|
int count = myFirstTeamCount + mySecondTeamCount;
|
UserInfo user = userInfoService.getUserById(uid);
|
if (user == null)
|
return;
|
|
Map<String, String> convertMap = hongBaoManageService.convertMap();
|
int tong = Integer.parseInt(convertMap.get("sale_tong"));
|
int yin = Integer.parseInt(convertMap.get("sale_yin"));
|
int jin = Integer.parseInt(convertMap.get("sale_jin"));
|
int rank = user.getRank();
|
if (count >= jin) {
|
rank = 3;
|
} else if (count >= yin) {
|
rank = 2;
|
} else if (count >= tong) {
|
rank = 1;
|
}
|
|
if (rank > user.getRank()) {
|
// 更新Rank
|
UserInfo userInfo = new UserInfo(uid);
|
userInfo.setRank(rank);
|
userInfoMapper.updateByPrimaryKeySelective(userInfo);
|
}
|
|
}
|
|
@Override
|
public List<ThreeSale> queryMyFirstTeamList(int start, int count, String key, Long bossId) {
|
return threeSaleMapper.queryMyFirstTeamList(start, count, key, bossId);
|
}
|
|
@Override
|
public long queryCountMyFirstTeamList(String key, Long bossId) {
|
return threeSaleMapper.queryCountMyFirstTeamList(key, bossId);
|
}
|
|
@Override
|
public List<ThreeSale> queryMySecondTeamList(int start, int count, String key, Long bossId) {
|
return threeSaleMapper.queryMySecondTeamList(start, count, key, bossId);
|
}
|
|
@Override
|
public long queryCountMySecondTeamList(String key, Long bossId) {
|
return threeSaleMapper.queryCountMySecondTeamList(key, bossId);
|
}
|
|
@Override
|
public int deleteByPrimaryKey(Long id) {
|
return threeSaleMapper.deleteByPrimaryKey(id);
|
}
|
|
@Override
|
public List<Long> queryLongTimeFailed(int daysNum) {
|
return threeSaleMapper.queryLongTimeFailed(daysNum);
|
}
|
|
@Override
|
public List<ThreeSale> queryLongTimeSuccess(int daysNum) {
|
return threeSaleMapper.queryLongTimeSuccess(daysNum);
|
}
|
|
@Override
|
public int updateExpire(List<Long> list) {
|
return threeSaleMapper.updateExpire(list);
|
}
|
|
@Override
|
public List<ThreeSale> listFirstTeamQuery(long start, int count, Long uid, Integer state, String startTime,
|
String endTime) {
|
return threeSaleMapper.listFirstTeamQuery(start, count, uid, state, startTime, endTime);
|
}
|
|
@Override
|
public long countFirstTeamQuery(Long uid, Integer state, String startTime, String endTime) {
|
return threeSaleMapper.countFirstTeamQuery(uid, state, startTime, endTime);
|
}
|
|
@Override
|
public List<ThreeSale> listSecondTeamQuery(long start, int count, Long uid, Integer state, String startTime,
|
String endTime) {
|
return threeSaleMapper.listSecondTeamQuery(start, count, uid, state, startTime, endTime);
|
}
|
|
@Override
|
public long countSecondTeamQuery(Long uid, Integer state, String startTime, String endTime) {
|
return threeSaleMapper.countSecondTeamQuery(uid, state, startTime, endTime);
|
}
|
|
@Override
|
public List<ThreeSale> listSuperiorQuery(long start, int count, Integer state, Long uid) {
|
return threeSaleMapper.listSuperiorQuery(start, count, state, uid);
|
}
|
|
@Override
|
public long countSuperiorQuery(Integer state, Long uid) {
|
return threeSaleMapper.countSuperiorQuery(state, uid);
|
}
|
|
@Override
|
public List<ThreeSale> listFirstTeam(long start, int count, Long uid) {
|
return threeSaleMapper.listFirstTeam(start, count, uid);
|
}
|
|
@Override
|
public long countFirstTeam(Long uid, Integer state) {
|
return threeSaleMapper.countFirstTeam(uid, state);
|
}
|
|
@Override
|
public List<ThreeSale> listSecondTeam(long start, int count, Long uid) {
|
return threeSaleMapper.listSecondTeam(start, count, uid);
|
}
|
|
@Override
|
public long countSecondTeam(Long uid, Integer state) {
|
return threeSaleMapper.countSecondTeam(uid, state);
|
}
|
|
@Override
|
public ThreeSale getMyBoss(Long uid) {
|
return threeSaleMapper.getMyBoss(uid);
|
}
|
|
@Override
|
public ThreeSale selectByPrimaryKey(Long id) {
|
return threeSaleMapper.selectByPrimaryKey(id);
|
}
|
|
@Override
|
public List<ThreeSale> listbyIdAndBossId(Long id, Long uid, Integer expire) {
|
return threeSaleMapper.listbyIdAndBossId(id, uid, expire);
|
}
|
|
@Override
|
public JSONObject getMyFirstTeam(long start, int count, Long uid) {
|
|
List<ThreeSale> list = threeSaleMapper.listFirstTeam(start, count, uid);
|
if (list == null) {
|
list = new ArrayList<ThreeSale>();
|
}
|
|
long countTotal = threeSaleMapper.countFirstTeam(uid, null);
|
|
return organizeTeam(countTotal, list);
|
}
|
|
@Override
|
public JSONObject getMySecondTeam(long start, int count, Long uid) {
|
List<ThreeSale> list = threeSaleMapper.listSecondTeam(start, count, uid);
|
if (list == null) {
|
list = new ArrayList<ThreeSale>();
|
}
|
|
long countTotal = threeSaleMapper.countSecondTeam(uid, null);
|
|
return organizeTeam(countTotal, list);
|
}
|
|
public JSONObject organizeTeam(long count, List<ThreeSale> list) {
|
|
JSONObject result = new JSONObject();
|
|
JSONArray resultArray = new JSONArray();
|
|
for (ThreeSale threeSale : list) {
|
JSONObject object = new JSONObject();
|
SimpleDateFormat sdf = new SimpleDateFormat("MM.dd HH:mm");
|
SimpleDateFormat format = new SimpleDateFormat("yyyy.MM.dd HH:mm");
|
SimpleDateFormat formatYears = new SimpleDateFormat("yyyy");
|
|
Date todayTime = new Date();
|
// 邀请id
|
object.put("inviteId", threeSale.getId());
|
|
// 加入队列时间
|
Long createTime = threeSale.getCreateTime();
|
Date inviteTime = new Date(createTime);
|
object.put("inviteTime", format.format(inviteTime) + " 加入");
|
|
String memoName = "";
|
ThreeSaleExtraInfo threeSaleExtraInfo = threeSale.getThreeSaleExtraInfo();
|
if (threeSaleExtraInfo != null) {
|
if (!StringUtil.isNullOrEmpty(threeSaleExtraInfo.getNickname())) {
|
memoName = threeSaleExtraInfo.getNickname();
|
}
|
}
|
object.put("memoName", memoName);
|
|
String nickName = "";
|
String portrait = "";
|
Long lastLoginTime = null;
|
|
UserInfo worker = threeSale.getWorker();
|
if (worker != null) {
|
portrait = worker.getPortrait();
|
lastLoginTime = worker.getLastLoginTime();
|
nickName = worker.getNickName();
|
}
|
object.put("nickName", nickName);
|
object.put("portrait", portrait);
|
|
int state = 0;
|
String fontColor1 = "#888888";
|
String fontColor2 = "#F14242";
|
|
JSONArray array = new JSONArray();
|
if (threeSale.getState()) {
|
state = 1;
|
if (lastLoginTime == null) {
|
lastLoginTime = threeSale.getCreateTime();
|
}
|
|
JSONObject contentJson = new JSONObject();
|
contentJson.put("color", fontColor1);
|
|
if (formatYears.format(todayTime).equals(formatYears.format(lastLoginTime))) {
|
// 本年
|
contentJson.put("content", "最近登录 " + sdf.format(lastLoginTime));
|
} else {
|
// 往年
|
contentJson.put("content", "最近登录 " + format.format(lastLoginTime));
|
}
|
|
array.add(contentJson);
|
|
} else if (threeSale.getExpire() != null
|
&& (threeSale.getExpire() == 1 || threeSale.getExpire().equals(1))) {
|
state = 2;
|
JSONObject contentJson = new JSONObject();
|
contentJson.put("color", fontColor1);
|
contentJson.put("content", "已经脱离邀请关系");
|
array.add(contentJson);
|
} else {
|
state = 0;
|
|
Calendar c = Calendar.getInstance();
|
c.setTime(inviteTime);
|
c.add(Calendar.DAY_OF_MONTH, 60);// 邀请不超过60天
|
|
long days = (c.getTimeInMillis() - todayTime.getTime()) / (1000 * 3600 * 24);
|
if (days < 0) {
|
days = 0;
|
}
|
|
JSONObject contentJson1 = new JSONObject();
|
contentJson1.put("color", fontColor1);
|
contentJson1.put("content", "将于");
|
|
JSONObject contentJson2 = new JSONObject();
|
contentJson2.put("color", fontColor2);
|
contentJson2.put("content", days + "天");
|
|
JSONObject contentJson3 = new JSONObject();
|
contentJson3.put("color", fontColor1);
|
contentJson3.put("content", "后脱离邀请关系");
|
|
array.add(contentJson1);
|
array.add(contentJson2);
|
array.add(contentJson3);
|
}
|
|
object.put("state", state);
|
object.put("recentMsg", array);
|
|
resultArray.add(object);
|
}
|
|
result.put("count", count);
|
result.put("result_list", resultArray);
|
|
return result;
|
}
|
|
@Override
|
public List<ThreeSale> listByWorkerId(Long workerId) {
|
return threeSaleMapper.listByWorkerId(workerId);
|
}
|
|
@Override
|
public int getSuccessRelationshipNum(Long uid) {
|
return threeSaleMapper.getSuccessRelationshipNum(uid);
|
}
|
|
@Override
|
@Transactional
|
public void bindRelationshipByInviteCode(UserInfo invitee, UserInfo inviter) throws ThreeSaleException {
|
|
if (invitee == null || inviter == null)
|
throw new ThreeSaleException(1, "用户信息为空");
|
|
// 获取有效的邀请关系
|
ThreeSale threeSale = threeSaleMapper.getRelationshipByBossIdAndWorkerId(inviter.getId(), invitee.getId());
|
|
if (threeSale != null) {
|
// 有效关系--生效
|
threeSale.setState(true);
|
threeSale.setExpire(ThreeSale.EXPIRE_NORMAL);
|
threeSale.setSucceedTime(java.lang.System.currentTimeMillis());
|
threeSale.setUpdateTime(java.lang.System.currentTimeMillis());
|
threeSaleMapper.updateByPrimaryKeySelective(threeSale);
|
} else {
|
// 新建立确定关系
|
threeSale = new ThreeSale();
|
threeSale.setBoss(inviter);
|
threeSale.setWorker(invitee);
|
threeSale.setState(true);
|
threeSale.setExpire(ThreeSale.EXPIRE_NORMAL);
|
threeSale.setSucceedTime(java.lang.System.currentTimeMillis());
|
threeSale.setCreateTime(java.lang.System.currentTimeMillis());
|
threeSale.setUpdateTime(java.lang.System.currentTimeMillis());
|
threeSaleMapper.insertSelective(threeSale);
|
|
}
|
|
List<ThreeSale> listExpire = threeSaleMapper.getExpireRecord(inviter.getId(), invitee.getId());
|
if (listExpire != null && listExpire.size() > 0) {
|
// 删除历史通知
|
for (ThreeSale saleExpire : listExpire) {
|
msgInviteDetailService.deleteByThreeSale(saleExpire);
|
}
|
// 删除已失效关系
|
threeSaleMapper.deleteExpireRecord(inviter.getId(), invitee.getId());
|
}
|
|
// 邀请消息
|
userInviteMsgNotificationService.inviteSuccess(inviter.getId(), threeSale);
|
}
|
|
@Override
|
public long countSuccessFirstTeam(Long uid) {
|
return threeSaleMapper.countFirstTeam(uid,1);
|
}
|
|
}
|