add autoconfig feature
This commit is contained in:
parent
ab32be694a
commit
e084e04133
@ -44,6 +44,11 @@
|
|||||||
<servlet-class>de.hsadmin.pillar.JsonPillarServlet</servlet-class>
|
<servlet-class>de.hsadmin.pillar.JsonPillarServlet</servlet-class>
|
||||||
</servlet>
|
</servlet>
|
||||||
|
|
||||||
|
<servlet>
|
||||||
|
<servlet-name>AutoconfigServlet</servlet-name>
|
||||||
|
<servlet-class>de.hsadmin.autoconfig.AutoconfigAutodiscoverServlet</servlet-class>
|
||||||
|
</servlet>
|
||||||
|
|
||||||
<servlet-mapping>
|
<servlet-mapping>
|
||||||
<servlet-name>Queue Status Servlet</servlet-name>
|
<servlet-name>Queue Status Servlet</servlet-name>
|
||||||
<url-pattern>/queueStatus</url-pattern>
|
<url-pattern>/queueStatus</url-pattern>
|
||||||
@ -54,6 +59,11 @@
|
|||||||
<url-pattern>/pillar</url-pattern>
|
<url-pattern>/pillar</url-pattern>
|
||||||
</servlet-mapping>
|
</servlet-mapping>
|
||||||
|
|
||||||
|
<servlet-mapping>
|
||||||
|
<servlet-name>AutoconfigServlet</servlet-name>
|
||||||
|
<url-pattern>/config-v1.1.xml</url-pattern>
|
||||||
|
</servlet-mapping>
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
<servlet-mapping>
|
<servlet-mapping>
|
||||||
<servlet-name>Queue PacTasks Servlet</servlet-name>
|
<servlet-name>Queue PacTasks Servlet</servlet-name>
|
||||||
|
@ -0,0 +1,156 @@
|
|||||||
|
package de.hsadmin.autoconfig;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import javax.persistence.EntityManager;
|
||||||
|
import javax.persistence.Query;
|
||||||
|
import javax.servlet.ServletException;
|
||||||
|
import javax.servlet.http.HttpServlet;
|
||||||
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import javax.xml.parsers.DocumentBuilder;
|
||||||
|
import javax.xml.parsers.DocumentBuilderFactory;
|
||||||
|
import javax.xml.parsers.ParserConfigurationException;
|
||||||
|
import javax.xml.transform.Transformer;
|
||||||
|
import javax.xml.transform.TransformerException;
|
||||||
|
import javax.xml.transform.TransformerFactory;
|
||||||
|
import javax.xml.transform.dom.DOMSource;
|
||||||
|
import javax.xml.transform.stream.StreamResult;
|
||||||
|
|
||||||
|
import org.apache.commons.httpclient.HttpStatus;
|
||||||
|
import org.w3c.dom.DOMException;
|
||||||
|
import org.w3c.dom.Document;
|
||||||
|
import org.w3c.dom.Element;
|
||||||
|
|
||||||
|
import de.hsadmin.core.model.Transaction;
|
||||||
|
import de.hsadmin.core.util.IPv6Trick;
|
||||||
|
import de.hsadmin.mods.email.EMailAddress;
|
||||||
|
import de.hsadmin.mods.pac.Pac;
|
||||||
|
import de.hsadmin.mods.user.UnixUser;
|
||||||
|
|
||||||
|
public class AutoconfigAutodiscoverServlet extends HttpServlet {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Thunderbird autoconfig
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
|
||||||
|
final String emailAddr = req.getParameter("emailaddress");
|
||||||
|
if (emailAddr == null || emailAddr.length() == 0) {
|
||||||
|
resp.sendError(HttpStatus.SC_UNAUTHORIZED);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
final String[] addrParts = emailAddr.split("@");
|
||||||
|
if (addrParts.length != 2) {
|
||||||
|
resp.sendError(HttpStatus.SC_BAD_REQUEST);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
final String localpart = addrParts[0];
|
||||||
|
final String domain = addrParts[1];
|
||||||
|
final Transaction transaction = new Transaction("autoconfig");
|
||||||
|
final EntityManager em = transaction.getEntityManager();
|
||||||
|
final Query emailQuery = em.createQuery("SELECT addr FROM EMailAddresses WHERE addr.localpart = :localpart AND addr.domain = :domain AND ( addr.subdomain IS NULL OR addr.subdomain = :subdomain)");
|
||||||
|
emailQuery.setParameter("subdomain", "");
|
||||||
|
emailQuery.setParameter("domain", domain);
|
||||||
|
emailQuery.setParameter("localpart", localpart);
|
||||||
|
final Object emailResult = emailQuery.getSingleResult();
|
||||||
|
if (emailResult == null) {
|
||||||
|
transaction.close();
|
||||||
|
resp.sendError(HttpStatus.SC_BAD_REQUEST);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
final EMailAddress emailAddress = (EMailAddress) emailResult;
|
||||||
|
final Query mboxQuery = em.createQuery("SELECT mbox FROM UnixUsers WHERE mbox.name = :target");
|
||||||
|
final String target = emailAddress.getTarget();
|
||||||
|
if (target == null || target.length() < 5 || (target.length() > 6 && target.charAt(5) != '-')) {
|
||||||
|
transaction.close();
|
||||||
|
resp.sendError(HttpStatus.SC_BAD_REQUEST);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
mboxQuery.setParameter("target", target);
|
||||||
|
final Object mboxResult = mboxQuery.getSingleResult();
|
||||||
|
if (mboxResult == null) {
|
||||||
|
transaction.close();
|
||||||
|
resp.sendError(HttpStatus.SC_BAD_REQUEST);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
final UnixUser mbox = (UnixUser) mboxResult;
|
||||||
|
final Pac pac = mbox.getPac();
|
||||||
|
final String pacDomain = pac.getName() + ".hostsharing.net";
|
||||||
|
final String userName = mbox.getName();
|
||||||
|
try {
|
||||||
|
DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
|
||||||
|
DocumentBuilder builder = builderFactory.newDocumentBuilder();
|
||||||
|
Document document = builder.newDocument();
|
||||||
|
Element clientConfig = document.createElement("clientConfig");
|
||||||
|
clientConfig.setAttribute("version", "1.1");
|
||||||
|
document.appendChild(clientConfig);
|
||||||
|
Element emailProvider = appendElementWithAttribute(document, clientConfig, "emailProvider", "id", "hostsharing.net");
|
||||||
|
appendElementWithText(document, emailProvider, "domain", "hostsharing.net");
|
||||||
|
Element incomingServer = appendElementWithAttribute(document, emailProvider, "incomingServer", "type", "imap");
|
||||||
|
appendElementWithText(document, incomingServer, "hostname", pacDomain);
|
||||||
|
appendElementWithText(document, incomingServer, "port", "993");
|
||||||
|
appendElementWithText(document, incomingServer, "socketType", "SSL");
|
||||||
|
appendElementWithText(document, incomingServer, "username", userName);
|
||||||
|
appendElementWithText(document, incomingServer, "authentication", "password-cleartext");
|
||||||
|
Element outgoingServer = appendElementWithAttribute(document, emailProvider, "outgoingServer", "type", "smtp");
|
||||||
|
appendElementWithText(document, outgoingServer, "hostname", pacDomain);
|
||||||
|
appendElementWithText(document, outgoingServer, "port", "465");
|
||||||
|
appendElementWithText(document, outgoingServer, "socketType", "SSL");
|
||||||
|
appendElementWithText(document, outgoingServer, "username", userName);
|
||||||
|
appendElementWithText(document, outgoingServer, "authentication", "password-cleartext");
|
||||||
|
appendElementWithText(document, outgoingServer, "addThisServer", "true");
|
||||||
|
appendElementWithText(document, outgoingServer, "useGlobalPreferredServer", "true");
|
||||||
|
serializeDocument(document, resp);
|
||||||
|
} catch (DOMException e) {
|
||||||
|
throw new ServletException(e);
|
||||||
|
} catch (ParserConfigurationException e) {
|
||||||
|
throw new ServletException(e);
|
||||||
|
}
|
||||||
|
transaction.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Microsoft autodiscover
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
|
||||||
|
final String remoteAddr = req.getRemoteAddr();
|
||||||
|
if (!IPv6Trick.isKnownRemote(remoteAddr)) {
|
||||||
|
resp.sendError(HttpStatus.SC_UNAUTHORIZED);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private Element appendElementWithAttribute(final Document document, final Element parent,
|
||||||
|
final String childElementName, final String attributeName, final String attributeValue) {
|
||||||
|
final Element child = document.createElement(childElementName);
|
||||||
|
child.setAttribute(attributeName, attributeValue);
|
||||||
|
parent.appendChild(child);
|
||||||
|
return child;
|
||||||
|
}
|
||||||
|
|
||||||
|
private Element appendElementWithText(final Document document, final Element parent,
|
||||||
|
final String childElementName, final String text) {
|
||||||
|
final Element child = document.createElement(childElementName);
|
||||||
|
parent.appendChild(child);
|
||||||
|
child.appendChild(document.createTextNode(text));
|
||||||
|
return child;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void serializeDocument(final Document document, final HttpServletResponse resp)
|
||||||
|
throws ServletException {
|
||||||
|
resp.setContentType("text/xml");
|
||||||
|
try {
|
||||||
|
TransformerFactory transformerFactory = TransformerFactory.newInstance();
|
||||||
|
Transformer transformer = transformerFactory.newTransformer();
|
||||||
|
transformer.transform(new DOMSource(document), new StreamResult(resp.getOutputStream()));
|
||||||
|
} catch (TransformerException e) {
|
||||||
|
throw new ServletException(e);
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new ServletException(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -137,7 +137,7 @@ public class JsonPillarServlet extends HttpServlet {
|
|||||||
writer.println(" ]");
|
writer.println(" ]");
|
||||||
writer.println("}");
|
writer.println("}");
|
||||||
writer.close();
|
writer.close();
|
||||||
em.close();
|
transaction.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user