org.broadleafcommerce.openadmin.server.security.service.AdminSecurityService Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of broadleaf-open-admin-platform Show documentation
Show all versions of broadleaf-open-admin-platform Show documentation
BroadleafCommerce Open Admin Platform
/*
* Copyright 2008-2012 the original author or authors.
*
* 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.broadleafcommerce.openadmin.server.security.service;
import org.broadleafcommerce.common.security.util.PasswordChange;
import org.broadleafcommerce.common.service.GenericResponse;
import org.broadleafcommerce.openadmin.server.security.domain.AdminPermission;
import org.broadleafcommerce.openadmin.server.security.domain.AdminRole;
import org.broadleafcommerce.openadmin.server.security.domain.AdminUser;
import org.broadleafcommerce.openadmin.server.security.service.type.PermissionType;
import java.util.List;
/**
*
* @author jfischer
*
*/
public interface AdminSecurityService {
List readAllAdminUsers();
AdminUser readAdminUserById(Long id);
AdminUser readAdminUserByUserName(String userName);
AdminUser saveAdminUser(AdminUser user);
void deleteAdminUser(AdminUser user);
List readAllAdminRoles();
AdminRole readAdminRoleById(Long id);
AdminRole saveAdminRole(AdminRole role);
void deleteAdminRole(AdminRole role);
List readAllAdminPermissions();
AdminPermission readAdminPermissionById(Long id);
AdminPermission saveAdminPermission(AdminPermission permission);
void deleteAdminPermission(AdminPermission permission);
AdminUser changePassword(PasswordChange passwordChange);
boolean isUserQualifiedForOperationOnCeilingEntity(AdminUser adminUser, PermissionType permissionType, String ceilingEntityFullyQualifiedName);
boolean doesOperationExistForCeilingEntity(PermissionType permissionType, String ceilingEntityFullyQualifiedName);
/**
* Looks up the corresponding AdminUser and emails the address on file with
* the associated username.
*
* @param emailAddress
* @return Response can contain errors including (notFound)
*
*/
GenericResponse sendForgotUsernameNotification(String emailAddress);
/**
* Generates an access token and then emails the user.
*
* @param userName
* @return Response can contain errors including (invalidEmail, invalidUsername, inactiveUser)
*
*/
GenericResponse sendResetPasswordNotification(String userName);
/**
* Updates the password for the passed in user only if the passed
* in token is valid for that user.
*
* @param username Name of the user
* @param token Valid reset token
* @param password new password
*
* @return Response can contain errors including (invalidUsername, inactiveUser, invalidToken, invalidPassword, tokenExpired, passwordMismatch)
*/
GenericResponse resetPasswordUsingToken(String username, String token, String password, String confirmPassword);
GenericResponse changePassword(String username, String oldPassword, String password, String confirmPassword);
}