From f4a0f2acc63d7785eab108419a4e16f5f688cb95 Mon Sep 17 00:00:00 2001
From: yujian <yujian@163.com>
Date: 星期六, 18 一月 2020 12:06:27 +0800
Subject: [PATCH] 用户注册信息

---
 fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserActiveLogServiceImpl.java |   83 +++++++++++++++++++++++++++++++++++++++++
 1 files changed, 83 insertions(+), 0 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserActiveLogServiceImpl.java b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserActiveLogServiceImpl.java
index 2638ebc..108380c 100644
--- a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserActiveLogServiceImpl.java
+++ b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserActiveLogServiceImpl.java
@@ -1,20 +1,33 @@
 package com.yeshi.fanli.service.impl.user;
 
+import java.text.ParseException;
 import java.util.Date;
+import java.util.List;
 
 import javax.annotation.Resource;
 
 import org.springframework.stereotype.Service;
+import org.yeshi.utils.DateUtil;
 
 import com.yeshi.fanli.dao.mybatis.user.UserActiveLogMapper;
+import com.yeshi.fanli.dao.user.UserActiveNumHistoryDao;
 import com.yeshi.fanli.entity.bus.user.UserActiveLog;
+import com.yeshi.fanli.entity.bus.user.UserActiveNumHistory;
 import com.yeshi.fanli.service.inter.user.UserActiveLogService;
+import com.yeshi.fanli.service.inter.user.UserInfoExtraService;
+import com.yeshi.fanli.util.TimeUtil;
 
 @Service
 public class UserActiveLogServiceImpl implements UserActiveLogService {
 
 	@Resource
 	private UserActiveLogMapper userActiveLogMapper;
+	
+	@Resource
+	private UserActiveNumHistoryDao userActiveNumHistoryDao;
+	
+	@Resource
+	private UserInfoExtraService userInfoExtraService;
 
 	@Override
 	public void addUserActiveLog(UserActiveLog userActiveLog) {
@@ -28,6 +41,21 @@
 			userActiveLog.setCreateTime(new Date());
 			userActiveLog.setUpdateTime(new Date());
 			userActiveLogMapper.insertSelective(userActiveLog);
+			// 鏇存柊鏈�鏂版椿璺冩椂闂�
+			userInfoExtraService.updateActiveTime(userActiveLog.getUid() , new Date());
+		} else if (latestLog != null) {
+			// 濡傛灉璁惧 锛岀増鏈紝娓犻亾鏈夊彉鍖栧垯闇�瑕佹洿鏀�
+			String oldIdentify = latestLog.getDevice() + "#" + latestLog.getVersionCode() + "#"
+					+ latestLog.getChannel();
+			String newIdentify = userActiveLog.getDevice() + "#" + userActiveLog.getVersionCode() + "#"
+					+ userActiveLog.getChannel();
+			if (!oldIdentify.equalsIgnoreCase(newIdentify)) {// 璁惧淇℃伅鍙樺寲瑕佽褰曚俊鎭�
+				userActiveLog.setCreateTime(new Date());
+				userActiveLog.setUpdateTime(new Date());
+				userActiveLogMapper.insertSelective(userActiveLog);
+				// 鏇存柊鏈�鏂版椿璺冩椂闂�
+				userInfoExtraService.updateActiveTime(userActiveLog.getUid() , new Date());
+			}
 		}
 	}
 
@@ -36,8 +64,63 @@
 		return userActiveLogMapper.selectLatestByUid(uid);
 	}
 
+	@Override
+	public UserActiveLog getFirstActiveInfo(Long uid) {
+		return userActiveLogMapper.selectFirstActiveInfo(uid);
+	}
+
+	@Override
+	public List<UserActiveNumHistory> query(Date startTime, Date endTime){
+		// 閲嶆柊鏌ヨ缁熻浠婃棩浠ュ強绌虹己
+		initUserActiveNumCount();
+		
+		return userActiveNumHistoryDao.query(startTime, endTime);
+	}
 	
 	
+	// 鍒濆鍖栫粺璁�
+	private void initUserActiveNumCount() {
+		UserActiveNumHistory history = userActiveNumHistoryDao.getMaxDate();
+		Date lastDay = null;
+		if (history != null && history.getDay() != null)
+			lastDay = history.getDay();
+		
+		Date today = new Date();
+		try {
+			if (lastDay == null)
+				lastDay = TimeUtil.parse("2018-09-01");
+			int betweenDays = DateUtil.daysBetween2(lastDay, today);
+			
+			// 缁熻浠婃棩涔嬪墠鐨�
+			if (betweenDays > 0) {
+				for (int i = 1; i <= betweenDays; i++ ) {
+					addUserActiveNumHistory(DateUtil.plusDay(i, lastDay));
+				}
+			}
+			// 閲嶆柊缁熻浠婃棩
+			addUserActiveNumHistory(TimeUtil.getGernalTime(today.getTime()));
+		} catch (Exception e) {
+			// 
+		}
+	}
+	
+	/*
+	 * 缁熻褰撳ぉ娲昏穬鐢ㄦ埛涓湁澶氬皯涓敤鎴锋槸90澶╁墠鎵嶆椿璺冭繃锛屾湡闂翠粠鏈椿璺冪殑鐢ㄦ埛鏁伴噺銆�
+	 */
+	@Override
+	public void addUserActiveNumHistory(String date){
+		int num = userActiveLogMapper.countActiveNumByDate(date);
+		
+		UserActiveNumHistory history = new UserActiveNumHistory();
+		history.setId(date);
+		history.setNum(num);
+		try {
+			history.setDay(TimeUtil.parse(date));
+		} catch (ParseException e) {
+			e.printStackTrace();
+		}
+		userActiveNumHistoryDao.save(history);
+	}
 	
 	
 }

--
Gitblit v1.8.0