/*
 * Copyright (c) 2003, 2017, Oracle and/or its affiliates. All rights reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.  Oracle designates this
 * particular file as subject to the "Classpath" exception as provided
 * by Oracle in the LICENSE file that accompanied this code.
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
 */

/*
 * @COPYRIGHT_MINI_LEGAL_NOTICE_PLACEHOLDER@
 */

package sun.management.jmxremote;

import sun.misc.ObjectInputFilter;
import java.rmi.AccessException;
import java.rmi.NotBoundException;
import java.rmi.Remote;
import java.rmi.RemoteException;
import java.rmi.server.RMIClientSocketFactory;
import java.rmi.server.RMIServerSocketFactory;

import sun.rmi.registry.RegistryImpl;

A Registry that consists of a single entry that never changes.
/** A Registry that consists of a single entry that never changes. */
public class SingleEntryRegistry extends RegistryImpl { SingleEntryRegistry(int port, String name, Remote object) throws RemoteException { super(port, null, null, new ObjectInputFilter() { @Override public Status checkInput(FilterInfo info) { return SingleEntryRegistry.singleRegistryFilter(info); } }); this.name = name; this.object = object; } SingleEntryRegistry(int port, RMIClientSocketFactory csf, RMIServerSocketFactory ssf, String name, Remote object) throws RemoteException { super(port, csf, ssf, new ObjectInputFilter() { @Override public Status checkInput(FilterInfo info) { return SingleEntryRegistry.singleRegistryFilter(info); } }); this.name = name; this.object = object; } public String[] list() { return new String[] {name}; } public Remote lookup(String name) throws NotBoundException { if (name.equals(this.name)) return object; throw new NotBoundException("Not bound: \"" + name + "\" (only " + "bound name is \"" + this.name + "\")"); } public void bind(String name, Remote obj) throws AccessException { throw new AccessException("Cannot modify this registry"); } public void rebind(String name, Remote obj) throws AccessException { throw new AccessException("Cannot modify this registry"); } public void unbind(String name) throws AccessException { throw new AccessException("Cannot modify this registry"); }
ObjectInputFilter to check parameters to SingleEntryRegistry. Since it is a read-only Registry, no classes are accepted. String arguments are accepted without passing them to the serialFilter.
Params:
  • info – a reference to the serialization filter information
Returns:Status.REJECTED if parameters are out of range
/** * ObjectInputFilter to check parameters to SingleEntryRegistry. * Since it is a read-only Registry, no classes are accepted. * String arguments are accepted without passing them to the serialFilter. * * @param info a reference to the serialization filter information * @return Status.REJECTED if parameters are out of range */
private static ObjectInputFilter.Status singleRegistryFilter(ObjectInputFilter.FilterInfo info) { return (info.serialClass() != null || info.depth() > 2 || info.references() > 4 || info.arrayLength() >= 0) ? ObjectInputFilter.Status.REJECTED : ObjectInputFilter.Status.ALLOWED; } private final String name; private final Remote object; }