X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;ds=sidebyside;f=security%2Fruntime%2Forg.argeo.security.core%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fsecurity%2FUserAdminService.java;h=65bc4bb251eb2dba8afe374aa7a3baac656bb818;hb=6bb0606505be3e99021c5ff9771c719eb1e1f2e7;hp=5fc482f903fdb4028c2698232b56f1a9124e61de;hpb=019e0f2af17286be08ab17c1c9e1d8ba871ec9b2;p=lgpl%2Fargeo-commons.git diff --git a/security/runtime/org.argeo.security.core/src/main/java/org/argeo/security/UserAdminService.java b/security/runtime/org.argeo.security.core/src/main/java/org/argeo/security/UserAdminService.java index 5fc482f90..65bc4bb25 100644 --- a/security/runtime/org.argeo.security.core/src/main/java/org/argeo/security/UserAdminService.java +++ b/security/runtime/org.argeo.security.core/src/main/java/org/argeo/security/UserAdminService.java @@ -1,16 +1,18 @@ package org.argeo.security; -import java.util.List; import java.util.Set; -public interface UserAdminService { +import org.springframework.security.userdetails.UserDetailsManager; + +/** Enrich {@link UserDetailsManager} in order to provide roles semantics. */ +public interface UserAdminService extends UserDetailsManager { /** * Usernames must match this regexp pattern ({@value #USERNAME_PATTERN}). * Thanks to this tip (modified to remove '-') + * >this tip (modified to add upper-case, add '@') */ - public final static String USERNAME_PATTERN = "^[a-z0-9_]{3,15}$"; + //public final static String USERNAME_PATTERN = "^[a-zA-Z0-9_-@]{3,64}$"; /** * Email addresses must match this regexp pattern ({@value #EMAIL_PATTERN}. @@ -23,24 +25,14 @@ public interface UserAdminService { /* * USERS */ - public void newUser(ArgeoUser argeoUser); - - public ArgeoUser getUser(String username); - - public Set listUsers(); - - public Boolean userExists(String username); - - public void updateUser(ArgeoUser user); - - public void updateUserPassword(String username, String password); + /** List all users. */ + public Set listUsers(); /** List users having this role (except the super user). */ - public Set listUsersInRole(String role); - - public List listUserRoles(String username); + public Set listUsersInRole(String role); - public void deleteUser(String username); + /** Synchronize with the underlying DAO. */ + public void synchronize(); /* * ROLES