You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@camel.apache.org by "Claus Ibsen (JIRA)" <ji...@apache.org> on 2015/09/04 10:21:46 UTC
[jira] [Assigned] (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:all-tabpanel ]
Claus Ibsen reassigned CAMEL-9102:
----------------------------------
Assignee: Claus Ibsen
> 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
> Assignee: Claus Ibsen
> Priority: Trivial
> Fix For: 2.16.0
>
>
> 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)