package com.yeshi.makemoney.app.service.impl.money;
|
|
import com.yeshi.makemoney.app.dao.money.UserExtractMoneyLimitDao;
|
import com.yeshi.makemoney.app.dao.money.UserExtractMoneyLimitDao.DaoQuery;
|
import com.yeshi.makemoney.app.entity.money.UserExtractMoneyLimit;
|
import com.yeshi.makemoney.app.exception.money.UserExtractMoneyLimitException;
|
import com.yeshi.makemoney.app.service.inter.money.UserExtractMoneyLimitService;
|
import com.yeshi.makemoney.app.service.query.money.UserExtractMoneyLimitQuery;
|
import org.springframework.data.mongodb.core.query.Criteria;
|
import org.springframework.data.mongodb.core.query.Query;
|
import org.springframework.stereotype.Service;
|
import org.yeshi.utils.TimeUtil;
|
import org.yeshi.utils.bean.BeanUtil;
|
|
import javax.annotation.Resource;
|
import java.util.Date;
|
import java.util.List;
|
|
@Service
|
public class UserExtractMoneyLimitServiceImpl implements UserExtractMoneyLimitService {
|
|
@Resource
|
private UserExtractMoneyLimitDao userExtractMoneyLimitDao;
|
|
@Override
|
public List<UserExtractMoneyLimit> list(UserExtractMoneyLimitQuery userExtractMoneyLimitQuery, int page, int pageSize) {
|
DaoQuery daoQuery = new DaoQuery();
|
try {
|
BeanUtil.copyProperties(userExtractMoneyLimitQuery, daoQuery);
|
} catch (IllegalAccessException e) {
|
e.printStackTrace();
|
}
|
daoQuery.start = (page - 1) * pageSize;
|
daoQuery.count = pageSize;
|
return userExtractMoneyLimitDao.list(daoQuery);
|
}
|
|
@Override
|
public long count(UserExtractMoneyLimitQuery userExtractMoneyLimitQuery) {
|
DaoQuery daoQuery = new DaoQuery();
|
try {
|
BeanUtil.copyProperties(userExtractMoneyLimitQuery, daoQuery);
|
} catch (IllegalAccessException e) {
|
e.printStackTrace();
|
}
|
return userExtractMoneyLimitDao.count(daoQuery);
|
}
|
|
@Override
|
public UserExtractMoneyLimit get(String id) {
|
Query query = new Query();
|
query.addCriteria(Criteria.where("_id").is(id));
|
return userExtractMoneyLimitDao.findOne(query);
|
}
|
|
@Override
|
public void add(UserExtractMoneyLimit userExtractMoneyLimit) throws UserExtractMoneyLimitException {
|
//查询主键ID是否存在
|
if (userExtractMoneyLimitDao.get(userExtractMoneyLimit.getId()) != null) {
|
throw new UserExtractMoneyLimitException(UserExtractMoneyLimitException.CODE_EXIST, "已存在");
|
}
|
|
if (userExtractMoneyLimit.getCreateTime() == null) {
|
userExtractMoneyLimit.setCreateTime(new Date());
|
}
|
//保存
|
userExtractMoneyLimitDao.save(userExtractMoneyLimit);
|
}
|
|
@Override
|
public void update(UserExtractMoneyLimit userExtractMoneyLimit) {
|
if (userExtractMoneyLimit.getUpdateTime() == null) {
|
userExtractMoneyLimit.setUpdateTime(new Date());
|
}
|
//更新
|
userExtractMoneyLimitDao.updateSelective(userExtractMoneyLimit);
|
}
|
|
@Override
|
public void delete(List<String> idList) {
|
for (String id : idList) {
|
userExtractMoneyLimitDao.delete(id);
|
}
|
}
|
|
@Override
|
public void addLittleMoneyLimit(Long uid, int count,Date date) throws UserExtractMoneyLimitException {
|
UserExtractMoneyLimit limit = new UserExtractMoneyLimit();
|
limit.setCount(count);
|
limit.setDay(TimeUtil.getGernalTime(date.getTime(), "yyyy-MM-dd"));
|
limit.setUid(uid);
|
limit.setMinMoney(0);
|
limit.setMaxMoney(1 * 100);
|
UserExtractMoneyLimit old = get(limit.toId());
|
if (old != null) {
|
UserExtractMoneyLimit update = new UserExtractMoneyLimit();
|
update.setId(old.getId());
|
update.setCount(count + old.getCount());
|
userExtractMoneyLimitDao.updateSelective(update);
|
return;
|
}
|
add(limit);
|
}
|
|
@Override
|
public int getLittleMoneyLimit(Long uid,Date date) {
|
UserExtractMoneyLimit limit = new UserExtractMoneyLimit();
|
limit.setDay(TimeUtil.getGernalTime(date.getTime(), "yyyy-MM-dd"));
|
limit.setUid(uid);
|
limit.setMinMoney(0);
|
limit.setMaxMoney(1 * 100);
|
UserExtractMoneyLimit old = get(limit.toId());
|
if (old == null) {
|
return 0;
|
}
|
return old.getCount();
|
}
|
|
|
}
|