/**
* Copyright (c) 2012 SUSE LLC
*
* This software is licensed to you under the GNU General Public License,
* version 2 (GPLv2). There is NO WARRANTY for this software, express or
* implied, including the implied warranties of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. You should have received a copy of GPLv2
* along with this software; if not, see
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.txt.
*
* Red Hat trademarks are not licensed under GPLv2. No permission is
* granted to use or replicate Red Hat trademarks that are incorporated
* in this software or its documentation.
*/
package com.redhat.rhn.frontend.action.user;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts.action.ActionErrors;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import org.apache.struts.action.ActionMessage;
import org.apache.struts.action.ActionMessages;
import com.redhat.rhn.domain.credentials.Credentials;
import com.redhat.rhn.domain.credentials.CredentialsFactory;
import com.redhat.rhn.domain.user.User;
import com.redhat.rhn.frontend.struts.RequestContext;
import com.redhat.rhn.frontend.struts.RhnAction;
import com.redhat.rhn.frontend.struts.RhnHelper;
/**
* Create and edit credentials for external systems or APIs.
*/
public class UserCredentialsEditAction extends RhnAction {
private static final String ATTRIB_CREDS = "creds";
private static final String PARAM_USER = "studio_user";
private static final String PARAM_KEY = "studio_key";
private static final String PARAM_URL = "studio_url";
private static final String DEFAULT_URL = "https://susestudio.com";
/** {@inheritDoc} */
@Override
public ActionForward execute(ActionMapping mapping, ActionForm formIn,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
RequestContext ctx = new RequestContext(request);
// Lookup this user's credentials
User user = ctx.getCurrentUser();
Credentials creds = CredentialsFactory.lookupStudioCredentials(user);
if (creds == null) {
// Create new credentials if necessary
creds = CredentialsFactory.createStudioCredentials(user);
creds.setUrl(DEFAULT_URL);
}
request.setAttribute(ATTRIB_CREDS, creds);
if (ctx.isSubmitted()) {
// The form was submitted, create a temporary object
Credentials newCreds = CredentialsFactory.createCredentials();
newCreds.setUsername(request.getParameter(PARAM_USER).trim());
newCreds.setPassword(request.getParameter(PARAM_KEY).trim());
newCreds.setUrl(normalizeURL(request.getParameter(PARAM_URL)));
// Check for completeness
if (newCreds.isEmpty() || newCreds.isComplete()) {
if (newCreds.isEmpty()) {
// Delete from DB
CredentialsFactory.removeCredentials(creds);
request.setAttribute(ATTRIB_CREDS, newCreds);
}
else {
// Store the credentials
creds.setUsername(newCreds.getUsername());
creds.setPassword(newCreds.getPassword());
String url = newCreds.getUrl();
creds.setUrl(url.isEmpty() ? DEFAULT_URL : url);
CredentialsFactory.storeCredentials(creds);
}
ActionMessages messages = new ActionMessages();
messages.add(ActionMessages.GLOBAL_MESSAGE, new ActionMessage(
"credentials.message.updated"));
getStrutsDelegate().saveMessages(request, messages);
}
else {
// Incomplete credentials, show an error
ActionErrors errors = new ActionErrors();
errors.add(ActionMessages.GLOBAL_MESSAGE, new ActionMessage(
"credentials.message.incomplete"));
getStrutsDelegate().saveMessages(request, errors);
request.setAttribute(ATTRIB_CREDS, newCreds);
}
}
return mapping.findForward(RhnHelper.DEFAULT_FORWARD);
}
/**
* Very basic URL normalization.
* @param url
* @return url normalized
*/
private String normalizeURL(String url) {
String ret = url;
if (ret != null) {
// trim() and make all lowercase
ret = url.trim().toLowerCase();
// Remove trailing slashes
while (ret.endsWith("/")) {
ret = ret.substring(0, ret.length() - 1);
}
}
return ret;
}
}