
javax.management.remote.generic.GenericClientNotifForwarder Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jppf-jmxremote_optional Show documentation
Show all versions of jppf-jmxremote_optional Show documentation
A modification of the OpenDMK JMX remote implementation. Licensed under the Apache Software License v2.0 as permitted by the original CDDL license
/*
* JPPF.
* Copyright (C) 2005-2016 JPPF Team.
* http://www.jppf.org
*
* Licensed 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.
*/
/*
* @(#)file ConnectionClosedException.java
* @(#)author Sun Microsystems, Inc.
* @(#)version 1.5
* @(#)lastedit 07/03/08
* @(#)build @BUILD_TAG_PLACEHOLDER@
*
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright (c) 2007 Sun Microsystems, Inc. All Rights Reserved.
*
* The contents of this file are subject to the terms of either the GNU General
* Public License Version 2 only ("GPL") or the Common Development and
* Distribution License("CDDL")(collectively, the "License"). You may not use
* this file except in compliance with the License. You can obtain a copy of the
* License at http://opendmk.dev.java.net/legal_notices/licenses.txt or in the
* LEGAL_NOTICES folder that accompanied this code. See the License for the
* specific language governing permissions and limitations under the License.
*
* When distributing the software, include this License Header Notice in each
* file and include the License file found at
* http://opendmk.dev.java.net/legal_notices/licenses.txt
* or in the LEGAL_NOTICES folder that accompanied this code.
* Sun designates this particular file as subject to the "Classpath" exception
* as provided by Sun in the GPL Version 2 section of the License file that
* accompanied this code.
*
* If applicable, add the following below the License Header, with the fields
* enclosed by brackets [] replaced by your own identifying information:
*
* "Portions Copyrighted [year] [name of copyright owner]"
*
* Contributor(s):
*
* If you wish your version of this file to be governed by only the CDDL or
* only the GPL Version 2, indicate your decision by adding
*
* "[Contributor] elects to include this software in this distribution
* under the [CDDL or GPL Version 2] license."
*
* If you don't indicate a single choice of license, a recipient has the option
* to distribute your version of this file under either the CDDL or the GPL
* Version 2, or to extend the choice of license to its licensees as provided
* above. However, if you add GPL Version 2 code and therefore, elected the
* GPL Version 2 license, then the option applies only if the new code is made
* subject to such option by the copyright holder.
*
*/
package javax.management.remote.generic;
import java.io.IOException;
import java.util.Map;
import javax.management.*;
import javax.management.remote.*;
import javax.management.remote.message.*;
import com.sun.jmx.remote.opt.internal.ClientNotifForwarder;
import com.sun.jmx.remote.opt.util.ClassLogger;
/**
* @exclude
*/
class GenericClientNotifForwarder extends ClientNotifForwarder {
/** */
private static final ClassLogger logger = new ClassLogger("javax.management.remote.generic", "GenericClientCommunicatorAdmin");
/** */
private final ClientIntermediary intermediary;
/**
* Initialize this notification forwarder witht he specified environment.
* @param intermediary .
* @param env the configuration environment to use.
*/
public GenericClientNotifForwarder(final ClientIntermediary intermediary, final Map env) {
super(env);
this.intermediary = intermediary;
}
@Override
protected NotificationResult fetchNotifs(final long clientSequenceNumber, final int maxNotifications, final long timeout) throws IOException, ClassNotFoundException {
logger.trace("GenericClientNotifForwarder-fetchNotifs", "fetching notifs...");
final NotificationRequestMessage nreq = new NotificationRequestMessage(clientSequenceNumber, maxNotifications, timeout);
final NotificationResponseMessage nresp = (NotificationResponseMessage) intermediary.connection.sendWithReturn(nreq);
Object wrapped = nresp.getWrappedNotificationResult();
Object unwrapped = intermediary.serialization.unwrap(wrapped, intermediary.myloader);
if (!(unwrapped instanceof NotificationResult)) {
// This is a protocol error, so we close the client.
final String msg = "Not a NotificationResult: " + unwrapped.getClass();
logger.warning("Forwarder.fetchNotifs", msg);
logger.warning("Forwarder.fetchNotifs", "closing connector");
intermediary.client.close();
// Cast below will generate a ClassCastException, but anyway this thread is going to die.
}
return (NotificationResult) unwrapped;
}
@Override
protected Integer addListenerForMBeanRemovedNotif() throws IOException, InstanceNotFoundException {
logger.trace("GenericClientNotifForwarder-" + "addListenerForMBeanRemovedNotif", "Add a listener to receive UNREGISTRATION_NOTIFICATION");
NotificationFilterSupport clientFilter = new NotificationFilterSupport();
clientFilter.enableType(MBeanServerNotification.UNREGISTRATION_NOTIFICATION);
final ObjectName[] names = { ClientIntermediary.delegateName };
final Object wrappedFilter = intermediary.serialization.wrap(clientFilter);
final Object[] filters = { wrappedFilter };
final Object[] params = { names, filters };
try {
int code = MBeanServerRequestMessage.ADD_NOTIFICATION_LISTENERS;
return (Integer) intermediary.mBeanServerRequest(code, params, null);
} catch (InstanceNotFoundException n) {
throw n;
} catch (Exception e) {
throw ClientIntermediary.appropriateException(e);
}
}
@Override
protected void removeListenerForMBeanRemovedNotif(final Integer id) throws IOException {
logger.trace("GenericClientNotifForwarder-" + "removeListenerForMBeanRemovedNotif", "Remove the listener used to receive " + "UNREGISTRATION_NOTIFICATION.");
try {
int code = MBeanServerRequestMessage.REMOVE_NOTIFICATION_LISTENER_FILTER_HANDBACK;
intermediary.mBeanServerRequest(code, new Object[] { intermediary.delegateName, id }, null, false);
} catch (Exception e) {
throw ClientIntermediary.appropriateException(e);
}
}
@Override
protected void lostNotifs(final String message, final long number) {
final String notifType = JMXConnectionNotification.NOTIFS_LOST;
final JMXConnectionNotification n = new JMXConnectionNotification(notifType, intermediary, intermediary.connection.getConnectionId(), intermediary.lostNotifCounter++, message, new Long(number));
intermediary.client.sendNotification(n);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy