if (buyer instanceof UserImpl) {
try {
UserImpl godson = (UserImpl)buyer;
UserDao uDao = DaoFactory.getUserDao();
ProductPointDao ppDao = DaoFactory.getProductPointDao();
UserPointDao upDao = DaoFactory.getUserPointDao();
UserImpl godfather = (UserImpl)uDao.findUser(godson.getGodfather());
if (godfather != null) {
ProductPoint pp = ppDao.get(p, years, ProductPoint.GODSON);
if (pp.getPoints()!=0) {
UserPoint oldGFUP = getUserPoint(godfather);
UserPoint gfUP = UserPointFactory.godson(godfather, oldGFUP, godson, p, subscribedUsers, pp);
upDao.save(gfUP);
ServiceFactory.getRegistrationService().sendFidelityAccountPointEarnedByGodSonBuyMail(godfather, godson, p, subscribedUsers, years, gfUP.getEarnedPoints(), gfUP.getPoints());
LOGGER.info("adding " + pp.getPoints() + " to user: " + godfather.getId() + ", his godson: " + godson.getId() + " bought " + p.getCode() + " for " + years + " years");
}
} else {
LOGGER.info("user: " + buyer.getId() + " does not have a godfather");
}
ProductPoint pp = ppDao.get(p, years, ProductPoint.PURCHASE);
if (pp != null && pp.getPoints()!=0) {
UserPoint oldGSUP = getUserPoint(godson);
UserPoint gsUP = UserPointFactory.purchase(godson, oldGSUP, p, subscribedUsers, pp);
upDao.save(gsUP);
ServiceFactory.getRegistrationService().sendFidelityAccountPointEarnedBySelfPurchaseMail(godson, p, subscribedUsers, years, gsUP.getEarnedPoints(), gsUP.getPoints());
LOGGER.info("adding " + pp.getPoints() + " to user: " + godson.getId() + ", he bought " + p.getCode() + " for " + years + " years");
}
} catch (DaoException e) {
LOGGER.warn("cannot add fidelity points to user: " + buyer.getId(), e);