You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@camel.apache.org by "Bruno Marco Visioli (JIRA)" <ji...@apache.org> on 2015/09/02 16:57:45 UTC

[jira] [Commented] (CAMEL-9102) CxfEndpoint could use loggingSizeLimit = -1 for no size limit

    [ https://issues.apache.org/jira/browse/CAMEL-9102?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=14727460#comment-14727460 ] 

Bruno Marco Visioli commented on CAMEL-9102:
--------------------------------------------

Changed to trivial because using Integer.MAX_VALUE for setLoggingSizeLimit(int limit) has the same result as -1.

> 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: Trivial
>
> 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)