2 * ============LICENSE_START=======================================================
3 * DCAEGEN2-SERVICES-SDK
4 * ================================================================================
5 * Copyright (C) 2019 Nokia. All rights reserved.
6 * ================================================================================
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ============LICENSE_END=========================================================
20 package org.onap.dcaegen2.services.sdk.services.hvves.client.producer.api;
22 import org.jetbrains.annotations.NotNull;
23 import org.onap.ves.VesEventOuterClass.VesEvent;
24 import org.reactivestreams.Publisher;
27 * <p>Main High Volume VES producer interface.</p>
29 * <p>Client code should use this interface for sending events to the endpoint configured when calling
30 * {@link HvVesProducerFactory#create(ProducerOptions)}.</p>
32 * <p>Sample usage with <a href="https://projectreactor.io/">Project Reactor</a>:</p>
35 * ProducerOptions options = {@link ImmutableProducerOptions}.builder(). ... .build()
36 * HvVesProducer hvVes = {@link HvVesProducerFactory}.create(options);
38 * Flux.just(msg1, msg2, msg3)
39 * .transform(hvVes::send)
43 * @author <a href="mailto:piotr.jaszczyk@nokia.com">Piotr Jaszczyk</a>
47 public interface HvVesProducer {
49 * Send the messages to the collector.
51 * Returns a Publisher that completes when all the messages are sent. The returned Publisher fails with an error in
52 * case of any problem with sending the messages.
54 * @param messages source of the messages to be sent
55 * @return empty publisher which completes after messages are sent or error occurs
58 @NotNull Publisher<Void> send(Publisher<VesEvent> messages);