Generate Java code from GPB
[dcaegen2/services/sdk.git] / services / hv-ves-client / producer / api / src / main / java / org / onap / dcaegen2 / services / sdk / services / hvves / client / producer / api / options / ProducerOptions.java
1 /*
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
10  *
11  *       http://www.apache.org/licenses/LICENSE-2.0
12  *
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=====================================
19  */
20 package org.onap.dcaegen2.services.sdk.services.hvves.client.producer.api.options;
21
22 import io.vavr.collection.Set;
23 import java.net.InetSocketAddress;
24 import org.immutables.value.Value;
25 import org.jetbrains.annotations.NotNull;
26 import org.jetbrains.annotations.Nullable;
27
28 /**
29  * @author <a href="mailto:piotr.jaszczyk@nokia.com">Piotr Jaszczyk</a>
30  * @since 1.1.1
31  */
32 @Value.Immutable
33 public interface ProducerOptions {
34
35     /**
36      * A set of available collector endpoints.
37      *
38      * @return configured collector endpoints
39      * @since 1.1.1
40      */
41     @NotNull
42     Set<InetSocketAddress> collectorAddresses();
43
44     /**
45      * Security keys definition used when connecting to the collector.
46
47      *
48      * @return security keys definition or null when plain TCP sockets are to be used.
49      * @since 1.1.1
50      */
51     @Nullable
52     SecurityKeys securityKeys();
53
54     @Value.Check
55     default void validate() {
56         if (collectorAddresses().isEmpty()) {
57             throw new IllegalArgumentException("address list cannot be empty");
58         }
59     }
60 }