}
public void buy(User buyer, Product p, int years, int subscribedUsers) {
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);