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

org.apache.cxf.aegis.type.encoded.SoapRef Maven / Gradle / Ivy

There is a newer version: 2.7.18
Show 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.cxf.aegis.type.encoded;

/**
 * SoapRef represents an encoded SOAP 1.1 href or SOAP 1.2 ref object. This data class is updated when the ref
 * is resolved which can be immedately when the ref is resolved, or later when an instance with the referenced
 * id is unmarshalled.
 * 

* When the reference is resolved, an optional Action will be invoked which is commonly used to update a * property on the source object of the reference. */ public class SoapRef { private Object instance; private Action action; /** * Gets the referenced object instance or null if the reference has not been resolved yet; * * @return the referenced object instance or null */ public Object get() { return instance; } /** * Sets the referenced object instance. If an action is registered the onSet method is invoked. * * @param object the reference instance; not null */ public void set(Object object) { if (object == null) { throw new NullPointerException("object is null"); } this.instance = object; if (action != null) { action.onSet(this); } } /** * Registers an action to invoke when the instance is set. If the instance, has already been set, the * onSet method will immedately be invoked. * * @return the action to invoke when this reference is resolved; not null */ public void setAction(Action action) { if (action == null) { throw new NullPointerException("action is null"); } this.action = action; if (instance != null) { action.onSet(this); } } public interface Action { void onSet(SoapRef ref); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy