All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.river.reggie.proxy.ConstrainableEventLease Maven / Gradle / Ivy

The newest version!
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership. The ASF 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 org.apache.river.reggie.proxy;

import org.apache.river.proxy.ConstrainableProxyUtil;
import java.io.IOException;
import java.io.InvalidObjectException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.lang.reflect.Method;
import net.jini.core.constraint.MethodConstraints;
import net.jini.core.constraint.RemoteMethodControl;
import net.jini.core.lease.Lease;
import net.jini.core.lease.LeaseMap;
import net.jini.core.lookup.ServiceID;
import net.jini.id.Uuid;
import net.jini.security.proxytrust.ProxyTrustIterator;
import net.jini.security.proxytrust.SingletonProxyTrustIterator;
import org.apache.river.api.io.AtomicSerial;
import org.apache.river.api.io.AtomicSerial.GetArg;

/**
 * EventLease subclass that supports constraints.
 *
 * @author Sun Microsystems, Inc.
 *
 */
@AtomicSerial
final class ConstrainableEventLease
    extends EventLease implements RemoteMethodControl
{
    private static final long serialVersionUID = 2L;

    /** Mappings between Lease and Registrar methods */
    private static final Method[] methodMappings = {
	Util.getMethod(Lease.class, "cancel", new Class[0]),
	Util.getMethod(Registrar.class, "cancelEventLease",
		       new Class[]{ long.class, Uuid.class }),

	Util.getMethod(Lease.class, "renew", new Class[]{ long.class }),
	Util.getMethod(Registrar.class, "renewEventLease",
		       new Class[]{ long.class, Uuid.class, long.class })
    };

    /**
     * Verifies that the client constraints for this proxy are consistent with
     * those set on the underlying server ref.
     */
    public static void verifyConsistentConstraints(
	MethodConstraints constraints, Object proxy) throws InvalidObjectException {
	ConstrainableProxyUtil.verifyConsistentConstraints(
	    constraints, proxy, methodMappings);
    }
    
    static MethodConstraints reverseTranslateConstraints(MethodConstraints constraints) {
	return ConstrainableProxyUtil.reverseTranslateConstraints(
		constraints, methodMappings);
    }



    /** Client constraints for this proxy, or null */
    private final MethodConstraints constraints;

    /**
     * The server proxy will have been downloaded first and already have 
     * constraints applied by AtomicMarshalInputStream.
     * @param arg
     * @return
     * @throws IOException 
     */
    private static MethodConstraints check(GetArg arg) throws IOException{
	MethodConstraints constraints = (MethodConstraints) arg.get("constraints", null);
	EventLease el = new EventLease(arg);
	MethodConstraints proxyCon = null;
	if (el.server instanceof RemoteMethodControl && 
	    (proxyCon = ((RemoteMethodControl)el.server).getConstraints()) != null) {
	    // Constraints set during proxy deserialization.
	    return reverseTranslateConstraints(proxyCon);
	}
	verifyConsistentConstraints(constraints, el.server);
	return constraints;
    }
    
    ConstrainableEventLease(GetArg arg) throws IOException{
	this(arg, check(arg));
    }
    
    ConstrainableEventLease(GetArg arg, MethodConstraints constraints) throws IOException{
	super(arg);
	this.constraints = constraints;
    }

    /**
     * Creates new ConstrainableEventLease with given server reference, event
     * and lease IDs, expiration time and client constraints.
     */
    ConstrainableEventLease(Registrar server,
			    ServiceID registrarID,
			    long eventID,
			    Uuid leaseID,
			    long expiration,
			    MethodConstraints constraints,
			    boolean setConstraints)
    {
	super( setConstraints ? (Registrar) ((RemoteMethodControl) server).setConstraints(
		  ConstrainableProxyUtil.translateConstraints(
		      constraints, methodMappings)) : server,
	      registrarID,
	      eventID,
	      leaseID,
	      expiration);
	this.constraints = constraints;
    }

    /**
     * Creates a constraint-aware lease map.
     */
    public LeaseMap createLeaseMap(long duration) {
	return new ConstrainableRegistrarLeaseMap(this, duration);
    }

    /**
     * Two leases can be batched if they are both RegistrarLeases, share the
     * same server, and have compatible constraints.
     */
    public boolean canBatch(Lease lease) {
	if (!(super.canBatch(lease) && lease instanceof RemoteMethodControl)) {
	    return false;
	}
	return ConstrainableProxyUtil.equivalentConstraints(
	    ((RemoteMethodControl) lease).getConstraints(),
	    ConstrainableProxyUtil.translateConstraints(
		constraints, ConstrainableRegistrarLeaseMap.methodMappings),
	    ConstrainableRegistrarLeaseMap.methodMappings);
    }

    // javadoc inherited from RemoteMethodControl.setConstraints
    public RemoteMethodControl setConstraints(MethodConstraints constraints) {
	return new ConstrainableEventLease(
	    server, registrarID, eventID, leaseID, getExpiration(), constraints, true);
    }

    // javadoc inherited from RemoteMethodControl.getConstraints
    public MethodConstraints getConstraints() {
	return constraints;
    }

    /**
     * Returns iterator used by ProxyTrustVerifier to retrieve a trust verifier
     * for this object.
     */
    private ProxyTrustIterator getProxyTrustIterator() {
	return new SingletonProxyTrustIterator(server);
    }

    private void writeObject(ObjectOutputStream out) throws IOException {
	out.defaultWriteObject();
    }

    /**
     * Verifies that the client constraints for this proxy are consistent with
     * those set on the underlying server ref.
     */
    private void readObject(ObjectInputStream in)
	throws IOException, ClassNotFoundException
    {
	in.defaultReadObject();
	verifyConsistentConstraints(constraints, server);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy