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)