/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.synapse.transport.nhttp.debug;
import org.apache.http.Header;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;
/**
*
*/
public abstract class AbstractConnectionDebug {
protected String keyValueSeparator;
protected String fieldSeparator;
protected String statementSeparator;
protected boolean printAllHeaders;
protected boolean printNoHeaders;
protected List<String> printHeaderNames;
protected Header[] headers;
protected AbstractConnectionDebug() {
NhttpConnectionDebugConfig connDebugConfig = NhttpConnectionDebugConfig.getInstance();
this.keyValueSeparator = connDebugConfig.getKeyValueSeparator();
this.fieldSeparator = connDebugConfig.getFieldSeparator();
this.statementSeparator = connDebugConfig.getStatementSeparator();
if (connDebugConfig.isNoHeaders()) {
this.printNoHeaders = true;
} else if (connDebugConfig.isAllHeaders()) {
this.printAllHeaders = true;
} else {
this.printHeaderNames = connDebugConfig.getHeaders();
}
}
// SimpleDateFormat is not thread-safe
private static final ThreadLocal<SimpleDateFormat> formatter = new ThreadLocal<SimpleDateFormat>() {
@Override
protected SimpleDateFormat initialValue() {
return new SimpleDateFormat("HH:mm:ss.SSS");
}
};
protected String format(long ms) {
return formatter.get().format(new Date(ms));
}
public abstract String dump();
protected StringBuffer headersToString() {
StringBuffer sb = new StringBuffer();
if (headers != null) {
if (printAllHeaders) {
boolean first = true;
for (Header h : headers) {
if (first) {
first = false;
} else {
sb.append(fieldSeparator);
}
sb.append(h.getName()).append(keyValueSeparator).append(h.getValue());
}
} else if (printHeaderNames != null) {
boolean first = true;
for (Header h : headers) {
if (printHeaderNames.contains(h.getName())) {
if (first) {
first = false;
} else {
sb.append(fieldSeparator);
}
sb.append(h.getName()).append(keyValueSeparator).append(h.getValue());
}
}
}
}
return sb.length() > 0 ? sb : sb.append("NOT_AVAILABLE");
}
}