public class org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer extends org.apache.camel.processor.loadbalancer.LoadBalancerSupport implements org.apache.camel.Traceable, org.apache.camel.CamelContextAware
{
private static final int STATE_CLOSED;
private static final int STATE_HALF_OPEN;
private static final int STATE_OPEN;
private final java.util.List exceptions;
private org.apache.camel.CamelContext camelContext;
private int threshold;
private long halfOpenAfter;
private long lastFailure;
private java.util.concurrent.atomic.AtomicInteger failures;
private java.util.concurrent.atomic.AtomicInteger state;
private final org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics statistics;
public void <init>()
{
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
specialinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: void <init>(java.util.List)>(null);
return;
}
public void <init>(java.util.List)
{
java.util.List v;
java.util.concurrent.atomic.AtomicInteger v, v;
org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics v, v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v := @parameter: java.util.List;
specialinvoke v.<org.apache.camel.processor.loadbalancer.LoadBalancerSupport: void <init>()>();
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>()>();
v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger failures> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>(int)>(0);
v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger state> = v;
v = new org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics;
specialinvoke v.<org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics: void <init>()>();
v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics statistics> = v;
v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.List exceptions> = v;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics statistics>;
virtualinvoke v.<org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics: void init(java.util.List)>(v);
return;
}
public void setHalfOpenAfter(long)
{
long v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v := @parameter: long;
v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: long halfOpenAfter> = v;
return;
}
public long getHalfOpenAfter()
{
long v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: long halfOpenAfter>;
return v;
}
public void setThreshold(int)
{
int v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v := @parameter: int;
v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: int threshold> = v;
return;
}
public int getThreshold()
{
int v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: int threshold>;
return v;
}
public int getState()
{
int v;
java.util.concurrent.atomic.AtomicInteger v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger state>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
return v;
}
public org.apache.camel.CamelContext getCamelContext()
{
org.apache.camel.CamelContext v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: org.apache.camel.CamelContext camelContext>;
return v;
}
public void setCamelContext(org.apache.camel.CamelContext)
{
org.apache.camel.CamelContext v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v := @parameter: org.apache.camel.CamelContext;
v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: org.apache.camel.CamelContext camelContext> = v;
return;
}
public java.util.List getExceptions()
{
java.util.List v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.List exceptions>;
return v;
}
protected boolean hasFailed(org.apache.camel.Exchange)
{
org.apache.camel.Exchange v;
java.lang.Boolean v;
java.lang.String v;
boolean v, v, v;
org.slf4j.Logger v;
java.util.Iterator v;
org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
java.lang.Exception v, v;
java.util.List v, v, v;
java.lang.Object v, v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v := @parameter: org.apache.camel.Exchange;
if v != null goto label;
return 0;
label:
v = 0;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.Exception getException()>();
if v == null goto label;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.List exceptions>;
if v == null goto label;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.List exceptions>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
label:
v = 1;
goto label;
label:
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.List exceptions>;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.Object getException(java.lang.Class)>(v);
if v == null goto label;
v = 1;
label:
if v == 0 goto label;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics statistics>;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.Exception getException()>();
virtualinvoke v.<org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics: void onHandledFailure(java.lang.Exception)>(v);
label:
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: org.slf4j.Logger log>;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.String getExchangeId()>();
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("Failed: {} for exchangeId: {}", v, v);
return v;
}
public boolean isRunAllowed()
{
org.apache.camel.CamelContext v;
org.apache.camel.spi.ShutdownStrategy v;
org.slf4j.Logger v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
boolean v, v, v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: org.apache.camel.CamelContext camelContext>;
v = interfaceinvoke v.<org.apache.camel.CamelContext: org.apache.camel.spi.ShutdownStrategy getShutdownStrategy()>();
v = interfaceinvoke v.<org.apache.camel.spi.ShutdownStrategy: boolean forceShutdown(org.apache.camel.Service)>(v);
if v == 0 goto label;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>("Run not allowed as ShutdownStrategy is forcing shutting down");
label:
if v != 0 goto label;
v = specialinvoke v.<org.apache.camel.processor.loadbalancer.LoadBalancerSupport: boolean isRunAllowed()>();
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public boolean process(org.apache.camel.Exchange, org.apache.camel.AsyncCallback)
{
org.slf4j.Logger v;
org.apache.camel.AsyncCallback v;
org.apache.camel.Exchange v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
java.lang.Exception v;
java.util.concurrent.RejectedExecutionException v;
boolean v, v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v := @parameter: org.apache.camel.Exchange;
v := @parameter: org.apache.camel.AsyncCallback;
v = virtualinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: boolean isRunAllowed()>();
if v != 0 goto label;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("Run not allowed, will reject executing exchange: {}", v);
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.Exception getException()>();
if v != null goto label;
v = new java.util.concurrent.RejectedExecutionException;
specialinvoke v.<java.util.concurrent.RejectedExecutionException: void <init>(java.lang.String)>("Run is not allowed");
interfaceinvoke v.<org.apache.camel.Exchange: void setException(java.lang.Throwable)>(v);
label:
interfaceinvoke v.<org.apache.camel.AsyncCallback: void done(boolean)>(1);
return 1;
label:
v = specialinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: boolean calculateState(org.apache.camel.Exchange,org.apache.camel.AsyncCallback)>(v, v);
return v;
}
private boolean calculateState(org.apache.camel.Exchange, org.apache.camel.AsyncCallback)
{
java.lang.IllegalStateException v;
byte v, v, v;
java.util.concurrent.atomic.AtomicInteger v, v, v, v, v, v, v, v;
boolean v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
long v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.camel.Exchange v;
int v, v, v, v, v, v, v, v, v, v, v;
java.lang.String v;
org.apache.camel.AsyncCallback v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v := @parameter: org.apache.camel.Exchange;
v := @parameter: org.apache.camel.AsyncCallback;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger state>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
if v != 1 goto label;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger failures>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
if v != 0 goto label;
v = specialinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: boolean closeCircuit(org.apache.camel.Exchange,org.apache.camel.AsyncCallback)>(v, v);
goto label;
label:
v = specialinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: boolean openCircuit(org.apache.camel.Exchange,org.apache.camel.AsyncCallback)>(v, v);
goto label;
label:
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger state>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
if v != 2 goto label;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger failures>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: int threshold>;
if v < v goto label;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: long lastFailure>;
v = v - v;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: long halfOpenAfter>;
v = v cmp v;
if v >= 0 goto label;
v = specialinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: boolean openCircuit(org.apache.camel.Exchange,org.apache.camel.AsyncCallback)>(v, v);
goto label;
label:
v = specialinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: boolean halfOpenCircuit(org.apache.camel.Exchange,org.apache.camel.AsyncCallback)>(v, v);
goto label;
label:
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger state>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
if v != 0 goto label;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger failures>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: int threshold>;
if v < v goto label;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: long lastFailure>;
v = v - v;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: long halfOpenAfter>;
v = v cmp v;
if v >= 0 goto label;
v = specialinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: boolean openCircuit(org.apache.camel.Exchange,org.apache.camel.AsyncCallback)>(v, v);
goto label;
label:
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger failures>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: int threshold>;
if v < v goto label;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: long lastFailure>;
v = v - v;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: long halfOpenAfter>;
v = v cmp v;
if v < 0 goto label;
v = specialinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: boolean halfOpenCircuit(org.apache.camel.Exchange,org.apache.camel.AsyncCallback)>(v, v);
goto label;
label:
v = specialinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: boolean closeCircuit(org.apache.camel.Exchange,org.apache.camel.AsyncCallback)>(v, v);
goto label;
label:
v = new java.lang.IllegalStateException;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger state>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Unrecognised circuitBreaker state \u0001");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
label:
return v;
}
private boolean openCircuit(org.apache.camel.Exchange, org.apache.camel.AsyncCallback)
{
java.util.concurrent.atomic.AtomicInteger v;
org.apache.camel.AsyncCallback v;
org.apache.camel.Exchange v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
boolean v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v := @parameter: org.apache.camel.Exchange;
v := @parameter: org.apache.camel.AsyncCallback;
v = specialinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: boolean rejectExchange(org.apache.camel.Exchange,org.apache.camel.AsyncCallback)>(v, v);
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger state>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(2);
specialinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: void logState()>();
return v;
}
private boolean halfOpenCircuit(org.apache.camel.Exchange, org.apache.camel.AsyncCallback)
{
java.util.concurrent.atomic.AtomicInteger v;
org.apache.camel.AsyncCallback v;
org.apache.camel.Exchange v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
boolean v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v := @parameter: org.apache.camel.Exchange;
v := @parameter: org.apache.camel.AsyncCallback;
v = specialinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: boolean executeProcessor(org.apache.camel.Exchange,org.apache.camel.AsyncCallback)>(v, v);
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger state>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(1);
specialinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: void logState()>();
return v;
}
private boolean closeCircuit(org.apache.camel.Exchange, org.apache.camel.AsyncCallback)
{
java.util.concurrent.atomic.AtomicInteger v;
org.apache.camel.AsyncCallback v;
org.apache.camel.Exchange v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
boolean v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v := @parameter: org.apache.camel.Exchange;
v := @parameter: org.apache.camel.AsyncCallback;
v = specialinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: boolean executeProcessor(org.apache.camel.Exchange,org.apache.camel.AsyncCallback)>(v, v);
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger state>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(0);
specialinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: void logState()>();
return v;
}
private void logState()
{
org.slf4j.Logger v, v;
java.lang.String v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
boolean v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: org.slf4j.Logger log>;
v = virtualinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.lang.String dumpState()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
return;
}
public java.lang.String dumpState()
{
java.lang.Object[] v, v;
long v, v, v, v;
java.lang.Integer v, v;
byte v;
java.lang.Long v;
java.util.concurrent.atomic.AtomicInteger v, v, v;
int v, v, v;
java.lang.String v, v, v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger state>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = staticinvoke <org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.lang.String stateAsString(int)>(v);
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: long lastFailure>;
v = v cmp 0L;
if v <= 0 goto label;
v = newarray (java.lang.Object)[3];
v[0] = v;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger failures>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[1] = v;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: long lastFailure>;
v = v - v;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[2] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("State %s, failures %d, closed since %d", v);
return v;
label:
v = newarray (java.lang.Object)[2];
v[0] = v;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger failures>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("State %s, failures %d", v);
return v;
}
private boolean executeProcessor(org.apache.camel.Exchange, org.apache.camel.AsyncCallback)
{
java.lang.IllegalStateException v;
long v;
org.apache.camel.Exchange v;
java.util.concurrent.atomic.AtomicInteger v, v, v;
int v;
java.lang.String v, v, v;
boolean v, v;
org.slf4j.Logger v, v;
org.apache.camel.AsyncCallback v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer$CircuitBreakerCallback v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
java.util.List v;
org.apache.camel.AsyncProcessor v;
java.lang.Object v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v := @parameter: org.apache.camel.Exchange;
v := @parameter: org.apache.camel.AsyncCallback;
v = virtualinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.List getProcessors()>();
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
if v != null goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("No processors could be chosen to process CircuitBreaker");
throw v;
label:
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger state>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = staticinvoke <org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.lang.String stateAsString(int)>(v);
interfaceinvoke v.<org.apache.camel.Exchange: void setProperty(java.lang.String,java.lang.Object)>("CamelCircuitBreakerState", v);
v = staticinvoke <org.apache.camel.util.AsyncProcessorConverterHelper: org.apache.camel.AsyncProcessor convert(org.apache.camel.Processor)>(v);
v = new org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer$CircuitBreakerCallback;
specialinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer$CircuitBreakerCallback: void <init>(org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer,org.apache.camel.Exchange,org.apache.camel.AsyncCallback)>(v, v, v);
v = interfaceinvoke v.<org.apache.camel.AsyncProcessor: boolean process(org.apache.camel.Exchange,org.apache.camel.AsyncCallback)>(v, v);
if v == 0 goto label;
v = virtualinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: boolean hasFailed(org.apache.camel.Exchange)>(v);
if v != 0 goto label;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger failures>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(0);
goto label;
label:
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger failures>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: long lastFailure> = v;
goto label;
label:
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.String getExchangeId()>();
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("Processing exchangeId: {} is continued being processed asynchronously", v);
return 0;
label:
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.String getExchangeId()>();
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("Processing exchangeId: {} is continued being processed synchronously", v);
interfaceinvoke v.<org.apache.camel.AsyncCallback: void done(boolean)>(1);
return 1;
}
private boolean rejectExchange(org.apache.camel.Exchange, org.apache.camel.AsyncCallback)
{
java.util.concurrent.RejectedExecutionException v;
java.util.concurrent.atomic.AtomicInteger v;
org.apache.camel.AsyncCallback v;
long v;
org.apache.camel.Exchange v;
java.lang.String v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v := @parameter: org.apache.camel.Exchange;
v := @parameter: org.apache.camel.AsyncCallback;
v = new java.util.concurrent.RejectedExecutionException;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger failures>;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: long lastFailure>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.concurrent.atomic.AtomicInteger,long)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("CircuitBreaker Open: failures: \u, lastFailure: \u0001");
specialinvoke v.<java.util.concurrent.RejectedExecutionException: void <init>(java.lang.String)>(v);
interfaceinvoke v.<org.apache.camel.Exchange: void setException(java.lang.Throwable)>(v);
interfaceinvoke v.<org.apache.camel.AsyncCallback: void done(boolean)>(1);
return 1;
}
private static java.lang.String stateAsString(int)
{
int v;
v := @parameter: int;
if v != 0 goto label;
return "closed";
label:
if v != 1 goto label;
return "half opened";
label:
return "opened";
}
public java.lang.String toString()
{
java.util.List v;
java.lang.String v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v = virtualinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.List getProcessors()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.List)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("CircuitBreakerLoadBalancer[\u]");
return v;
}
public java.lang.String getTraceLabel()
{
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
return "circuitbreaker";
}
public org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics getExceptionFailureStatistics()
{
org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics statistics>;
return v;
}
public void reset()
{
java.util.concurrent.atomic.AtomicInteger v, v;
org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics v;
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger failures>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(0);
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: java.util.concurrent.atomic.AtomicInteger state>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(0);
v = v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics statistics>;
virtualinvoke v.<org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics: void reset()>();
return;
}
protected void doStart() throws java.lang.Exception
{
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
specialinvoke v.<org.apache.camel.processor.loadbalancer.LoadBalancerSupport: void doStart()>();
virtualinvoke v.<org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer: void reset()>();
return;
}
protected void doStop() throws java.lang.Exception
{
org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer;
specialinvoke v.<org.apache.camel.processor.loadbalancer.LoadBalancerSupport: void doStop()>();
return;
}
}