package com.mossle.auth.subscribe; import java.io.IOException; import javax.annotation.Resource; import com.mossle.api.user.UserDTO; import com.mossle.auth.component.AuthCache; import com.mossle.core.id.IdGenerator; import com.mossle.core.mapper.JsonMapper; import com.mossle.core.subscribe.Subscribable; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.stereotype.Component; import org.springframework.transaction.annotation.Transactional; @Transactional @Component("com.mossle.auth.component.UserCreatedSubscriber") public class UserCreatedSubscriber implements Subscribable<String> { private static Logger logger = LoggerFactory .getLogger(UserCreatedSubscriber.class); private String insertSql = "INSERT INTO AUTH_USER_STATUS(ID,USERNAME,REF,STATUS,PASSWORD,USER_REPO_REF,TENANT_ID) VALUES(?,?,?,1,'',?,?)"; private JsonMapper jsonMapper = new JsonMapper(); private String destinationName = "queue.user.sync.created"; private JdbcTemplate jdbcTemplate; private AuthCache authCache; private IdGenerator idGenerator; public void handleMessage(String message) { try { UserDTO userDto = jsonMapper.fromJson(message, UserDTO.class); String tenantId = userDto.getUserRepoRef(); jdbcTemplate.update(insertSql, idGenerator.generateId(), userDto.getUsername(), userDto.getId(), tenantId, tenantId); logger.info("create user : {}", message); authCache.evictUser(userDto.getId()); } catch (IOException ex) { logger.error(ex.getMessage(), ex); } } public boolean isTopic() { return false; } public String getName() { return destinationName; } public void setDestinationName(String destinationName) { this.destinationName = destinationName; } @Resource public void setJdbcTemplate(JdbcTemplate jdbcTemplate) { this.jdbcTemplate = jdbcTemplate; } @Resource public void setAuthCache(AuthCache authCache) { this.authCache = authCache; } @Resource public void setIdGenerator(IdGenerator idGenerator) { this.idGenerator = idGenerator; } }