use of com.dtflys.forest.logging.DefaultLogHandler in project forest by dromara.
the class ForestConfiguration method createConfiguration.
public static ForestConfiguration createConfiguration() {
ForestConfiguration configuration = new ForestConfiguration();
configuration.setId("forestConfiguration" + configuration.hashCode());
configuration.setJsonConverterSelector(new JSONConverterSelector());
ForestProtobufConverterManager protobufConverterFactory = ForestProtobufConverterManager.getInstance();
configuration.setProtobufConverter(protobufConverterFactory.getForestProtobufConverter());
configuration.setXmlConverter(new ForestJaxbConverter());
configuration.setTextConverter(new DefaultTextConverter());
DefaultAutoConverter autoConverter = new DefaultAutoConverter(configuration);
configuration.getConverterMap().put(ForestDataType.AUTO, autoConverter);
configuration.getConverterMap().put(ForestDataType.BINARY, new DefaultBinaryConverter(autoConverter));
configuration.getConverterMap().put(ForestDataType.FORM, new DefaultFormConvertor(configuration));
setupJSONConverter(configuration);
configuration.setTimeout(3000);
configuration.setMaxConnections(500);
configuration.setMaxRouteConnections(500);
configuration.setRetryer(BackOffRetryer.class);
configuration.setMaxRetryCount(0);
configuration.setMaxRetryInterval(0);
configuration.registerFilter("json", JSONFilter.class);
configuration.registerFilter("xml", XmlFilter.class);
configuration.setLogHandler(new DefaultLogHandler());
return configuration;
}
use of com.dtflys.forest.logging.DefaultLogHandler in project forest by dromara.
the class ForestMethod method processMetaRequest.
private void processMetaRequest(MetaRequest metaRequest) {
Class[] paramTypes = method.getParameterTypes();
Type[] genericParamTypes = method.getGenericParameterTypes();
Annotation[][] paramAnns = method.getParameterAnnotations();
Parameter[] parameters = method.getParameters();
Class<? extends Annotation> reqAnnType = metaRequest.getRequestAnnotation().annotationType();
parameterTemplateArray = new MappingParameter[paramTypes.length];
processParameters(parameters, genericParamTypes, paramAnns);
bodyTypeTemplate = makeTemplate(reqAnnType, "type", metaRequest.getBodyType());
urlTemplate = makeURLTemplate(reqAnnType, "url", metaRequest.getUrl());
typeTemplate = makeTemplate(reqAnnType, "type", metaRequest.getType());
dataTypeTemplate = makeTemplate(reqAnnType, "dataType", metaRequest.getDataType());
if (StringUtils.isNotEmpty(metaRequest.getContentType())) {
contentTypeTemplate = makeTemplate(reqAnnType, "contentType", metaRequest.getContentType());
}
if (StringUtils.isNotEmpty(metaRequest.getUserAgent())) {
userAgentTemplate = makeTemplate(reqAnnType, "userAgent", metaRequest.getUserAgent());
}
sslKeyStoreId = makeTemplate(reqAnnType, "keyStore", metaRequest.getKeyStore());
if (StringUtils.isNotEmpty(metaRequest.getContentEncoding())) {
encodeTemplate = makeTemplate(reqAnnType, "contentEncoding", metaRequest.getContentEncoding());
}
charsetTemplate = makeTemplate(reqAnnType, "charset", metaRequest.getCharset());
if (metaRequest.getResponseEncoding() != null) {
responseEncodingTemplate = makeTemplate(reqAnnType, "responseEncoding", metaRequest.getResponseEncoding());
}
sslProtocolTemplate = makeTemplate(reqAnnType, "sslProtocol", metaRequest.getSslProtocol());
progressStep = metaRequest.getProgressStep();
async = metaRequest.isAsync();
retryerClass = metaRequest.getRetryer();
Class<? extends ForestEncoder> encoderClass = metaRequest.getEncoder();
Class<? extends ForestConverter> decoderClass = metaRequest.getDecoder();
String[] dataArray = metaRequest.getData();
String[] headerArray = metaRequest.getHeaders();
Integer tout = metaRequest.getTimeout();
if (tout != null && tout >= 0) {
timeout = tout;
}
Integer ctout = metaRequest.getConnectTimeout();
if (ctout != null && ctout >= 0) {
connectTimeout = ctout;
}
Integer rtout = metaRequest.getReadTimeout();
if (rtout != null && rtout >= 0) {
readTimeout = rtout;
}
Integer rtnum = metaRequest.getRetryCount();
if (rtnum != null && rtnum >= 0) {
retryCount = rtnum;
}
maxRetryInterval = metaRequest.getMaxRetryInterval();
logEnabled = configuration.isLogEnabled();
if (!logEnabled) {
logEnabled = metaRequest.isLogEnabled();
}
logRequest = configuration.isLogRequest();
logResponseStatus = configuration.isLogResponseStatus();
logResponseContent = configuration.isLogResponseContent();
LogConfiguration metaLogConfiguration = metaRequest.getLogConfiguration();
if (metaLogConfiguration == null && baseLogConfiguration != null) {
metaLogConfiguration = baseLogConfiguration;
}
if (metaLogConfiguration != null) {
logEnabled = metaLogConfiguration.isLogEnabled();
logRequest = metaLogConfiguration.isLogRequest();
logResponseStatus = metaLogConfiguration.isLogResponseStatus();
logResponseContent = metaLogConfiguration.isLogResponseContent();
logHandler = metaLogConfiguration.getLogHandler();
if (logHandler == null && baseLogConfiguration != null) {
logHandler = baseLogConfiguration.getLogHandler();
}
}
if (logHandler == null && configuration.getLogHandler() != null) {
logHandler = configuration.getLogHandler();
}
if (logHandler == null) {
logHandler = new DefaultLogHandler();
}
logConfiguration = new LogConfiguration();
logConfiguration.setLogEnabled(logEnabled);
logConfiguration.setLogRequest(logRequest);
logConfiguration.setLogResponseStatus(logResponseStatus);
logConfiguration.setLogResponseContent(logResponseContent);
logConfiguration.setLogHandler(logHandler);
dataTemplateArray = new MappingTemplate[dataArray.length];
for (int j = 0; j < dataArray.length; j++) {
String data = dataArray[j];
MappingTemplate dataTemplate = makeTemplate(reqAnnType, "data", data);
dataTemplateArray[j] = dataTemplate;
}
headerTemplateArray = new MappingTemplate[headerArray.length];
for (int j = 0; j < headerArray.length; j++) {
String header = headerArray[j];
MappingTemplate headerTemplate = makeTemplate(reqAnnType, "header", header);
headerTemplateArray[j] = headerTemplate;
}
Class[] interceptorClasses = metaRequest.getInterceptor();
if (interceptorClasses != null && interceptorClasses.length > 0) {
for (int cidx = 0, len = interceptorClasses.length; cidx < len; cidx++) {
Class interceptorClass = interceptorClasses[cidx];
addInterceptor(interceptorClass);
}
}
if (encoderClass != null && !encoderClass.isInterface() && ForestEncoder.class.isAssignableFrom(encoderClass)) {
this.encoder = configuration.getForestObjectFactory().getObject(encoderClass);
}
if (decoderClass != null && !encoderClass.isInterface() && ForestConverter.class.isAssignableFrom(decoderClass)) {
this.decoder = configuration.getForestObjectFactory().getObject(decoderClass);
}
}
Aggregations