All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.erigir.wrench.ape.http.ApeErrorHandlerControl Maven / Gradle / Ivy

There is a newer version: 2.2.16+16
Show newest version
package com.erigir.wrench.ape.http;

import com.erigir.wrench.ape.exception.ApeExceptionWriter;
import com.erigir.wrench.ape.exception.DataValidationException;
import com.erigir.wrench.ape.exception.NoSuchResourceException;
import com.erigir.wrench.aws.sns.ServerErrorNotifier;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.security.Principal;
import java.util.Collections;
import java.util.Map;
import java.util.TreeMap;

/**
 * Created by cweiss on 8/22/15.
 */
@Controller
public class ApeErrorHandlerControl {
  private static final Logger LOG = LoggerFactory.getLogger(ApeErrorHandlerControl.class);
  @Resource(name = "apeExceptionWriter")
  private ApeExceptionWriter apeExceptionWriter;
  // Autowired here since there might not be one
  @Autowired(required = false)
  private ServerErrorNotifier serverErrorNotifier;

  @RequestMapping(value = "/ErrorHandler")
  public void
  errorHandler(HttpServletRequest req, HttpServletResponse resp) {
    Exception main = (Exception) req.getAttribute("javax.servlet.error.exception");
    int currentStatus = resp.getStatus();
    if (main == null) {
      if (currentStatus == 400) {
        // This is typically caused by Spring not being able to parse the supplied
        // body into the needed object.  Fake that instead
        LOG.warn("No exception and status 400 - treating as spring parse error");
        main = new DataValidationException(Collections.singletonMap("request-body", "bad or mismatched json"));
      } else {
        LOG.warn("Someone requested the error handler directly.  Faking a 404");
        main = new NoSuchResourceException();
      }
    }

    try {
      if (serverErrorNotifier != null) {
        buildAndSendErrorReport(req);
      }
      // Now output json
      apeExceptionWriter.writeExceptionToResponse(req, resp, main);

      //req.removeAttribute("javax.servlet.error.exception");
    } catch (Exception e) {
      LOG.error("Well this is really bad, got an exception trying to handle the error page!:" + e, e);
    }
  }

  private void buildAndSendErrorReport(HttpServletRequest req) {
    LOG.info("Building error report");
    try {
      Map other = new TreeMap();
      Principal principal = req.getUserPrincipal();
      if (principal != null) {
        other.put("Logged In Principal", principal);
      }
      serverErrorNotifier.reportError(req, other);
    } catch (Throwable t) {
      LOG.error("Didn't send report due to error", t);
    }
  }

  public void setServerErrorNotifier(ServerErrorNotifier serverErrorNotifier) {
    this.serverErrorNotifier = serverErrorNotifier;
  }

  public void setApeExceptionWriter(ApeExceptionWriter apeExceptionWriter) {
    this.apeExceptionWriter = apeExceptionWriter;
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy