From 4a566aed0d003bb2fe5219af70c423120fc5841a Mon Sep 17 00:00:00 2001 From: Abhi Shah Date: Thu, 8 Jul 2021 16:08:36 -0700 Subject: [PATCH] Avoid re-wrapping MetacatException in another MetacatException --- .../metacat/main/api/RequestWrapper.java | 24 +++++++++---------- 1 file changed, 11 insertions(+), 13 deletions(-) diff --git a/metacat-main/src/main/java/com/netflix/metacat/main/api/RequestWrapper.java b/metacat-main/src/main/java/com/netflix/metacat/main/api/RequestWrapper.java index 6131a5450..c4101f40f 100644 --- a/metacat-main/src/main/java/com/netflix/metacat/main/api/RequestWrapper.java +++ b/metacat-main/src/main/java/com/netflix/metacat/main/api/RequestWrapper.java @@ -27,7 +27,6 @@ import com.netflix.metacat.common.exception.MetacatNotFoundException; import com.netflix.metacat.common.exception.MetacatNotSupportedException; import com.netflix.metacat.common.exception.MetacatPreconditionFailedException; -import com.netflix.metacat.common.exception.MetacatUnAuthorizedException; import com.netflix.metacat.common.exception.MetacatUserMetadataException; import com.netflix.metacat.common.exception.MetacatTooManyRequestsException; import com.netflix.metacat.common.server.api.ratelimiter.RateLimiter; @@ -207,21 +206,16 @@ public R processRequest( final String message = String.format("%s.%s -- %s usermetadata operation failed for %s", e.getMessage(), e.getCause() == null ? "" : e.getCause().getMessage(), resourceRequestName, name); throw new MetacatUserMetadataException(message); - } catch (MetacatUnAuthorizedException e) { + } catch (Exception e) { collectRequestExceptionMetrics(tags, e.getClass().getSimpleName()); final String message = String.format("%s.%s -- %s failed for %s", e.getMessage(), e.getCause() == null ? "" : e.getCause().getMessage(), resourceRequestName, name); log.error(message, e); - throw e; - } catch (MetacatTooManyRequestsException e) { - collectRequestExceptionMetrics(tags, e.getClass().getSimpleName()); - throw e; - } catch (Exception e) { - collectRequestExceptionMetrics(tags, e.getClass().getSimpleName()); - final String message = String.format("%s.%s -- %s failed for %s", e.getMessage(), - e.getCause() == null ? "" : e.getCause().getMessage(), resourceRequestName, name); - log.error(message, e); - throw new MetacatException(message, e); + if (e instanceof MetacatException) { + throw e; + } else { + throw new MetacatException(message, e); + } } finally { final long duration = registry.clock().wallTime() - start; log.info("### Time taken to complete {} for {} is {} ms", resourceRequestName, name, duration); @@ -272,7 +266,11 @@ public R processRequest( e.getMessage(), e.getCause() == null ? "" : e.getCause().getMessage(), resourceRequestName); log.error(message, e); - throw new MetacatException(message, e); + if (e instanceof MetacatException) { + throw e; + } else { + throw new MetacatException(message, e); + } } finally { final long duration = registry.clock().wallTime() - start; log.info("### Time taken to complete {} is {} ms", resourceRequestName,