partially support for template email added
git-svn-id: https://svn.research-infrastructures.eu/d4science/gcube/trunk/portal/invites-common-library@148502 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
parent
13c9d216ac
commit
0ec56ee80c
|
@ -18,7 +18,7 @@
|
||||||
<attribute name="org.eclipse.jst.component.nondependency" value=""/>
|
<attribute name="org.eclipse.jst.component.nondependency" value=""/>
|
||||||
</attributes>
|
</attributes>
|
||||||
</classpathentry>
|
</classpathentry>
|
||||||
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.7">
|
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.8">
|
||||||
<attributes>
|
<attributes>
|
||||||
<attribute name="maven.pomderived" value="true"/>
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
</attributes>
|
</attributes>
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
eclipse.preferences.version=1
|
eclipse.preferences.version=1
|
||||||
org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled
|
org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled
|
||||||
org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.7
|
org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.8
|
||||||
org.eclipse.jdt.core.compiler.compliance=1.7
|
org.eclipse.jdt.core.compiler.compliance=1.7
|
||||||
org.eclipse.jdt.core.compiler.problem.assertIdentifier=error
|
org.eclipse.jdt.core.compiler.problem.assertIdentifier=error
|
||||||
org.eclipse.jdt.core.compiler.problem.enumIdentifier=error
|
org.eclipse.jdt.core.compiler.problem.enumIdentifier=error
|
||||||
|
|
13
pom.xml
13
pom.xml
|
@ -12,7 +12,7 @@
|
||||||
|
|
||||||
<groupId>org.gcube.portal</groupId>
|
<groupId>org.gcube.portal</groupId>
|
||||||
<artifactId>invites-common-library</artifactId>
|
<artifactId>invites-common-library</artifactId>
|
||||||
<version>1.3.0-SNAPSHOT</version>
|
<version>1.4.0-SNAPSHOT</version>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
<description>
|
<description>
|
||||||
gCube Invites Common Library is a common library containing shared code for Inviting external users to portal VREs.
|
gCube Invites Common Library is a common library containing shared code for Inviting external users to portal VREs.
|
||||||
|
@ -26,7 +26,7 @@
|
||||||
<properties>
|
<properties>
|
||||||
<distroDirectory>distro</distroDirectory>
|
<distroDirectory>distro</distroDirectory>
|
||||||
<maven.compiler.source>1.7</maven.compiler.source>
|
<maven.compiler.source>1.7</maven.compiler.source>
|
||||||
<maven.compiler.target>1.7</maven.compiler.target>
|
<maven.compiler.target>1.8</maven.compiler.target>
|
||||||
<liferay.version>6.2.5</liferay.version>
|
<liferay.version>6.2.5</liferay.version>
|
||||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
|
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
|
||||||
|
@ -53,6 +53,11 @@
|
||||||
<artifactId>portal-manager</artifactId>
|
<artifactId>portal-manager</artifactId>
|
||||||
<scope>provided</scope>
|
<scope>provided</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.gcube.portal.mailing</groupId>
|
||||||
|
<artifactId>email-templates-library</artifactId>
|
||||||
|
<version>[1.0.0-SNAPSHOT,)</version>
|
||||||
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.gcube.dvos</groupId>
|
<groupId>org.gcube.dvos</groupId>
|
||||||
<artifactId>usermanagement-core</artifactId>
|
<artifactId>usermanagement-core</artifactId>
|
||||||
|
@ -104,8 +109,8 @@
|
||||||
<plugin>
|
<plugin>
|
||||||
<artifactId>maven-compiler-plugin</artifactId>
|
<artifactId>maven-compiler-plugin</artifactId>
|
||||||
<configuration>
|
<configuration>
|
||||||
<source>1.7</source>
|
<source>${maven.compiler.source}</source>
|
||||||
<target>1.7</target>
|
<target>${maven.compiler.target}</target>
|
||||||
</configuration>
|
</configuration>
|
||||||
</plugin>
|
</plugin>
|
||||||
|
|
||||||
|
|
|
@ -17,6 +17,9 @@ import org.gcube.portal.databook.server.DatabookStore;
|
||||||
import org.gcube.portal.databook.shared.Invite;
|
import org.gcube.portal.databook.shared.Invite;
|
||||||
import org.gcube.portal.databook.shared.InviteOperationResult;
|
import org.gcube.portal.databook.shared.InviteOperationResult;
|
||||||
import org.gcube.portal.databook.shared.InviteStatus;
|
import org.gcube.portal.databook.shared.InviteStatus;
|
||||||
|
import org.gcube.portal.mailing.message.Recipient;
|
||||||
|
import org.gcube.portal.mailing.service.EmailTemplateService;
|
||||||
|
import org.gcube.portal.mailing.templates.TemplatedJoinMeInvite;
|
||||||
import org.gcube.vomanagement.usermanagement.exception.GroupRetrievalFault;
|
import org.gcube.vomanagement.usermanagement.exception.GroupRetrievalFault;
|
||||||
import org.gcube.vomanagement.usermanagement.exception.UserManagementSystemException;
|
import org.gcube.vomanagement.usermanagement.exception.UserManagementSystemException;
|
||||||
import org.gcube.vomanagement.usermanagement.impl.LiferayGroupManager;
|
import org.gcube.vomanagement.usermanagement.impl.LiferayGroupManager;
|
||||||
|
@ -24,11 +27,6 @@ import org.gcube.vomanagement.usermanagement.impl.LiferayUserManager;
|
||||||
import org.gcube.vomanagement.usermanagement.model.GCubeGroup;
|
import org.gcube.vomanagement.usermanagement.model.GCubeGroup;
|
||||||
import org.gcube.vomanagement.usermanagement.model.GCubeRole;
|
import org.gcube.vomanagement.usermanagement.model.GCubeRole;
|
||||||
import org.gcube.vomanagement.usermanagement.model.GCubeUser;
|
import org.gcube.vomanagement.usermanagement.model.GCubeUser;
|
||||||
import org.jsoup.Jsoup;
|
|
||||||
import org.jsoup.nodes.Document;
|
|
||||||
import org.jsoup.nodes.Element;
|
|
||||||
import org.jsoup.nodes.Node;
|
|
||||||
import org.jsoup.nodes.TextNode;
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
@ -104,23 +102,27 @@ public class InvitesManager {
|
||||||
String email,
|
String email,
|
||||||
String vreDescription) {
|
String vreDescription) {
|
||||||
|
|
||||||
GCubeUser currUser = PortalContext.getConfiguration().getCurrentUser(request);
|
PortalContext pContext = PortalContext.getConfiguration();
|
||||||
String fromFullName = currUser.getFullname();
|
GCubeUser currUser = pContext.getCurrentUser(request);
|
||||||
|
String gatewayURL = pContext.getGatewayURL(request);
|
||||||
|
String gatewayName = pContext.getGatewayName(request);
|
||||||
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
String subject = "Join me on " + vreName;
|
String subject = "Join me on " + vreName + " VRE";
|
||||||
|
|
||||||
long groupId = PortalContext.getConfiguration().getCurrentGroupId(request);
|
long groupId = PortalContext.getConfiguration().getCurrentGroupId(request);
|
||||||
final String linkToAcceptInvite = portalURL + PortalContext.getConfiguration().getSiteLandingPagePath(request)+"/explore?siteId="+groupId;
|
final String linkToAcceptInvite = portalURL + PortalContext.getConfiguration().getSiteLandingPagePath(request)+"/explore?siteId="+groupId;
|
||||||
final String linkToCreateAccount = portalURL + "/?p_p_id=58&p_p_lifecycle=0&p_p_state=maximized&p_p_mode=view&p_p_col_id=column-1&p_p_col_count=1&saveLastPath=false&_58_struts_action=%2Flogin%2Fcreate_account";
|
final String linkToCreateAccount = portalURL + "/?p_p_id=58&p_p_lifecycle=0&p_p_state=maximized&p_p_mode=view&p_p_col_id=column-1&p_p_col_count=1&saveLastPath=false&_58_struts_action=%2Flogin%2Fcreate_account";
|
||||||
|
|
||||||
EmailNotification mailToAdmin = new EmailNotification(
|
EmailTemplateService.send(
|
||||||
email ,
|
|
||||||
subject,
|
subject,
|
||||||
getHTMLEmail(name, lastName, email, fromFullName, vreName, vreDescription, linkToAcceptInvite, linkToCreateAccount),
|
new TemplatedJoinMeInvite(gatewayName, gatewayURL, currUser, name, vreName, vreDescription, linkToAcceptInvite, linkToCreateAccount),
|
||||||
request);
|
request,
|
||||||
mailToAdmin.sendEmail();
|
new Recipient(email));
|
||||||
_log.debug("Sent message successfully to " + email );
|
|
||||||
|
|
||||||
|
_log.debug("Join Me Invite email message sent successfully to " + email );
|
||||||
} catch (Exception mex) {
|
} catch (Exception mex) {
|
||||||
mex.printStackTrace();
|
mex.printStackTrace();
|
||||||
_log.error("Sent message ERROR to " + email );
|
_log.error("Sent message ERROR to " + email );
|
||||||
|
@ -129,96 +131,6 @@ public class InvitesManager {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @param aslSession
|
|
||||||
* @param portalUrl the url of the portal
|
|
||||||
* @param name the name of the invited person
|
|
||||||
* @param lastName the last name of the invited person
|
|
||||||
* @param email the email address of the invite person
|
|
||||||
* @param fromFullName who is inviting
|
|
||||||
* @param vreName the name of the environment where you are inviting the person
|
|
||||||
* @param vreDescription the description of the environment where you are inviting the person
|
|
||||||
* @return the email text
|
|
||||||
*/
|
|
||||||
private String getHTMLEmail(
|
|
||||||
String name,
|
|
||||||
String lastName,
|
|
||||||
String email,
|
|
||||||
String fromFullName,
|
|
||||||
String vreName,
|
|
||||||
String vreDescription,
|
|
||||||
String linkToAcceptInvite,
|
|
||||||
String linkToCreateAccount) {
|
|
||||||
|
|
||||||
linkToAcceptInvite = " <a href=\"" + linkToAcceptInvite + "\">" + linkToAcceptInvite + "</a> ";
|
|
||||||
linkToCreateAccount = " <a href=\"" + linkToCreateAccount + "\">" + linkToCreateAccount + "</a> ";
|
|
||||||
|
|
||||||
StringBuilder body = new StringBuilder();
|
|
||||||
body.append("<div style=\"color:#000; font-size:13px; font-family:'lucida grande',tahoma,verdana,arial,sans-serif;\">")
|
|
||||||
.append("Dear " + name)
|
|
||||||
.append(", <p>")
|
|
||||||
.append(fromFullName).append(" has invited you to " + vreName + ", you can find a brief description below:")
|
|
||||||
.append("</p>")
|
|
||||||
.append("<p>").append(vreDescription)
|
|
||||||
.append("</p>")
|
|
||||||
.append("<p>To accept the invite just follow this link: " + linkToAcceptInvite)
|
|
||||||
.append("</p>")
|
|
||||||
.append("</p>")
|
|
||||||
.append("Please note: if you do not have an account yet, sign up first: " + linkToCreateAccount)
|
|
||||||
.append("</p>")
|
|
||||||
.append("</div>");
|
|
||||||
return body.toString();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Convert html into simple text
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
protected static String convertHTML2Text(String html) {
|
|
||||||
if (html == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
String removedMarkup = html.replaceAll("&", "&");
|
|
||||||
removedMarkup = removedMarkup.replaceAll(">", ">");
|
|
||||||
removedMarkup = removedMarkup.replaceAll("<", "<");
|
|
||||||
String text = removedMarkup;
|
|
||||||
try {
|
|
||||||
Document document = Jsoup.parse(removedMarkup);
|
|
||||||
Element body = document.body();
|
|
||||||
text = buildStringFromNode(body).toString();
|
|
||||||
}
|
|
||||||
catch (Exception e) {
|
|
||||||
_log.error("While converting HTML into text: " +e.getMessage());
|
|
||||||
return removedMarkup;
|
|
||||||
}
|
|
||||||
return text;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static StringBuffer buildStringFromNode(Node node) {
|
|
||||||
StringBuffer buffer = new StringBuffer();
|
|
||||||
|
|
||||||
if (node instanceof TextNode) {
|
|
||||||
TextNode textNode = (TextNode) node;
|
|
||||||
buffer.append(textNode.text().trim());
|
|
||||||
}
|
|
||||||
|
|
||||||
for (Node childNode : node.childNodes()) {
|
|
||||||
buffer.append(buildStringFromNode(childNode));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (node instanceof Element) {
|
|
||||||
Element element = (Element) node;
|
|
||||||
String tagName = element.tagName();
|
|
||||||
if ("p".equals(tagName) || "br".equals(tagName) || "div".equals(tagName) || "h1".equals(tagName) || "h2".equals(tagName) || "h3".equals(tagName) || "h4".equals(tagName)) {
|
|
||||||
buffer.append("\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return buffer;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static ArrayList<String> getAdministratorsEmails(String scope) {
|
private static ArrayList<String> getAdministratorsEmails(String scope) {
|
||||||
LiferayUserManager userManager = new LiferayUserManager();
|
LiferayUserManager userManager = new LiferayUserManager();
|
||||||
LiferayGroupManager groupManager = new LiferayGroupManager();
|
LiferayGroupManager groupManager = new LiferayGroupManager();
|
||||||
|
|
Loading…
Reference in New Issue