You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

RepositoryFilter.java 4.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. /*
  2. * Copyright (C) 2009-2010, Google Inc. and others
  3. *
  4. * This program and the accompanying materials are made available under the
  5. * terms of the Eclipse Distribution License v. 1.0 which is available at
  6. * https://www.eclipse.org/org/documents/edl-v10.php.
  7. *
  8. * SPDX-License-Identifier: BSD-3-Clause
  9. */
  10. package org.eclipse.jgit.http.server;
  11. import static javax.servlet.http.HttpServletResponse.SC_FORBIDDEN;
  12. import static javax.servlet.http.HttpServletResponse.SC_INTERNAL_SERVER_ERROR;
  13. import static javax.servlet.http.HttpServletResponse.SC_NOT_FOUND;
  14. import static javax.servlet.http.HttpServletResponse.SC_UNAUTHORIZED;
  15. import static org.eclipse.jgit.http.server.GitSmartHttpTools.sendError;
  16. import static org.eclipse.jgit.http.server.ServletUtils.ATTRIBUTE_REPOSITORY;
  17. import java.io.IOException;
  18. import java.text.MessageFormat;
  19. import javax.servlet.Filter;
  20. import javax.servlet.FilterChain;
  21. import javax.servlet.FilterConfig;
  22. import javax.servlet.ServletContext;
  23. import javax.servlet.ServletException;
  24. import javax.servlet.ServletRequest;
  25. import javax.servlet.ServletResponse;
  26. import javax.servlet.http.HttpServletRequest;
  27. import javax.servlet.http.HttpServletResponse;
  28. import org.eclipse.jgit.errors.RepositoryNotFoundException;
  29. import org.eclipse.jgit.lib.Repository;
  30. import org.eclipse.jgit.transport.ServiceMayNotContinueException;
  31. import org.eclipse.jgit.transport.resolver.RepositoryResolver;
  32. import org.eclipse.jgit.transport.resolver.ServiceNotAuthorizedException;
  33. import org.eclipse.jgit.transport.resolver.ServiceNotEnabledException;
  34. /**
  35. * Open a repository named by the path info through
  36. * {@link org.eclipse.jgit.transport.resolver.RepositoryResolver}.
  37. * <p>
  38. * This filter assumes it is invoked by
  39. * {@link org.eclipse.jgit.http.server.GitServlet} and is likely to not work as
  40. * expected if called from any other class. This filter assumes the path info of
  41. * the current request is a repository name which can be used by the configured
  42. * {@link org.eclipse.jgit.transport.resolver.RepositoryResolver} to open a
  43. * {@link org.eclipse.jgit.lib.Repository} and attach it to the current request.
  44. * <p>
  45. * This filter sets request attribute
  46. * {@link org.eclipse.jgit.http.server.ServletUtils#ATTRIBUTE_REPOSITORY} when
  47. * it discovers the repository, and automatically closes and removes the
  48. * attribute when the request is complete.
  49. */
  50. public class RepositoryFilter implements Filter {
  51. private final RepositoryResolver<HttpServletRequest> resolver;
  52. private ServletContext context;
  53. /**
  54. * Create a new filter.
  55. *
  56. * @param resolver
  57. * the resolver which will be used to translate the URL name
  58. * component to the actual
  59. * {@link org.eclipse.jgit.lib.Repository} instance for the
  60. * current web request.
  61. */
  62. public RepositoryFilter(RepositoryResolver<HttpServletRequest> resolver) {
  63. this.resolver = resolver;
  64. }
  65. /** {@inheritDoc} */
  66. @Override
  67. public void init(FilterConfig config) throws ServletException {
  68. context = config.getServletContext();
  69. }
  70. /** {@inheritDoc} */
  71. @Override
  72. public void destroy() {
  73. context = null;
  74. }
  75. /** {@inheritDoc} */
  76. @Override
  77. public void doFilter(final ServletRequest request,
  78. final ServletResponse response, final FilterChain chain)
  79. throws IOException, ServletException {
  80. HttpServletRequest req = (HttpServletRequest) request;
  81. HttpServletResponse res = (HttpServletResponse) response;
  82. if (request.getAttribute(ATTRIBUTE_REPOSITORY) != null) {
  83. context.log(MessageFormat.format(HttpServerText.get().internalServerErrorRequestAttributeWasAlreadySet
  84. , ATTRIBUTE_REPOSITORY
  85. , getClass().getName()));
  86. sendError(req, res, SC_INTERNAL_SERVER_ERROR);
  87. return;
  88. }
  89. String name = req.getPathInfo();
  90. while (name != null && 0 < name.length() && name.charAt(0) == '/')
  91. name = name.substring(1);
  92. if (name == null || name.length() == 0) {
  93. sendError(req, res, SC_NOT_FOUND);
  94. return;
  95. }
  96. try (Repository db = resolver.open(req, name)) {
  97. request.setAttribute(ATTRIBUTE_REPOSITORY, db);
  98. chain.doFilter(request, response);
  99. } catch (RepositoryNotFoundException e) {
  100. sendError(req, res, SC_NOT_FOUND);
  101. return;
  102. } catch (ServiceNotEnabledException e) {
  103. sendError(req, res, SC_FORBIDDEN, e.getMessage());
  104. return;
  105. } catch (ServiceNotAuthorizedException e) {
  106. res.sendError(SC_UNAUTHORIZED, e.getMessage());
  107. return;
  108. } catch (ServiceMayNotContinueException e) {
  109. sendError(req, res, e.getStatusCode(), e.getMessage());
  110. return;
  111. } finally {
  112. request.removeAttribute(ATTRIBUTE_REPOSITORY);
  113. }
  114. }
  115. }