package org.hadatac.console.service; import org.hadatac.console.models.SysUser; import play.Application; import com.feth.play.module.pa.user.AuthUser; import com.feth.play.module.pa.user.AuthUserIdentity; import com.feth.play.module.pa.service.UserServicePlugin; import com.google.inject.Inject; public class MyUserServicePlugin extends UserServicePlugin { @Inject public MyUserServicePlugin(final Application app) { super(app); } @Override public Object save(final AuthUser authUser) { return saveSolr(authUser); } public Object saveSolr(final AuthUser authUser) { final boolean isLinked = SysUser.existsByAuthUserIdentity(authUser); if (!isLinked) { return SysUser.create(authUser).getId(); } else { // we have this user already, so return null return null; } } @Override public Object getLocalIdentity(final AuthUserIdentity identity) { // For production: Caching might be a good idea here... // ...and dont forget to sync the cache when users get deactivated/deleted final SysUser u = SysUser.findByAuthUserIdentity(identity); if(u != null) { return u.getId(); } else { return null; } } @Override public AuthUser merge(final AuthUser newUser, final AuthUser oldUser) { if (!oldUser.equals(newUser)) { SysUser.merge(oldUser, newUser); } return oldUser; } @Override public AuthUser link(final AuthUser oldUser, final AuthUser newUser) { SysUser.addLinkedAccount(oldUser, newUser); return newUser; } @Override public AuthUser update(final AuthUser knownUser) { // User logged in again, bump last login date SysUser.setLastLoginDate(knownUser); return knownUser; } }