io.streamthoughts.kafka.specs.command.BaseCommand Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jikkou Show documentation
Show all versions of jikkou Show documentation
A command-line tool to help you automate the management of the configurations that live on your Apache Kafka clusters.
/*
* Copyright 2021 StreamThoughts.
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF 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.streamthoughts.kafka.specs.command;
import io.streamthoughts.kafka.specs.config.JikkouConfig;
import io.streamthoughts.kafka.specs.config.JikkouParams;
import io.streamthoughts.kafka.specs.resources.Named;
import org.apache.kafka.clients.admin.AdminClient;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import picocli.CommandLine.Command;
import picocli.CommandLine.Mixin;
import picocli.CommandLine.ParentCommand;
import java.util.Optional;
import java.util.concurrent.Callable;
import java.util.function.Predicate;
import static java.util.Arrays.stream;
@Command(synopsisHeading = "%nUsage:%n%n",
descriptionHeading = "%nDescription:%n%n",
parameterListHeading = "%nParameters:%n%n",
optionListHeading = "%nOptions:%n%n",
commandListHeading = "%nCommands:%n%n",
mixinStandardHelpOptions = true)
public abstract class BaseCommand implements Callable {
private static final Logger LOG = LoggerFactory.getLogger(BaseCommand.class);
@Mixin
ExecOptionsMixin execOptions;
@ParentCommand
WithAdminClientCommand command;
/**
* {@inheritDoc}
*/
@Override
public Integer call() {
return command.withAdminClient(this::call);
}
public abstract Integer call(final AdminClient client);
public final boolean isResourceCandidate(final Named resourceName) {
final boolean candidate = isResourceCandidate(resourceName.name());
if (!candidate) {
LOG.info("Excluded resource with name '{}'.", resourceName);
}
return candidate;
}
public final boolean isResourceCandidate(final String resourceName) {
final boolean candidate = includePredicate().test(resourceName) && !excludePredicate().test(resourceName);
if (!candidate) {
LOG.info("Excluded resource with name '{}'.", resourceName);
}
return candidate;
}
private Predicate includePredicate() {
return s -> Optional.ofNullable(execOptions.include)
.or(() -> JikkouParams.INCLUDE_RESOURCES.getOption(JikkouConfig.get()).toJavaOptional())
.map(patterns -> patterns.length == 0 || stream(patterns).anyMatch(m -> m.matcher(s).matches()))
.orElse(true);
}
private Predicate excludePredicate() {
return s -> Optional.ofNullable(execOptions.exclude)
.or(() -> JikkouParams.EXCLUDE_RESOURCES.getOption(JikkouConfig.get()).toJavaOptional())
.map(patterns -> patterns.length != 0 && stream(patterns).anyMatch(m -> m.matcher(s).matches()))
.orElse(false);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy