Skip to content

Commit 35f6c08

Browse files
committed
Reduced duplicate code
1 parent 6b2431c commit 35f6c08

24 files changed

+101
-161
lines changed

api/src/main/java/io/kafbat/ui/serdes/ClusterSerdes.java

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -64,12 +64,12 @@ public Stream<SerdeInstance> all() {
6464

6565
public SerdeInstance suggestSerdeForSerialize(String topic, Serde.Target type) {
6666
return findSerdeByPatternsOrDefault(topic, type, s -> s.canSerialize(topic, type))
67-
.orElse(serdes.get(StringSerde.name()));
67+
.orElse(serdes.get(StringSerde.NAME));
6868
}
6969

7070
public SerdeInstance suggestSerdeForDeserialize(String topic, Serde.Target type) {
7171
return findSerdeByPatternsOrDefault(topic, type, s -> s.canDeserialize(topic, type))
72-
.orElse(serdes.get(StringSerde.name()));
72+
.orElse(serdes.get(StringSerde.NAME));
7373
}
7474

7575
@Override

api/src/main/java/io/kafbat/ui/serdes/SerdesInitializer.java

Lines changed: 29 additions & 29 deletions
Original file line numberDiff line numberDiff line change
@@ -42,23 +42,23 @@ public class SerdesInitializer {
4242
public SerdesInitializer() {
4343
this(
4444
ImmutableMap.<String, Class<? extends BuiltInSerde>>builder()
45-
.put(StringSerde.name(), StringSerde.class)
46-
.put(SchemaRegistrySerde.name(), SchemaRegistrySerde.class)
47-
.put(ProtobufFileSerde.name(), ProtobufFileSerde.class)
48-
.put(Int32Serde.name(), Int32Serde.class)
49-
.put(Int64Serde.name(), Int64Serde.class)
50-
.put(UInt32Serde.name(), UInt32Serde.class)
51-
.put(UInt64Serde.name(), UInt64Serde.class)
52-
.put(AvroEmbeddedSerde.name(), AvroEmbeddedSerde.class)
53-
.put(Base64Serde.name(), Base64Serde.class)
54-
.put(HexSerde.name(), HexSerde.class)
55-
.put(UuidBinarySerde.name(), UuidBinarySerde.class)
56-
.put(ProtobufRawSerde.name(), ProtobufRawSerde.class)
45+
.put(StringSerde.NAME, StringSerde.class)
46+
.put(SchemaRegistrySerde.NAME, SchemaRegistrySerde.class)
47+
.put(ProtobufFileSerde.NAME, ProtobufFileSerde.class)
48+
.put(Int32Serde.NAME, Int32Serde.class)
49+
.put(Int64Serde.NAME, Int64Serde.class)
50+
.put(UInt32Serde.NAME, UInt32Serde.class)
51+
.put(UInt64Serde.NAME, UInt64Serde.class)
52+
.put(AvroEmbeddedSerde.NAME, AvroEmbeddedSerde.class)
53+
.put(Base64Serde.NAME, Base64Serde.class)
54+
.put(HexSerde.NAME, HexSerde.class)
55+
.put(UuidBinarySerde.NAME, UuidBinarySerde.class)
56+
.put(ProtobufRawSerde.NAME, ProtobufRawSerde.class)
5757

5858
// mm2 serdes
59-
.put(HeartbeatSerde.name(), HeartbeatSerde.class)
60-
.put(OffsetSyncSerde.name(), OffsetSyncSerde.class)
61-
.put(CheckpointSerde.name(), CheckpointSerde.class)
59+
.put(HeartbeatSerde.NAME, HeartbeatSerde.class)
60+
.put(OffsetSyncSerde.NAME, OffsetSyncSerde.class)
61+
.put(CheckpointSerde.NAME, CheckpointSerde.class)
6262
.build(),
6363
new CustomSerdeLoader()
6464
);
@@ -139,8 +139,8 @@ public ClusterSerdes init(Environment env,
139139
.orElse(null),
140140
Optional.ofNullable(clusterProperties.getDefaultValueSerde())
141141
.map(name -> Preconditions.checkNotNull(registeredSerdes.get(name), "Default value serde not found"))
142-
.or(() -> Optional.ofNullable(registeredSerdes.get(SchemaRegistrySerde.name())))
143-
.or(() -> Optional.ofNullable(registeredSerdes.get(ProtobufFileSerde.name())))
142+
.or(() -> Optional.ofNullable(registeredSerdes.get(SchemaRegistrySerde.NAME)))
143+
.or(() -> Optional.ofNullable(registeredSerdes.get(ProtobufFileSerde.NAME)))
144144
.orElse(null),
145145
createFallbackSerde()
146146
);
@@ -150,16 +150,16 @@ public ClusterSerdes init(Environment env,
150150
* Registers serdse that should only be used for specific (hard-coded) topics, like ConsumerOffsetsSerde.
151151
*/
152152
private void registerTopicRelatedSerde(Map<String, SerdeInstance> serdes) {
153-
serdes.putAll(consumerOffsetsSerde(serdes));
154-
serdes.putAll(mirrorMakerSerdes(serdes));
153+
serdes.putAll(consumerOffsetsSerde());
154+
serdes.putAll(mirrorMakerSerdes());
155155
}
156156

157-
private Map<String, SerdeInstance> consumerOffsetsSerde(Map<String, SerdeInstance> serdes) {
157+
private Map<String, SerdeInstance> consumerOffsetsSerde() {
158158
var pattern = Pattern.compile(ConsumerOffsetsSerde.TOPIC);
159159
return Map.of(
160-
ConsumerOffsetsSerde.name(),
160+
ConsumerOffsetsSerde.NAME,
161161
new SerdeInstance(
162-
ConsumerOffsetsSerde.name(),
162+
ConsumerOffsetsSerde.NAME,
163163
new ConsumerOffsetsSerde(),
164164
pattern,
165165
pattern,
@@ -168,14 +168,14 @@ private Map<String, SerdeInstance> consumerOffsetsSerde(Map<String, SerdeInstanc
168168
);
169169
}
170170

171-
private Map<String, SerdeInstance> mirrorMakerSerdes(Map<String, SerdeInstance> serdes) {
171+
private Map<String, SerdeInstance> mirrorMakerSerdes() {
172172
return Map.of(
173-
HeartbeatSerde.name(),
174-
mirrorSerde(HeartbeatSerde.name(), HeartbeatSerde.TOPIC_NAME_PATTERN, new HeartbeatSerde()),
175-
OffsetSyncSerde.name(),
176-
mirrorSerde(HeartbeatSerde.name(), OffsetSyncSerde.TOPIC_NAME_PATTERN, new OffsetSyncSerde()),
177-
CheckpointSerde.name(),
178-
mirrorSerde(HeartbeatSerde.name(), CheckpointSerde.TOPIC_NAME_PATTERN, new CheckpointSerde())
173+
HeartbeatSerde.NAME,
174+
mirrorSerde(HeartbeatSerde.NAME, HeartbeatSerde.TOPIC_NAME_PATTERN, new HeartbeatSerde()),
175+
OffsetSyncSerde.NAME,
176+
mirrorSerde(HeartbeatSerde.NAME, OffsetSyncSerde.TOPIC_NAME_PATTERN, new OffsetSyncSerde()),
177+
CheckpointSerde.NAME,
178+
mirrorSerde(HeartbeatSerde.NAME, CheckpointSerde.TOPIC_NAME_PATTERN, new CheckpointSerde())
179179
);
180180
}
181181

api/src/main/java/io/kafbat/ui/serdes/builtin/AvroEmbeddedSerde.java

Lines changed: 1 addition & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -13,10 +13,7 @@
1313
import org.apache.avro.generic.GenericDatumReader;
1414

1515
public class AvroEmbeddedSerde implements BuiltInSerde {
16-
17-
public static String name() {
18-
return "Avro (Embedded)";
19-
}
16+
public static final String NAME = "Avro (Embedded)";
2017

2118
@Override
2219
public boolean canDeserialize(String topic, Target type) {

api/src/main/java/io/kafbat/ui/serdes/builtin/Base64Serde.java

Lines changed: 1 addition & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -1,18 +1,13 @@
11
package io.kafbat.ui.serdes.builtin;
22

33
import io.kafbat.ui.serde.api.DeserializeResult;
4-
import io.kafbat.ui.serde.api.SchemaDescription;
54
import io.kafbat.ui.serde.api.Serde;
65
import io.kafbat.ui.serdes.BuiltInSerde;
76
import java.util.Base64;
87
import java.util.Map;
9-
import java.util.Optional;
108

119
public class Base64Serde implements BuiltInSerde {
12-
13-
public static String name() {
14-
return "Base64";
15-
}
10+
public static final String NAME = "Base64";
1611

1712
@Override
1813
public boolean canDeserialize(String topic, Serde.Target type) {

api/src/main/java/io/kafbat/ui/serdes/builtin/ConsumerOffsetsSerde.java

Lines changed: 1 addition & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,7 @@
1313
// Deserialization logic and message's schemas can be found in
1414
// kafka.coordinator.group.GroupMetadataManager (readMessageKey, readOffsetMessageValue, readGroupMessageValue)
1515
public class ConsumerOffsetsSerde extends StructSerde implements BuiltInSerde {
16+
public static final String NAME = "__consumer_offsets";
1617

1718
private static final String ASSIGNMENT = "assignment";
1819
private static final String CLIENT_HOST = "client_host";
@@ -33,10 +34,6 @@ public class ConsumerOffsetsSerde extends StructSerde implements BuiltInSerde {
3334

3435
public static final String TOPIC = "__consumer_offsets";
3536

36-
public static String name() {
37-
return "__consumer_offsets";
38-
}
39-
4037
@Override
4138
public boolean canDeserialize(String topic, Target type) {
4239
return topic.equals(TOPIC);

api/src/main/java/io/kafbat/ui/serdes/builtin/HexSerde.java

Lines changed: 1 addition & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -2,20 +2,15 @@
22

33
import io.kafbat.ui.serde.api.DeserializeResult;
44
import io.kafbat.ui.serde.api.PropertyResolver;
5-
import io.kafbat.ui.serde.api.SchemaDescription;
65
import io.kafbat.ui.serdes.BuiltInSerde;
76
import java.util.HexFormat;
87
import java.util.Map;
9-
import java.util.Optional;
108

119
public class HexSerde implements BuiltInSerde {
10+
public static final String NAME = "Hex";
1211

1312
private HexFormat deserializeHexFormat;
1413

15-
public static String name() {
16-
return "Hex";
17-
}
18-
1914
@Override
2015
public void autoConfigure(PropertyResolver kafkaClusterProperties, PropertyResolver globalProperties) {
2116
configure(" ", true);

api/src/main/java/io/kafbat/ui/serdes/builtin/Int32Serde.java

Lines changed: 1 addition & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -8,10 +8,7 @@
88
import java.util.Optional;
99

1010
public class Int32Serde implements BuiltInSerde {
11-
12-
public static String name() {
13-
return "Int32";
14-
}
11+
public static final String NAME = "Int32";
1512

1613
@Override
1714
public Optional<SchemaDescription> getSchema(String topic, Target type) {

api/src/main/java/io/kafbat/ui/serdes/builtin/Int64Serde.java

Lines changed: 1 addition & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -9,10 +9,7 @@
99
import java.util.Optional;
1010

1111
public class Int64Serde implements BuiltInSerde {
12-
13-
public static String name() {
14-
return "Int64";
15-
}
12+
public static final String NAME = "Int64";
1613

1714
@Override
1815
public Optional<SchemaDescription> getSchema(String topic, Serde.Target type) {

api/src/main/java/io/kafbat/ui/serdes/builtin/ProtobufFileSerde.java

Lines changed: 2 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -69,10 +69,7 @@
6969

7070
@Slf4j
7171
public class ProtobufFileSerde implements BuiltInSerde {
72-
73-
public static String name() {
74-
return "ProtobufFile";
75-
}
72+
public static final String NAME = "ProtobufFile";
7673

7774
private static final ProtobufSchemaConverter SCHEMA_CONVERTER = new ProtobufSchemaConverter();
7875

@@ -112,7 +109,7 @@ void configure(Configuration configuration) {
112109
&& configuration.defaultKeyMessageDescriptor() == null
113110
&& configuration.messageDescriptorMap().isEmpty()
114111
&& configuration.keyMessageDescriptorMap().isEmpty()) {
115-
throw new ValidationException("Neither default, nor per-topic descriptors defined for " + name() + " serde");
112+
throw new ValidationException("Neither default, nor per-topic descriptors defined for " + NAME + " serde");
116113
}
117114
this.defaultMessageDescriptor = configuration.defaultMessageDescriptor();
118115
this.defaultKeyMessageDescriptor = configuration.defaultKeyMessageDescriptor();

api/src/main/java/io/kafbat/ui/serdes/builtin/ProtobufRawSerde.java

Lines changed: 2 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -12,17 +12,14 @@
1212
import lombok.SneakyThrows;
1313

1414
public class ProtobufRawSerde implements BuiltInSerde {
15-
16-
public static String name() {
17-
return "ProtobufDecodeRaw";
18-
}
19-
15+
public static final String NAME = "ProtobufDecodeRaw";
2016

2117
@Override
2218
public boolean canDeserialize(String topic, Serde.Target type) {
2319
return true;
2420
}
2521

22+
2623
@Override
2724
public Serde.Deserializer deserializer(String topic, Serde.Target type) {
2825
return new Serde.Deserializer() {

0 commit comments

Comments
 (0)