PageRenderTime 54ms CodeModel.GetById 19ms RepoModel.GetById 0ms app.codeStats 0ms

/src/main/java/com/puzzlebazar/server/OpenIdServlet.java

https://code.google.com/p/puzzlebazar/
Java | 190 lines | 132 code | 25 blank | 33 comment | 18 complexity | 1cc063081c4ce6f92c849ee6afb34d3c MD5 | raw file
  1. /**
  2. * Copyright 2010 Philippe Beaudoin
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. package com.puzzlebazar.server;
  17. import java.io.FileNotFoundException;
  18. import java.io.IOException;
  19. import java.net.UnknownHostException;
  20. import javax.servlet.ServletException;
  21. import javax.servlet.http.HttpServlet;
  22. import javax.servlet.http.HttpServletRequest;
  23. import javax.servlet.http.HttpServletResponse;
  24. import com.dyuproject.openid.Constants;
  25. import com.dyuproject.openid.OpenIdServletFilter;
  26. import com.dyuproject.openid.OpenIdUser;
  27. import com.dyuproject.openid.RelyingParty;
  28. import com.dyuproject.openid.YadisDiscovery;
  29. import com.dyuproject.openid.ext.AxSchemaExtension;
  30. import com.dyuproject.util.http.UrlEncodedParameterMap;
  31. import com.google.inject.Inject;
  32. import com.google.inject.Provider;
  33. import com.google.inject.Singleton;
  34. import com.puzzlebazar.server.model.UserDAO;
  35. /**
  36. * @author Philippe Beaudoin
  37. */
  38. @Singleton
  39. public class OpenIdServlet extends HttpServlet {
  40. private static final long serialVersionUID = 6314103753523555658L;
  41. private static final String CLOSE_POPUP_URI = "/openid/ClosePopup.html";
  42. private final Provider<UserDAO> userDAO;
  43. @Inject
  44. public OpenIdServlet(Provider<UserDAO> userDAO) {
  45. this.userDAO = userDAO;
  46. }
  47. @Override
  48. public void doGet(HttpServletRequest request, HttpServletResponse response)
  49. throws IOException, ServletException {
  50. doPost(request, response);
  51. }
  52. @Override
  53. public void doPost(HttpServletRequest request, HttpServletResponse response)
  54. throws IOException, ServletException {
  55. String provider = request.getParameter("provider");
  56. if (provider != null) {
  57. // If the ui supplies a number of buttons for default providers.
  58. // This will speed up the openid process by skipping discovery.
  59. // The override is done by adding the OpenIdUser to the request attribute.
  60. if (provider.equals("google")) {
  61. OpenIdUser user = OpenIdUser.populate("https://www.google.com/accounts/o8/id",
  62. YadisDiscovery.IDENTIFIER_SELECT,
  63. "https://www.google.com/accounts/o8/ud");
  64. request.setAttribute(OpenIdUser.ATTR_NAME, user);
  65. } else if (provider.equals("yahoo")) {
  66. OpenIdUser user = OpenIdUser.populate("http://yahoo.com/",
  67. YadisDiscovery.IDENTIFIER_SELECT,
  68. "https://open.login.yahooapis.com/openid/op/auth");
  69. request.setAttribute(OpenIdUser.ATTR_NAME, user);
  70. }
  71. }
  72. RelyingParty relyingParty = RelyingParty.getInstance();
  73. String errorMsg = OpenIdServletFilter.DEFAULT_ERROR_MSG;
  74. try {
  75. OpenIdUser user = relyingParty.discover(request);
  76. if (user == null) {
  77. if (RelyingParty.isAuthResponse(request)) {
  78. // authentication timeout
  79. response.sendRedirect(request.getRequestURI());
  80. } else {
  81. // set error msg if the openid_identifier is not resolved.
  82. if (request.getParameter(relyingParty.getIdentifierParameter()) != null) {
  83. request.setAttribute(OpenIdServletFilter.ERROR_MSG_ATTR, errorMsg);
  84. }
  85. // TODO: Simply close the window? Alert?
  86. request.getRequestDispatcher(CLOSE_POPUP_URI).forward(request, response);
  87. }
  88. return;
  89. }
  90. if (user.isAuthenticated()) {
  91. // user already authenticated
  92. request.getRequestDispatcher(CLOSE_POPUP_URI).forward(request, response);
  93. return;
  94. }
  95. if (user.isAssociated() && RelyingParty.isAuthResponse(request)) {
  96. // verify authentication
  97. if (relyingParty.verifyAuth(user, request, response)) {
  98. // authenticated
  99. userDAO.get().setSessionUser(user);
  100. // redirect to home to remove the query params instead of doing:
  101. request.getRequestDispatcher(CLOSE_POPUP_URI).forward(request, response);
  102. } else {
  103. // failed verification
  104. // TODO: Simply close the window? Alert?
  105. request.getRequestDispatcher(CLOSE_POPUP_URI).forward(request, response);
  106. }
  107. return;
  108. }
  109. // associate and authenticate user
  110. StringBuffer url = request.getRequestURL();
  111. String trustRoot = url.substring(0, url.indexOf("/", 9));
  112. String realm = url.substring(0, url.lastIndexOf("/"));
  113. String returnTo = url.toString();
  114. if (relyingParty.associateAndAuthenticate(user, request, response, trustRoot, realm,
  115. returnTo)) {
  116. return;
  117. }
  118. } catch (UnknownHostException uhe) {
  119. System.err.println("not found");
  120. errorMsg = OpenIdServletFilter.ID_NOT_FOUND_MSG;
  121. } catch (FileNotFoundException fnfe) {
  122. System.err.println("could not be resolved");
  123. errorMsg = OpenIdServletFilter.DEFAULT_ERROR_MSG;
  124. } catch (Exception e) {
  125. e.printStackTrace();
  126. errorMsg = OpenIdServletFilter.DEFAULT_ERROR_MSG;
  127. }
  128. request.setAttribute(OpenIdServletFilter.ERROR_MSG_ATTR, errorMsg);
  129. // TODO: Simply close the window? Alert?
  130. request.getRequestDispatcher(CLOSE_POPUP_URI).forward(request, response);
  131. }
  132. @Override
  133. public void init() throws ServletException {
  134. super.init();
  135. // One-time initialization of RelyingParty.
  136. RelyingParty.getInstance()
  137. .addListener(new AxSchemaExtension()
  138. .addExchange("email")
  139. .addExchange("language")
  140. )
  141. .addListener(new RelyingParty.Listener()
  142. {
  143. @Override
  144. public void onDiscovery(OpenIdUser user, HttpServletRequest request) {
  145. }
  146. @Override
  147. public void onPreAuthenticate(OpenIdUser user, HttpServletRequest request,
  148. UrlEncodedParameterMap params) {
  149. if ("true".equals(request.getParameter("popup"))) {
  150. String returnTo = params.get(Constants.OPENID_TRUST_ROOT) + request.getRequestURI();
  151. params.put(Constants.OPENID_RETURN_TO, returnTo);
  152. params.put(Constants.OPENID_REALM, returnTo);
  153. params.put("openid.ns.ui", "http://specs.openid.net/extensions/ui/1.0");
  154. params.put("openid.ui.mode", "popup");
  155. }
  156. }
  157. @Override
  158. public void onAuthenticate(OpenIdUser user, HttpServletRequest request) {
  159. }
  160. @Override
  161. public void onAccess(OpenIdUser user, HttpServletRequest request) {
  162. }
  163. });
  164. }
  165. }