blob: f9d4e0baabce0b221e377bcee713df864e012d11 [file] [log] [blame]
Thomas Vachuska24c849c2014-10-27 09:53:05 -07001/*
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -07002 * Copyright 2014 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 */
Madan Jampaniab6d3112014-10-02 16:30:14 -070016package org.onlab.netty;
17
18import java.io.IOException;
19
Yuta HIGUCHI0a0b9e42015-02-11 16:57:12 -080020import org.onlab.util.ByteArraySizeHashPrinter;
21
22import com.google.common.base.MoreObjects;
23
Madan Jampaniab6d3112014-10-02 16:30:14 -070024/**
25 * Internal message representation with additional attributes
26 * for supporting, synchronous request/reply behavior.
27 */
28public final class InternalMessage implements Message {
29
Madan Jampani2e5f87b2015-02-22 10:37:15 -080030 public static final long REPLY_MESSAGE_TYPE =
31 NettyMessagingService.hashToLong("NETTY_MESSAGING_REQUEST_REPLY");
Yuta HIGUCHIc65f5122014-10-07 10:05:59 -070032
Madan Jampaniab6d3112014-10-02 16:30:14 -070033 private long id;
34 private Endpoint sender;
Madan Jampani2e5f87b2015-02-22 10:37:15 -080035 private long type;
Madan Jampani53e44e62014-10-07 12:39:51 -070036 private byte[] payload;
Madan Jampaniab6d3112014-10-02 16:30:14 -070037 private transient NettyMessagingService messagingService;
Madan Jampaniab6d3112014-10-02 16:30:14 -070038
39 // Must be created using the Builder.
40 private InternalMessage() {}
41
Madan Jampani2e5f87b2015-02-22 10:37:15 -080042 InternalMessage(long id, Endpoint sender, long type, byte[] payload) {
Yuta HIGUCHI91768e32014-11-22 05:06:35 -080043 this.id = id;
44 this.sender = sender;
45 this.type = type;
46 this.payload = payload;
47 }
48
Madan Jampaniab6d3112014-10-02 16:30:14 -070049 public long id() {
50 return id;
51 }
52
Madan Jampani2e5f87b2015-02-22 10:37:15 -080053 public long type() {
Madan Jampaniab6d3112014-10-02 16:30:14 -070054 return type;
55 }
56
57 public Endpoint sender() {
58 return sender;
59 }
60
61 @Override
Madan Jampani53e44e62014-10-07 12:39:51 -070062 public byte[] payload() {
Madan Jampaniab6d3112014-10-02 16:30:14 -070063 return payload;
64 }
65
Madan Jampani86ed0552014-10-03 16:45:42 -070066 protected void setMessagingService(NettyMessagingService messagingService) {
67 this.messagingService = messagingService;
68 }
69
Madan Jampaniab6d3112014-10-02 16:30:14 -070070 @Override
Madan Jampani53e44e62014-10-07 12:39:51 -070071 public void respond(byte[] data) throws IOException {
Madan Jampaniab6d3112014-10-02 16:30:14 -070072 Builder builder = new Builder(messagingService);
73 InternalMessage message = builder.withId(this.id)
Madan Jampani87100932014-10-21 16:46:12 -070074 .withSender(messagingService.localEp())
Madan Jampaniab6d3112014-10-02 16:30:14 -070075 .withPayload(data)
76 .withType(REPLY_MESSAGE_TYPE)
77 .build();
78 messagingService.sendAsync(sender, message);
79 }
80
Yuta HIGUCHI0a0b9e42015-02-11 16:57:12 -080081 @Override
82 public String toString() {
83 return MoreObjects.toStringHelper(this)
84 .add("id", id)
85 .add("type", type)
86 .add("sender", sender)
87 .add("payload", ByteArraySizeHashPrinter.of(payload))
88 .toString();
89 }
Madan Jampaniab6d3112014-10-02 16:30:14 -070090
91 /**
92 * Builder for InternalMessages.
93 */
Yuta HIGUCHI24fb2992014-10-06 22:51:45 -070094 public static final class Builder {
Madan Jampaniab6d3112014-10-02 16:30:14 -070095 private InternalMessage message;
96
97 public Builder(NettyMessagingService messagingService) {
98 message = new InternalMessage();
99 message.messagingService = messagingService;
100 }
101
102 public Builder withId(long id) {
103 message.id = id;
104 return this;
105 }
106
Madan Jampani2e5f87b2015-02-22 10:37:15 -0800107 public Builder withType(long type) {
Madan Jampaniab6d3112014-10-02 16:30:14 -0700108 message.type = type;
109 return this;
110 }
111
112 public Builder withSender(Endpoint sender) {
113 message.sender = sender;
114 return this;
115 }
Madan Jampani53e44e62014-10-07 12:39:51 -0700116 public Builder withPayload(byte[] payload) {
Madan Jampaniab6d3112014-10-02 16:30:14 -0700117 message.payload = payload;
118 return this;
119 }
120
121 public InternalMessage build() {
122 return message;
123 }
124 }
Yuta HIGUCHI92626c02014-10-06 15:46:18 -0700125}