use of org.craftercms.profile.api.Ticket in project profile by craftercms.
the class AuthenticationManagerImplTest method getTicket1.
private Ticket getTicket1() {
Ticket ticket = new Ticket();
ticket.setId(TICKET_ID1);
ticket.setTenant(TENANT1);
ticket.setProfileId(PROFILE_ID1.toString());
ticket.setLastRequestTime(new Date());
return ticket;
}
use of org.craftercms.profile.api.Ticket in project profile by craftercms.
the class AuthenticationManagerImplTest method getTicket2.
private Ticket getTicket2() {
Ticket ticket = new Ticket();
ticket.setId(TICKET_ID2);
ticket.setTenant(TENANT2);
ticket.setProfileId(PROFILE_ID2.toString());
ticket.setLastRequestTime(new Date());
return ticket;
}
use of org.craftercms.profile.api.Ticket in project profile by craftercms.
the class AuthenticationServiceImpl method invalidateTicket.
@Override
public void invalidateTicket(String ticketId) throws ProfileException {
try {
Ticket ticket = ticketRepository.findByStringId(ticketId);
if (ticket != null) {
checkIfManageTicketsIsAllowed(ticket.getTenant());
ticketRepository.removeByStringId(ticketId);
logger.debug(LOG_KEY_TICKET_INVALIDATED, ticketId);
}
} catch (MongoDataException e) {
throw new I10nProfileException(ERROR_KEY_DELETE_TICKET_ERROR, ticketId);
}
}
use of org.craftercms.profile.api.Ticket in project profile by craftercms.
the class AuthenticationServiceImpl method authenticate.
@Override
public Ticket authenticate(String tenantName, String username, String password) throws ProfileException {
checkIfManageTicketsIsAllowed(tenantName);
Profile profile = profileService.getProfileByUsername(tenantName, username, ProfileConstants.NO_ATTRIBUTE);
if (profile == null) {
// Invalid username
throw new BadCredentialsException();
}
if (!profile.isEnabled()) {
throw new DisabledProfileException(profile.getId().toString(), tenantName);
}
if (isProfileInTimeOut(profile)) {
throw new ProfileLockedException();
}
try {
if (!CryptoUtils.matchPassword(profile.getPassword(), password)) {
// Invalid password
countAsFail(profile);
throw new BadCredentialsException();
}
clearAllLoginAttempts(profile);
Ticket ticket = new Ticket();
ticket.setId(UUID.randomUUID().toString());
ticket.setTenant(tenantName);
ticket.setProfileId(profile.getId().toString());
ticket.setLastRequestTime(new Date());
ticketRepository.insert(ticket);
logger.debug(LOG_KEY_AUTHENTICATION_SUCCESSFUL, profile.getId(), ticket);
return ticket;
} catch (MongoDataException e) {
throw new I10nProfileException(ERROR_KEY_CREATE_TICKET_ERROR, profile.getId());
}
}
use of org.craftercms.profile.api.Ticket in project profile by craftercms.
the class AuthenticationServiceImpl method createTicket.
@Override
public Ticket createTicket(String profileId) throws ProfileException {
Profile profile = profileService.getProfile(profileId, ProfileConstants.NO_ATTRIBUTE);
if (profile != null) {
String tenantName = profile.getTenant();
checkIfManageTicketsIsAllowed(tenantName);
if (!profile.isEnabled()) {
throw new DisabledProfileException(profile.getId().toString(), tenantName);
}
try {
Ticket ticket = new Ticket();
ticket.setId(UUID.randomUUID().toString());
ticket.setTenant(tenantName);
ticket.setProfileId(profile.getId().toString());
ticket.setLastRequestTime(new Date());
ticketRepository.insert(ticket);
logger.debug(LOG_KEY_TICKET_CREATED, profile.getId(), ticket);
return ticket;
} catch (MongoDataException e) {
throw new I10nProfileException(ERROR_KEY_CREATE_TICKET_ERROR, profile.getId());
}
} else {
throw new NoSuchProfileException.ById(profileId);
}
}
Aggregations