blob: 0d96c09787948af20c609a2e2f46d288fa07ee28 [file] [log] [blame]
Thomas Vachuska24c849c2014-10-27 09:53:05 -07001/*
Aaron Kruglikov1b727382016-02-09 16:17:47 -08002 * Copyright 2016 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;
Aaron Kruglikov1b727382016-02-09 16:17:47 -080019import org.onlab.util.ByteArraySizeHashPrinter;
20import org.onosproject.store.cluster.messaging.Endpoint;
Yuta HIGUCHI0a0b9e42015-02-11 16:57:12 -080021
Madan Jampaniab6d3112014-10-02 16:30:14 -070022/**
23 * Internal message representation with additional attributes
24 * for supporting, synchronous request/reply behavior.
25 */
Madan Jampanic26eede2015-04-16 11:42:16 -070026public final class InternalMessage {
Madan Jampaniab6d3112014-10-02 16:30:14 -070027
Madan Jampania9e70a62016-03-02 16:28:18 -080028 /**
29 * Message status.
30 */
31 public enum Status {
32 /**
33 * All ok.
34 */
35 OK,
36
37 /**
38 * Response status signifying no registered handler.
39 */
40 ERROR_NO_HANDLER,
41
42 /**
43 * Response status signifying an exception handling the message.
44 */
Madan Jampanib825aeb2016-04-01 15:18:25 -070045 ERROR_HANDLER_EXCEPTION,
46
47 /**
48 * Reponse status signifying invalid message structure.
49 */
50 PROTOCOL_EXCEPTION
Madan Jampania9e70a62016-03-02 16:28:18 -080051
52 // NOTE: For backwards compatibility it important that new enum constants
53 // be appended.
54 // FIXME: We should remove this restriction in the future.
55 }
56
Madan Jampanib825aeb2016-04-01 15:18:25 -070057 private final int preamble;
Madan Jampanic26eede2015-04-16 11:42:16 -070058 private final long id;
59 private final Endpoint sender;
60 private final String type;
61 private final byte[] payload;
Madan Jampania9e70a62016-03-02 16:28:18 -080062 private final Status status;
Yuta HIGUCHIc65f5122014-10-07 10:05:59 -070063
Madan Jampanib825aeb2016-04-01 15:18:25 -070064 public InternalMessage(int preamble, long id, Endpoint sender, String type, byte[] payload) {
65 this(preamble, id, sender, type, payload, Status.OK);
Madan Jampania9e70a62016-03-02 16:28:18 -080066 }
67
Madan Jampanib825aeb2016-04-01 15:18:25 -070068 public InternalMessage(int preamble, long id, Endpoint sender, String type, byte[] payload, Status status) {
69 this.preamble = preamble;
Yuta HIGUCHI91768e32014-11-22 05:06:35 -080070 this.id = id;
71 this.sender = sender;
72 this.type = type;
73 this.payload = payload;
Madan Jampania9e70a62016-03-02 16:28:18 -080074 this.status = status;
Yuta HIGUCHI91768e32014-11-22 05:06:35 -080075 }
76
Madan Jampanib825aeb2016-04-01 15:18:25 -070077 public int preamble() {
78 return preamble;
79 }
80
Madan Jampaniab6d3112014-10-02 16:30:14 -070081 public long id() {
82 return id;
83 }
84
Madan Jampani49115e92015-03-14 10:43:33 -070085 public String type() {
Madan Jampaniab6d3112014-10-02 16:30:14 -070086 return type;
87 }
88
89 public Endpoint sender() {
90 return sender;
91 }
92
Madan Jampani53e44e62014-10-07 12:39:51 -070093 public byte[] payload() {
Madan Jampaniab6d3112014-10-02 16:30:14 -070094 return payload;
95 }
96
Madan Jampania9e70a62016-03-02 16:28:18 -080097 public Status status() {
98 return status;
99 }
100
Yuta HIGUCHI0a0b9e42015-02-11 16:57:12 -0800101 @Override
102 public String toString() {
103 return MoreObjects.toStringHelper(this)
104 .add("id", id)
105 .add("type", type)
106 .add("sender", sender)
Madan Jampania9e70a62016-03-02 16:28:18 -0800107 .add("status", status)
Yuta HIGUCHI0a0b9e42015-02-11 16:57:12 -0800108 .add("payload", ByteArraySizeHashPrinter.of(payload))
109 .toString();
110 }
Yuta HIGUCHI92626c02014-10-06 15:46:18 -0700111}