Bruno Marco Visioli created CAMEL-9102:
------------------------------------------
Summary: CxfEndpoint could use loggingSizeLimit = -1 for no size
limit
Key: CAMEL-9102
URL: https://issues.apache.org/jira/browse/CAMEL-9102
Project: Camel
Issue Type: Improvement
Components: camel-cxf, camel-cxfrs
Affects Versions: 2.15.3
Reporter: Bruno Marco Visioli
Priority: Minor
When creating a CxfEndpoint, setting a loggingSizeLimit -1 to disable limiting
payload logging cause no effect due to the code bellow. CXF own
LoggingIn/OutInterceptor code accept -1 as unlimited.
org.apache.camel.component.cxf.CxfEndpoint
{code:java}
if (getLoggingSizeLimit() > 0) {
sfb.getFeatures().add(new LoggingFeature(getLoggingSizeLimit()));
} else {
sfb.getFeatures().add(new LoggingFeature());
}
{code}
org.apache.cxf.feature.LoggingFeature
{code:java}
private static final int DEFAULT_LIMIT =
AbstractLoggingInterceptor.DEFAULT_LIMIT;
private static final LoggingInInterceptor IN = new
LoggingInInterceptor(DEFAULT_LIMIT);
private static final LoggingOutInterceptor OUT = new
LoggingOutInterceptor(DEFAULT_LIMIT);
int limit = DEFAULT_LIMIT;
public LoggingFeature() {}
protected void initializeProvider(InterceptorProvider provider, Bus bus) {
if (limit == DEFAULT_LIMIT && inLocation == null && outLocation == null &&
!prettyLogging) {
provider.getInInterceptors().add(IN);
provider.getInFaultInterceptors().add(IN);
provider.getOutInterceptors().add(OUT);
provider.getOutFaultInterceptors().add(OUT);
} else {
//Creates and uses new Interceptors with specified limit
}
{code}
org.apache.cxf.interceptor.LoggingInInterceptor
{code:java}
public LoggingInInterceptor(int lim) {
this();
limit = lim;
}
protected void logInputStream(Message message, InputStream is, LoggingMessage
buffer, String encoding, String ct) {
(...)
//only copy up to the limit since that's all we need to log
//we can stream the rest
IOUtils.copyAtLeast(bis, bos, limit == -1 ? Integer.MAX_VALUE : limit);
{code}
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)