io.vertx.ext.bridge.BridgeOptions Maven / Gradle / Ivy
/*
* Copyright (c) 2011-2015 The original author or authors
* ------------------------------------------------------
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* and Apache License v2.0 which accompanies this distribution.
*
* The Eclipse Public License is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* The Apache License v2.0 is available at
* http://www.opensource.org/licenses/apache2.0.php
*
* You may elect to redistribute this code under either of these licenses.
*/
package io.vertx.ext.bridge;
import io.vertx.codegen.annotations.DataObject;
import io.vertx.core.json.JsonObject;
import java.util.ArrayList;
import java.util.List;
/**
* Specify the event bus bridge options.
*
* @author Clement Escoffier
*/
@DataObject(generateConverter = true)
public class BridgeOptions {
private List inboundPermitted = new ArrayList<>();
private List outboundPermitted = new ArrayList<>();
/**
* Creates a new instance of {@link BridgeOptions}, without any inbound and outbound permitted.
*/
public BridgeOptions() {
}
/**
* Creates a new instance of {@link BridgeOptions} by copying the content of another {@link BridgeOptions}
*
* @param that the {@link BridgeOptions} to copy.
*/
public BridgeOptions(BridgeOptions that) {
this.inboundPermitted = that.inboundPermitted;
this.outboundPermitted = that.outboundPermitted;
}
/**
* Creates a new instance of {@link BridgeOptions} from its JSON representation.
* This method uses the generated converter.
*
* @param json the serialized {@link BridgeOptions}
* @see BridgeOptionsConverter
*/
public BridgeOptions(JsonObject json) {
BridgeOptionsConverter.fromJson(json, this);
}
/**
* Serializes the current {@link BridgeOptions} to JSON. This method uses the generated converter.
*
* @return the serialized object
*/
public JsonObject toJson() {
JsonObject json = new JsonObject();
BridgeOptionsConverter.toJson(this, json);
return json;
}
/**
* Adds an inbound permitted option to the current {@link BridgeOptions}.
*
* @param permitted the inbound permitted
* @return the current {@link BridgeOptions}.
*/
public BridgeOptions addInboundPermitted(PermittedOptions permitted) {
inboundPermitted.add(permitted);
return this;
}
/**
* @return the list of inbound permitted options. Empty if none.
*/
public List getInboundPermitteds() {
return inboundPermitted;
}
/**
* Sets the list of inbound permitted options.
*
* @param inboundPermitted the list to use, must not be {@link null}. This method use the direct list reference
* (and doesn't create a copy).
* @return the current {@link BridgeOptions}.
*/
public BridgeOptions setInboundPermitteds(List inboundPermitted) {
this.inboundPermitted = inboundPermitted;
return this;
}
/**
* Adds an outbound permitted option to the current {@link BridgeOptions}.
*
* @param permitted the outbound permitted
* @return the current {@link BridgeOptions}.
*/
public BridgeOptions addOutboundPermitted(PermittedOptions permitted) {
outboundPermitted.add(permitted);
return this;
}
/**
* @return the list of outbound permitted options. Empty if none.
*/
public List getOutboundPermitteds() {
return outboundPermitted;
}
/**
* Sets the list of outbound permitted options.
*
* @param outboundPermitted the list to use, must not be {@link null}. This method use the direct list reference
* (and doesn't create a copy).
* @return the current {@link BridgeOptions}.
*/
public BridgeOptions setOutboundPermitteds(List outboundPermitted) {
this.outboundPermitted = outboundPermitted;
return this;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy