io.vertx.reactivex.pgclient.pubsub.PgSubscriber Maven / Gradle / Ivy
/*
* Copyright 2014 Red Hat, Inc.
*
* Red Hat 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 io.vertx.reactivex.pgclient.pubsub;
import io.vertx.reactivex.RxHelper;
import io.vertx.reactivex.ObservableHelper;
import io.vertx.reactivex.FlowableHelper;
import io.vertx.reactivex.impl.AsyncResultMaybe;
import io.vertx.reactivex.impl.AsyncResultSingle;
import io.vertx.reactivex.impl.AsyncResultCompletable;
import io.vertx.reactivex.WriteStreamObserver;
import io.vertx.reactivex.WriteStreamSubscriber;
import java.util.Map;
import java.util.Set;
import java.util.List;
import java.util.Iterator;
import java.util.function.Function;
import java.util.function.Supplier;
import java.util.stream.Collectors;
import io.vertx.core.Handler;
import io.vertx.core.AsyncResult;
import io.vertx.core.json.JsonObject;
import io.vertx.core.json.JsonArray;
import io.vertx.lang.rx.RxGen;
import io.vertx.lang.rx.TypeArg;
import io.vertx.lang.rx.MappingIterator;
/**
* A class for managing subscriptions using LISTEN/UNLISTEN
to Postgres channels.
*
* The subscriber manages a single connection to Postgres.
*
*
* NOTE: This class has been automatically generated from the {@link io.vertx.pgclient.pubsub.PgSubscriber original} non RX-ified interface using Vert.x codegen.
*/
@RxGen(io.vertx.pgclient.pubsub.PgSubscriber.class)
public class PgSubscriber {
@Override
public String toString() {
return delegate.toString();
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
PgSubscriber that = (PgSubscriber) o;
return delegate.equals(that.delegate);
}
@Override
public int hashCode() {
return delegate.hashCode();
}
public static final TypeArg __TYPE_ARG = new TypeArg<>( obj -> new PgSubscriber((io.vertx.pgclient.pubsub.PgSubscriber) obj),
PgSubscriber::getDelegate
);
private final io.vertx.pgclient.pubsub.PgSubscriber delegate;
public PgSubscriber(io.vertx.pgclient.pubsub.PgSubscriber delegate) {
this.delegate = delegate;
}
public PgSubscriber(Object delegate) {
this.delegate = (io.vertx.pgclient.pubsub.PgSubscriber)delegate;
}
public io.vertx.pgclient.pubsub.PgSubscriber getDelegate() {
return delegate;
}
/**
* Create a subscriber.
* @param vertx the vertx instance
* @param options the connect options
* @return the subscriber
*/
public static io.vertx.reactivex.pgclient.pubsub.PgSubscriber subscriber(io.vertx.reactivex.core.Vertx vertx, io.vertx.pgclient.PgConnectOptions options) {
io.vertx.reactivex.pgclient.pubsub.PgSubscriber ret = io.vertx.reactivex.pgclient.pubsub.PgSubscriber.newInstance((io.vertx.pgclient.pubsub.PgSubscriber)io.vertx.pgclient.pubsub.PgSubscriber.subscriber(vertx.getDelegate(), options));
return ret;
}
/**
* Return a channel for the given name
.
* @param name the channel name This will be the name of the channel exactly as held by Postgres for sending notifications. Internally this name will be truncated to the Postgres identifier maxiumum length of (NAMEDATALEN = 64) - 1 == 63
characters, and prepared as a quoted identifier without unicode escape sequence support for use in LISTEN/UNLISTEN
commands. Examples of channel names and corresponding NOTIFY
commands: - when
name == "the_channel"
: NOTIFY the_channel, 'msg'
, NOTIFY The_Channel, 'msg'
, or NOTIFY "the_channel", 'msg'
succeed in delivering a message to the created channel - when
name == "The_Channel"
: NOTIFY "The_Channel", 'msg'
, succeeds in delivering a message to the created channel
* @return the channel
*/
public io.vertx.reactivex.pgclient.pubsub.PgChannel channel(java.lang.String name) {
io.vertx.reactivex.pgclient.pubsub.PgChannel ret = io.vertx.reactivex.pgclient.pubsub.PgChannel.newInstance((io.vertx.pgclient.pubsub.PgChannel)delegate.channel(name));
return ret;
}
/**
* Connect the subscriber to Postgres.
* @return a future notified of the connection success or failure
*/
public io.vertx.core.Future connect() {
io.vertx.core.Future ret = delegate.connect().map(val -> val);
return ret;
}
/**
* Connect the subscriber to Postgres.
* @return a future notified of the connection success or failure
*/
public io.reactivex.Completable rxConnect() {
return AsyncResultCompletable.toCompletable($handler -> {
this.connect().onComplete($handler);
});
}
/**
* Set the reconnect policy that is executed when the subscriber is disconnected.
*
* When the subscriber is disconnected, the policy
function is called with the actual
* number of retries and returns an amountOfTime
value:
*
* - when
amountOfTime < 0
: the subscriber is closed and there is no retry
* - when
amountOfTime == 0
: the subscriber retries to connect immediately
* - when
amountOfTime > 0
: the subscriber retries after amountOfTime
milliseconds
*
*
* The default policy does not perform any retries.
* @param policy the policy to set
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.pgclient.pubsub.PgSubscriber reconnectPolicy(java.util.function.Function policy) {
delegate.reconnectPolicy(policy);
return this;
}
/**
* Set an handler called when the subscriber is closed.
* @param handler the handler
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.pgclient.pubsub.PgSubscriber closeHandler(io.vertx.core.Handler handler) {
delegate.closeHandler(handler);
return this;
}
/**
* @return the actual connection to Postgres, it might be null
*/
public io.vertx.reactivex.pgclient.PgConnection actualConnection() {
io.vertx.reactivex.pgclient.PgConnection ret = io.vertx.reactivex.pgclient.PgConnection.newInstance((io.vertx.pgclient.PgConnection)delegate.actualConnection());
return ret;
}
/**
* @return whether the subscriber is closed
*/
public boolean closed() {
boolean ret = delegate.closed();
return ret;
}
/**
* Close the subscriber, the retry policy will not be invoked.
* @return
*/
public io.vertx.core.Future close() {
io.vertx.core.Future ret = delegate.close().map(val -> val);
return ret;
}
/**
* Close the subscriber, the retry policy will not be invoked.
* @return
*/
public io.reactivex.Completable rxClose() {
return AsyncResultCompletable.toCompletable($handler -> {
this.close().onComplete($handler);
});
}
public static PgSubscriber newInstance(io.vertx.pgclient.pubsub.PgSubscriber arg) {
return arg != null ? new PgSubscriber(arg) : null;
}
}