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=====================================
21 package org.onap.dcaegen2.services.sdk.rest.services.cbs.client.impl.streams.gson;
23 import java.util.Objects;
24 import org.jetbrains.annotations.NotNull;
25 import org.jetbrains.annotations.Nullable;
26 import org.onap.dcaegen2.services.sdk.rest.services.cbs.client.model.streams.AafCredentials;
27 import org.onap.dcaegen2.services.sdk.rest.services.cbs.client.model.streams.dmaap.Kafka;
28 import org.onap.dcaegen2.services.sdk.rest.services.cbs.client.model.streams.dmaap.KafkaSource;
31 * @author <a href="mailto:piotr.jaszczyk@nokia.com">Piotr Jaszczyk</a>
34 abstract class GsonKafka implements Kafka {
36 protected final KafkaInfo kafkaInfo;
37 private final AafCredentials aafCredentials;
39 GsonKafka(@NotNull KafkaInfo kafkaInfo,
40 @Nullable AafCredentials aafCredentials) {
41 this.kafkaInfo = Objects.requireNonNull(kafkaInfo, "kafkaInfo");
42 this.aafCredentials = aafCredentials;
46 public String bootstrapServers() {
47 return kafkaInfo.bootstrapServers();
51 public String topicName() {
52 return kafkaInfo.topicName();
56 public @Nullable AafCredentials aafCredentials() {
57 return aafCredentials;
61 public @Nullable String clientRole() {
62 return kafkaInfo.clientRole();
66 public @Nullable String clientId() {
67 return kafkaInfo.clientId();
71 public int maxPayloadSizeBytes() {
72 return kafkaInfo.maxPayloadSizeBytes();
76 public boolean equals(Object o) {
80 if (o == null || getClass() != o.getClass()) {
83 GsonKafka gsonKafka = (GsonKafka) o;
84 return kafkaInfo.equals(gsonKafka.kafkaInfo) &&
85 Objects.equals(aafCredentials, gsonKafka.aafCredentials);
89 public int hashCode() {
90 return Objects.hash(kafkaInfo, aafCredentials);