/**
* Koya is an alfresco module that provides a corporate orientated dataroom.
*
* Copyright (C) Itl Developpement 2014
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see `<http://www.gnu.org/licenses/>`.
*/
package fr.itldev.koya.webscript.user;
import java.io.IOException;
import java.util.Map;
import org.alfresco.service.cmr.security.AuthorityService;
import org.alfresco.service.cmr.security.MutableAuthenticationService;
import org.springframework.extensions.webscripts.AbstractWebScript;
import org.springframework.extensions.webscripts.WebScriptException;
import org.springframework.extensions.webscripts.WebScriptRequest;
import org.springframework.extensions.webscripts.WebScriptResponse;
import fr.itldev.koya.alfservice.UserService;
import fr.itldev.koya.exception.KoyaServiceException;
import fr.itldev.koya.webscript.KoyaWebscript;
/**
* change user password
*
* user can change his password given old one
*
* admin can force change user password
*
* TODO encrypt password with user key?
*
*
*/
public class ChangePassword extends AbstractWebScript {
private UserService userService;
private MutableAuthenticationService authenticationService;
private AuthorityService authorityService;
public void setUserService(UserService userService) {
this.userService = userService;
}
public void setAuthenticationService(MutableAuthenticationService authenticationService) {
this.authenticationService = authenticationService;
}
public void setAuthorityService(AuthorityService authorityService) {
this.authorityService = authorityService;
}
@Override
public void execute(WebScriptRequest req, WebScriptResponse res) throws IOException {
Map<String, Object> params = KoyaWebscript.getJsonMap(req);
Boolean isAdmin = authorityService.isAdminAuthority(authenticationService.getCurrentUserName());
String username = null;
String oldpwd = null;
String newpwd = null;
try {
username = (String) params.get("userName");
} catch (Exception e) {
}
try {
oldpwd = (String) params.get("oldPwd");
} catch (Exception e) {
}
try {
newpwd = (String) params.get("newPwd");
} catch (Exception e) {
}
try {
if (username != null && isAdmin) {
userService.adminForceChangePassword(username, newpwd);
} else {
userService.changePassword(oldpwd, newpwd);
}
} catch (KoyaServiceException ex) {
throw new WebScriptException("KoyaError : " + ex.getErrorCode().toString());
}
res.setContentType("application/json;charset=UTF-8");
res.getWriter().write("");
}
}