blob: 0ab7c3186eb8d26d99b10192ad1dbbc514b9e3db [file] [log] [blame]
Thomas Vachuska24c849c2014-10-27 09:53:05 -07001/*
Brian O'Connor5ab426f2016-04-09 01:19:45 -07002 * Copyright 2016-present Open Networking Laboratory
Thomas Vachuska24c849c2014-10-27 09:53:05 -07003 *
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -07004 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
Thomas Vachuska24c849c2014-10-27 09:53:05 -07007 *
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -07008 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
Thomas Vachuska24c849c2014-10-27 09:53:05 -070015 */
Aaron Kruglikov1b727382016-02-09 16:17:47 -080016package org.onosproject.store.cluster.messaging.impl;
Yuta HIGUCHI0a0b9e42015-02-11 16:57:12 -080017
18import com.google.common.base.MoreObjects;
Madan Jampani05833872016-07-12 23:01:39 -070019
Aaron Kruglikov1b727382016-02-09 16:17:47 -080020import org.onlab.util.ByteArraySizeHashPrinter;
Madan Jampani05833872016-07-12 23:01:39 -070021import org.onosproject.core.HybridLogicalTime;
Aaron Kruglikov1b727382016-02-09 16:17:47 -080022import org.onosproject.store.cluster.messaging.Endpoint;
Yuta HIGUCHI0a0b9e42015-02-11 16:57:12 -080023
Madan Jampaniab6d3112014-10-02 16:30:14 -070024/**
25 * Internal message representation with additional attributes
26 * for supporting, synchronous request/reply behavior.
27 */
Madan Jampanic26eede2015-04-16 11:42:16 -070028public final class InternalMessage {
Madan Jampaniab6d3112014-10-02 16:30:14 -070029
Madan Jampania9e70a62016-03-02 16:28:18 -080030 /**
31 * Message status.
32 */
33 public enum Status {
Jordan Halterman742bd092017-02-28 01:01:49 -080034
35 // NOTE: For backwards compatibility enum constant IDs should not be changed.
36
Madan Jampania9e70a62016-03-02 16:28:18 -080037 /**
38 * All ok.
39 */
Jordan Halterman742bd092017-02-28 01:01:49 -080040 OK(0),
Madan Jampania9e70a62016-03-02 16:28:18 -080041
42 /**
43 * Response status signifying no registered handler.
44 */
Jordan Halterman742bd092017-02-28 01:01:49 -080045 ERROR_NO_HANDLER(1),
Madan Jampania9e70a62016-03-02 16:28:18 -080046
47 /**
48 * Response status signifying an exception handling the message.
49 */
Jordan Halterman742bd092017-02-28 01:01:49 -080050 ERROR_HANDLER_EXCEPTION(2),
Madan Jampanib825aeb2016-04-01 15:18:25 -070051
52 /**
Jordan Halterman742bd092017-02-28 01:01:49 -080053 * Response status signifying invalid message structure.
Madan Jampanib825aeb2016-04-01 15:18:25 -070054 */
Jordan Halterman742bd092017-02-28 01:01:49 -080055 PROTOCOL_EXCEPTION(3);
Madan Jampania9e70a62016-03-02 16:28:18 -080056
Jordan Halterman742bd092017-02-28 01:01:49 -080057 private final int id;
58
59 Status(int id) {
60 this.id = id;
61 }
62
63 /**
64 * Returns the unique status ID.
65 *
66 * @return the unique status ID.
67 */
68 public int id() {
69 return id;
70 }
71
72 /**
73 * Returns the status enum associated with the given ID.
74 *
75 * @param id the status ID.
76 * @return the status enum for the given ID.
77 */
78 public static Status forId(int id) {
79 switch (id) {
80 case 0:
81 return OK;
82 case 1:
83 return ERROR_NO_HANDLER;
84 case 2:
85 return ERROR_HANDLER_EXCEPTION;
86 case 3:
87 return PROTOCOL_EXCEPTION;
88 default:
89 throw new IllegalArgumentException("Unknown status ID " + id);
90 }
91 }
Madan Jampania9e70a62016-03-02 16:28:18 -080092 }
93
Madan Jampanib825aeb2016-04-01 15:18:25 -070094 private final int preamble;
Madan Jampani05833872016-07-12 23:01:39 -070095 private final HybridLogicalTime time;
Madan Jampanic26eede2015-04-16 11:42:16 -070096 private final long id;
97 private final Endpoint sender;
98 private final String type;
99 private final byte[] payload;
Madan Jampania9e70a62016-03-02 16:28:18 -0800100 private final Status status;
Yuta HIGUCHIc65f5122014-10-07 10:05:59 -0700101
Madan Jampani05833872016-07-12 23:01:39 -0700102 public InternalMessage(int preamble,
103 HybridLogicalTime time,
104 long id,
105 Endpoint sender,
106 String type,
107 byte[] payload) {
Jordan Haltermanf7c7f6f2017-05-05 03:02:34 -0700108 this(preamble, time, id, sender, type, payload, null);
Madan Jampania9e70a62016-03-02 16:28:18 -0800109 }
110
Madan Jampani05833872016-07-12 23:01:39 -0700111 public InternalMessage(int preamble,
Jordan Haltermanf7c7f6f2017-05-05 03:02:34 -0700112 HybridLogicalTime time,
113 long id,
114 Endpoint sender,
115 byte[] payload,
116 Status status) {
117 this(preamble, time, id, sender, "", payload, status);
118 }
119
120 InternalMessage(int preamble,
Madan Jampani05833872016-07-12 23:01:39 -0700121 HybridLogicalTime time,
122 long id,
123 Endpoint sender,
124 String type,
125 byte[] payload,
126 Status status) {
Madan Jampanib825aeb2016-04-01 15:18:25 -0700127 this.preamble = preamble;
Madan Jampani05833872016-07-12 23:01:39 -0700128 this.time = time;
Yuta HIGUCHI91768e32014-11-22 05:06:35 -0800129 this.id = id;
130 this.sender = sender;
131 this.type = type;
132 this.payload = payload;
Madan Jampania9e70a62016-03-02 16:28:18 -0800133 this.status = status;
Yuta HIGUCHI91768e32014-11-22 05:06:35 -0800134 }
135
Jordan Haltermanf7c7f6f2017-05-05 03:02:34 -0700136 public boolean isRequest() {
137 return status == null;
138 }
139
140 public boolean isReply() {
141 return status != null;
142 }
143
Madan Jampani05833872016-07-12 23:01:39 -0700144 public HybridLogicalTime time() {
145 return time;
146 }
147
Madan Jampanib825aeb2016-04-01 15:18:25 -0700148 public int preamble() {
149 return preamble;
150 }
151
Madan Jampaniab6d3112014-10-02 16:30:14 -0700152 public long id() {
153 return id;
154 }
155
Madan Jampani49115e92015-03-14 10:43:33 -0700156 public String type() {
Madan Jampaniab6d3112014-10-02 16:30:14 -0700157 return type;
158 }
159
160 public Endpoint sender() {
161 return sender;
162 }
163
Madan Jampani53e44e62014-10-07 12:39:51 -0700164 public byte[] payload() {
Madan Jampaniab6d3112014-10-02 16:30:14 -0700165 return payload;
166 }
167
Madan Jampania9e70a62016-03-02 16:28:18 -0800168 public Status status() {
169 return status;
170 }
171
Yuta HIGUCHI0a0b9e42015-02-11 16:57:12 -0800172 @Override
173 public String toString() {
174 return MoreObjects.toStringHelper(this)
Madan Jampani05833872016-07-12 23:01:39 -0700175 .add("time", time)
Yuta HIGUCHI0a0b9e42015-02-11 16:57:12 -0800176 .add("id", id)
177 .add("type", type)
178 .add("sender", sender)
Madan Jampania9e70a62016-03-02 16:28:18 -0800179 .add("status", status)
Yuta HIGUCHI0a0b9e42015-02-11 16:57:12 -0800180 .add("payload", ByteArraySizeHashPrinter.of(payload))
181 .toString();
182 }
Yuta HIGUCHI92626c02014-10-06 15:46:18 -0700183}