/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. The ASF licenses this file to You
* 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. For additional information regarding
* copyright in this work, please see the NOTICE file in the top level
* directory of this distribution.
*/
package org.apache.roller.ui.authoring.struts.actions;
import java.net.MalformedURLException;
import java.text.MessageFormat;
import java.util.ResourceBundle;
import javax.mail.MessagingException;
import javax.mail.Session;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.struts.action.ActionError;
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 org.apache.struts.actions.DispatchAction;
import org.apache.struts.util.RequestUtils;
import org.apache.roller.RollerException;
import org.apache.roller.config.RollerConfig;
import org.apache.roller.config.RollerRuntimeConfig;
import org.apache.roller.business.Roller;
import org.apache.roller.business.RollerFactory;
import org.apache.roller.business.UserManager;
import org.apache.roller.pojos.PermissionsData;
import org.apache.roller.pojos.UserData;
import org.apache.roller.pojos.WebsiteData;
import org.apache.roller.ui.core.BasePageModel;
import org.apache.roller.ui.core.RollerContext;
import org.apache.roller.ui.core.RollerRequest;
import org.apache.roller.ui.core.RollerSession;
import org.apache.roller.ui.authoring.struts.formbeans.InviteMemberForm;
import org.apache.roller.util.MailUtil;
/**
* Allows website admin to invite new members to website.
*
* @struts.action path="/roller-ui/authoring/inviteMember" parameter="method" name="inviteMemberForm"
* @struts.action-forward name="inviteMember.page" path=".InviteMember"
*/
public class InviteMemberAction extends DispatchAction {
private static Log mLogger =
LogFactory.getFactory().getInstance(InviteMemberAction.class);
/** If method param is not specified, use HTTP verb to pick method to call */
public ActionForward unspecified(
ActionMapping mapping,
ActionForm actionForm,
HttpServletRequest request,
HttpServletResponse response)
throws Exception {
if (request.getMethod().equals("GET")) {
return edit(mapping, actionForm, request, response);
}
return send(mapping, actionForm, request, response);
}
public ActionForward cancel(
ActionMapping mapping,
ActionForm actionForm,
HttpServletRequest request,
HttpServletResponse response)
throws Exception {
return mapping.findForward("memberPermissions");
}
public ActionForward edit(
ActionMapping mapping,
ActionForm actionForm,
HttpServletRequest request,
HttpServletResponse response)
throws Exception {
// if group blogging is disabled then you can't change permissions
if (!RollerConfig.getBooleanProperty("groupblogging.enabled")) {
return mapping.findForward("access-denied");
}
BasePageModel pageModel = new BasePageModel(
"inviteMember.title", request, response, mapping);
RollerSession rses = RollerSession.getRollerSession(request);
// Ensure use has admin perms for this weblog
if (pageModel.getWebsite() != null && rses.isUserAuthorizedToAdmin(pageModel.getWebsite())) {
request.setAttribute("model", pageModel);
InviteMemberForm form = (InviteMemberForm)actionForm;
form.setWebsiteId(pageModel.getWebsite().getId());
ActionForward forward = mapping.findForward("inviteMember.page");
return forward;
} else {
return mapping.findForward("access-denied");
}
}
public ActionForward send(
ActionMapping mapping,
ActionForm actionForm,
HttpServletRequest request,
HttpServletResponse response)
throws Exception {
// if group blogging is disabled then you can't change permissions
if (!RollerConfig.getBooleanProperty("groupblogging.enabled")) {
return mapping.findForward("access-denied");
}
ActionForward forward = mapping.findForward("inviteMember.page");
ActionMessages msgs = new ActionMessages();
ActionMessages errors = new ActionErrors();
InviteMemberForm form = (InviteMemberForm)actionForm;
UserManager umgr = RollerFactory.getRoller().getUserManager();
UserData user = umgr.getUserByUserName(form.getUserName());
BasePageModel pageModel = new BasePageModel(
"inviteMember.title", request, response, mapping);
RollerSession rses = RollerSession.getRollerSession(request);
// Ensure use has admin perms for this weblog
if (pageModel.getWebsite() != null && rses.isUserAuthorizedToAdmin(pageModel.getWebsite())) {
if (user == null) {
errors.add(ActionErrors.GLOBAL_ERROR,
new ActionError("inviteMember.error.userNotFound"));
} else {
RollerRequest rreq = RollerRequest.getRollerRequest(request);
WebsiteData website = rreq.getWebsite();
PermissionsData perms = umgr.getPermissions(website, user);
if (perms != null && perms.isPending()) {
errors.add(ActionErrors.GLOBAL_ERROR,
new ActionError("inviteMember.error.userAlreadyInvited"));
request.setAttribute("model", new BasePageModel(
"inviteMember.title", request, response, mapping));
} else if (perms != null) {
errors.add(ActionErrors.GLOBAL_ERROR,
new ActionError("inviteMember.error.userAlreadyMember"));
request.setAttribute("model", new BasePageModel(
"inviteMember.title", request, response, mapping));
} else {
String mask = request.getParameter("permissionsMask");
umgr.inviteUser(website, user, Short.parseShort(mask));
RollerFactory.getRoller().flush();
request.setAttribute("user", user);
try {
notifyInvitee(request, website, user);
} catch (RollerException e) {
errors.add(ActionErrors.GLOBAL_ERROR,
new ActionError("error.untranslated", e.getMessage()));
}
msgs.add(ActionMessages.GLOBAL_MESSAGE,
new ActionMessage("inviteMember.userInvited"));
request.setAttribute("model", new BasePageModel(
"inviteMemberDone.title", request, response, mapping));
forward = mapping.findForward("memberPermissions");
}
}
saveErrors(request, errors);
saveMessages(request, msgs);
} else {
return mapping.findForward("access-denied");
}
return forward;
}
/**
* Inform invitee of new invitation.
*/
private void notifyInvitee(
HttpServletRequest request, WebsiteData website, UserData user)
throws RollerException {
try {
Roller roller = RollerFactory.getRoller();
UserManager umgr = roller.getUserManager();
javax.naming.Context ctx = (javax.naming.Context)
new InitialContext().lookup("java:comp/env");
Session mailSession =
(Session)ctx.lookup("mail/Session");
if (mailSession != null) {
String userName = user.getUserName();
String from = website.getEmailAddress();
String cc[] = new String[] {from};
String bcc[] = new String[0];
String to[] = new String[] {user.getEmailAddress()};
String subject;
String content;
// Figure URL to entry edit page
RollerContext rc = RollerContext.getRollerContext();
String rootURL = RollerRuntimeConfig.getAbsoluteContextURL();
if (rootURL == null || rootURL.trim().length()==0) {
rootURL = RequestUtils.serverURL(request)
+ request.getContextPath();
}
String url = rootURL + "/roller-ui/yourWebsites.do";
ResourceBundle resources = ResourceBundle.getBundle(
"ApplicationResources",
website.getLocaleInstance());
StringBuffer sb = new StringBuffer();
sb.append(MessageFormat.format(
resources.getString("inviteMember.notificationSubject"),
new Object[] {
website.getName(),
website.getHandle()})
);
subject = sb.toString();
sb = new StringBuffer();
sb.append(MessageFormat.format(
resources.getString("inviteMember.notificationContent"),
new Object[] {
website.getName(),
website.getHandle(),
user.getUserName(),
url
}));
content = sb.toString();
MailUtil.sendTextMessage(
mailSession, from, to, cc, bcc, subject, content);
}
} catch (NamingException e) {
throw new RollerException("ERROR: Notification email(s) not sent, "
+ "Roller's mail session not properly configured", e);
} catch (MessagingException e) {
throw new RollerException("ERROR: Notification email(s) not sent, "
+ "due to Roller configuration or mail server problem.", e);
} catch (MalformedURLException e) {
throw new RollerException("ERROR: Notification email(s) not sent, "
+ "Roller site URL is malformed?", e);
} catch (RollerException e) {
throw new RuntimeException(
"FATAL ERROR: unable to find Roller object", e);
}
}
}