X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=org.argeo.security.core%2Fsrc%2Forg%2Fargeo%2Fsecurity%2FUserAdminService.java;fp=org.argeo.security.core%2Fsrc%2Forg%2Fargeo%2Fsecurity%2FUserAdminService.java;h=0a84cf66ff1b83538ebd7030d6fa9cd4fc839f3f;hb=10ed6557c631d5feee8541badd0c9f16a9e791c6;hp=0000000000000000000000000000000000000000;hpb=864072113f7a44fd2a291a4cb50659d6e67f8c29;p=lgpl%2Fargeo-commons.git diff --git a/org.argeo.security.core/src/org/argeo/security/UserAdminService.java b/org.argeo.security.core/src/org/argeo/security/UserAdminService.java new file mode 100644 index 000000000..0a84cf66f --- /dev/null +++ b/org.argeo.security.core/src/org/argeo/security/UserAdminService.java @@ -0,0 +1,60 @@ +/* + * Copyright (C) 2007-2012 Argeo GmbH + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package org.argeo.security; + +import java.util.Set; + +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 add upper-case, add '@') + */ + //public final static String USERNAME_PATTERN = "^[a-zA-Z0-9_-@]{3,64}$"; + + /** + * Email addresses must match this regexp pattern ({@value #EMAIL_PATTERN}. + * Thanks to this tip. + */ + public final static String EMAIL_PATTERN = "^[_A-Za-z0-9-]+(\\.[_A-Za-z0-9-]+)*@[A-Za-z0-9-]+(\\.[A-Za-z0-9]+)*(\\.[A-Za-z]{2,})$"; + + /* + * USERS + */ + /** List all users. */ + public Set listUsers(); + + /** List users having this role (except the super user). */ + public Set listUsersInRole(String role); + + /** Synchronize with the underlying DAO. */ + public void synchronize(); + + /* + * ROLES + */ + public void newRole(String role); + + public Set listEditableRoles(); + + public void deleteRole(String role); +}