1/********************************************************************
2 * Copyright (c) 2013 - 2014, Pivotal Inc.
3 * All rights reserved.
4 *
5 * Author: Zhanwei Wang
6 ********************************************************************/
7/********************************************************************
8 * 2014 -
9 * open source under Apache License Version 2.0
10 ********************************************************************/
11/**
12 * Licensed to the Apache Software Foundation (ASF) under one
13 * or more contributor license agreements. See the NOTICE file
14 * distributed with this work for additional information
15 * regarding copyright ownership. The ASF licenses this file
16 * to you under the Apache License, Version 2.0 (the
17 * "License"); you may not use this file except in compliance
18 * with the License. You may obtain a copy of the License at
19 *
20 * http://www.apache.org/licenses/LICENSE-2.0
21 *
22 * Unless required by applicable law or agreed to in writing, software
23 * distributed under the License is distributed on an "AS IS" BASIS,
24 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
25 * See the License for the specific language governing permissions and
26 * limitations under the License.
27 */
28#ifndef _HDFS_LIBHDFS3_RPC_RPCPROTOCOLINFO_H_
29#define _HDFS_LIBHDFS3_RPC_RPCPROTOCOLINFO_H_
30
31#include "Hash.h"
32
33#include <string>
34
35namespace Hdfs {
36namespace Internal {
37
38class RpcProtocolInfo {
39public:
40 RpcProtocolInfo(int v, const std::string & p, const std::string & tokenKind) :
41 version(v), protocol(p), tokenKind(tokenKind) {
42 }
43
44 size_t hash_value() const;
45
46 bool operator ==(const RpcProtocolInfo & other) const {
47 return version == other.version && protocol == other.protocol && tokenKind == other.tokenKind;
48 }
49
50 const std::string & getProtocol() const {
51 return protocol;
52 }
53
54 void setProtocol(const std::string & protocol) {
55 this->protocol = protocol;
56 }
57
58 int getVersion() const {
59 return version;
60 }
61
62 void setVersion(int version) {
63 this->version = version;
64 }
65
66 const std::string & getTokenKind() const {
67 return tokenKind;
68 }
69
70 void setTokenKind(const std::string & tokenKind) {
71 this->tokenKind = tokenKind;
72 }
73
74private:
75 int version;
76 std::string protocol;
77 std::string tokenKind;
78
79};
80
81}
82}
83
84HDFS_HASH_DEFINE(::Hdfs::Internal::RpcProtocolInfo);
85
86#endif /* _HDFS_LIBHDFS3_RPC_RPCPROTOCOLINFO_H_ */
87