blob: 7e79da053dc9b55acbe7d0a8675e2d03393a20b4 [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 {
34 /**
35 * All ok.
36 */
37 OK,
38
39 /**
40 * Response status signifying no registered handler.
41 */
42 ERROR_NO_HANDLER,
43
44 /**
45 * Response status signifying an exception handling the message.
46 */
Madan Jampanib825aeb2016-04-01 15:18:25 -070047 ERROR_HANDLER_EXCEPTION,
48
49 /**
50 * Reponse status signifying invalid message structure.
51 */
52 PROTOCOL_EXCEPTION
Madan Jampania9e70a62016-03-02 16:28:18 -080053
54 // NOTE: For backwards compatibility it important that new enum constants
55 // be appended.
56 // FIXME: We should remove this restriction in the future.
57 }
58
Madan Jampanib825aeb2016-04-01 15:18:25 -070059 private final int preamble;
Madan Jampani05833872016-07-12 23:01:39 -070060 private final HybridLogicalTime time;
Madan Jampanic26eede2015-04-16 11:42:16 -070061 private final long id;
62 private final Endpoint sender;
63 private final String type;
64 private final byte[] payload;
Madan Jampania9e70a62016-03-02 16:28:18 -080065 private final Status status;
Yuta HIGUCHIc65f5122014-10-07 10:05:59 -070066
Madan Jampani05833872016-07-12 23:01:39 -070067 public InternalMessage(int preamble,
68 HybridLogicalTime time,
69 long id,
70 Endpoint sender,
71 String type,
72 byte[] payload) {
73 this(preamble, time, id, sender, type, payload, Status.OK);
Madan Jampania9e70a62016-03-02 16:28:18 -080074 }
75
Madan Jampani05833872016-07-12 23:01:39 -070076 public InternalMessage(int preamble,
77 HybridLogicalTime time,
78 long id,
79 Endpoint sender,
80 String type,
81 byte[] payload,
82 Status status) {
Madan Jampanib825aeb2016-04-01 15:18:25 -070083 this.preamble = preamble;
Madan Jampani05833872016-07-12 23:01:39 -070084 this.time = time;
Yuta HIGUCHI91768e32014-11-22 05:06:35 -080085 this.id = id;
86 this.sender = sender;
87 this.type = type;
88 this.payload = payload;
Madan Jampania9e70a62016-03-02 16:28:18 -080089 this.status = status;
Yuta HIGUCHI91768e32014-11-22 05:06:35 -080090 }
91
Madan Jampani05833872016-07-12 23:01:39 -070092 public HybridLogicalTime time() {
93 return time;
94 }
95
Madan Jampanib825aeb2016-04-01 15:18:25 -070096 public int preamble() {
97 return preamble;
98 }
99
Madan Jampaniab6d3112014-10-02 16:30:14 -0700100 public long id() {
101 return id;
102 }
103
Madan Jampani49115e92015-03-14 10:43:33 -0700104 public String type() {
Madan Jampaniab6d3112014-10-02 16:30:14 -0700105 return type;
106 }
107
108 public Endpoint sender() {
109 return sender;
110 }
111
Madan Jampani53e44e62014-10-07 12:39:51 -0700112 public byte[] payload() {
Madan Jampaniab6d3112014-10-02 16:30:14 -0700113 return payload;
114 }
115
Madan Jampania9e70a62016-03-02 16:28:18 -0800116 public Status status() {
117 return status;
118 }
119
Yuta HIGUCHI0a0b9e42015-02-11 16:57:12 -0800120 @Override
121 public String toString() {
122 return MoreObjects.toStringHelper(this)
Madan Jampani05833872016-07-12 23:01:39 -0700123 .add("time", time)
Yuta HIGUCHI0a0b9e42015-02-11 16:57:12 -0800124 .add("id", id)
125 .add("type", type)
126 .add("sender", sender)
Madan Jampania9e70a62016-03-02 16:28:18 -0800127 .add("status", status)
Yuta HIGUCHI0a0b9e42015-02-11 16:57:12 -0800128 .add("payload", ByteArraySizeHashPrinter.of(payload))
129 .toString();
130 }
Yuta HIGUCHI92626c02014-10-06 15:46:18 -0700131}