io.hekate.messaging.internal.GuardedMessageReceiver Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of hekate-core Show documentation
Show all versions of hekate-core Show documentation
Java library for cluster communications and computing.
/*
* Copyright 2020 The Hekate Project
*
* The Hekate Project licenses this file to you under the Apache License,
* version 2.0 (the "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at:
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*/
package io.hekate.messaging.internal;
import io.hekate.messaging.Message;
import io.hekate.messaging.MessageReceiver;
import io.hekate.messaging.MessagingEndpoint;
import io.hekate.util.StateGuard;
class GuardedMessageReceiver implements MessageReceiver {
private final StateGuard guard;
private final MessageReceiver receiver;
public GuardedMessageReceiver(StateGuard guard, MessageReceiver receiver) {
this.guard = guard;
this.receiver = receiver;
}
@Override
public void receive(Message msg) {
guard.lockRead();
try {
// Do not notify original receiver if node is shutting down.
if (guard.isInitialized()) {
receiver.receive(msg);
}
} finally {
guard.unlockRead();
}
}
@Override
public void onConnect(MessagingEndpoint endpoint) {
guard.lockRead();
try {
if (guard.isInitialized()) {
receiver.onConnect(endpoint);
}
} finally {
guard.unlockRead();
}
}
@Override
public void onDisconnect(MessagingEndpoint endpoint) {
guard.lockRead();
try {
if (guard.isInitialized()) {
receiver.onDisconnect(endpoint);
}
} finally {
guard.unlockRead();
}
}
}