/** * Tencent is pleased to support the open source community by making MSEC available. * * Copyright (C) 2016 THL A29 Limited, a Tencent company. All rights reserved. * * Licensed under the GNU General Public 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 * * https://opensource.org/licenses/GPL-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.msec.rpc; import org.jboss.netty.channel.ChannelHandlerContext; import java.net.InetSocketAddress; import java.util.HashMap; import java.util.Map; public class RpcContext { public RpcContext(RpcRequest request, ChannelHandlerContext channelContext) { this.request = request; this.channelContext = channelContext; clientAddr = (InetSocketAddress)channelContext.getChannel().getRemoteAddress(); localAddr = (InetSocketAddress)channelContext.getChannel().getLocalAddress(); InitLogOptions(); } private RpcRequest request; private RpcResponse response; private InetSocketAddress clientAddr; private InetSocketAddress localAddr; private ChannelHandlerContext channelContext; private Map<String, String> logOptions = new HashMap<String, String>(); private void InitLogOptions() { logOptions.put("ReqID", Long.toString(request.getFlowid())); logOptions.put("ClientIP", clientAddr.getAddress().getHostAddress()); logOptions.put("ServerIP", localAddr.getAddress().getHostAddress()); logOptions.put("RPCName", request.getServiceName() + "." + request.getMethodName()); logOptions.put("Caller", request.getFromModule()); logOptions.put("ServiceName", ServiceFactory.getModuleName()); } public RpcRequest getRequest() { return request; } public ChannelHandlerContext getChannelContext() { return channelContext; } public RpcResponse getResponse() { return response; } public void setResponse(RpcResponse response) { this.response = response; } public InetSocketAddress getClientAddr() { return clientAddr; } public void setClientAddr(InetSocketAddress clientAddr) { this.clientAddr = clientAddr; } public InetSocketAddress getLocalAddr() { return localAddr; } public void setLocalAddr(InetSocketAddress localAddr) { this.localAddr = localAddr; } public Map<String, String> getLogOptions() { return logOptions; } }