
io.xream.x7.reyc.internal.HttpClientInvocationHandler Maven / Gradle / Ivy
/*
* 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 io.xream.x7.reyc.internal;
import io.xream.x7.common.util.LoggerProxy;
import io.xream.x7.reyc.BackendService;
import io.xream.x7.common.util.ExceptionUtil;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
public class HttpClientInvocationHandler implements InvocationHandler {
private HttpClientProxy httpClientProxy;
public HttpClientInvocationHandler(HttpClientProxy httpClientProxy){
this.httpClientProxy = httpClientProxy;
}
@Override
public Object invoke(Object proxy, Method method, Object[] args) {
final String methodName = method.getName();
if (methodName.equals("toString"))
return null;
Class clzz = httpClientProxy.getObjectType();
long startTime = System.currentTimeMillis();
try{
LoggerProxy.debug(clzz,methodName +"(..) start....");
R r = HttpClientResolver.r(clzz.getName(),methodName,args);
if (httpClientProxy.getBackend() == null) {
String result = HttpClientResolver.resolve(r,clzz);
return HttpClientResolver.toObject(r.getReturnType(),r.getGeneType(),result);
}
String result = HttpClientResolver.wrap(httpClientProxy, new BackendService() {
@Override
public String handle() {
return HttpClientResolver.resolve(r,clzz);
}
@Override
public Object fallback() {
return HttpClientResolver.fallback(clzz.getName(),methodName,args);
}
});
return HttpClientResolver.toObject(r.getReturnType(),r.getGeneType(),result);
} catch (RuntimeException re){
throw re;
} catch (Exception e){
throw new RuntimeException(ExceptionUtil.getMessage(e));
}finally {
long endTime = System.currentTimeMillis();
LoggerProxy.debug(clzz,methodName + "(..) end, cost time: " + (endTime - startTime) + "ms");
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy