io.kestra.plugin.ansible.cli.AnsibleCLI Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of plugin-ansible Show documentation
Show all versions of plugin-ansible Show documentation
Plugin to orchestrate Ansible playbooks with kestra
package io.kestra.plugin.ansible.cli;
import io.kestra.core.models.annotations.Example;
import io.kestra.core.models.annotations.Plugin;
import io.kestra.core.models.annotations.PluginProperty;
import io.kestra.core.models.tasks.*;
import io.kestra.core.models.tasks.runners.ScriptService;
import io.kestra.core.models.tasks.runners.TaskRunner;
import io.kestra.core.runners.RunContext;
import io.kestra.plugin.scripts.exec.scripts.models.DockerOptions;
import io.kestra.plugin.scripts.exec.scripts.models.RunnerType;
import io.kestra.plugin.scripts.exec.scripts.models.ScriptOutput;
import io.kestra.plugin.scripts.exec.scripts.runners.CommandsWrapper;
import io.kestra.plugin.scripts.runner.docker.Docker;
import io.swagger.v3.oas.annotations.media.Schema;
import jakarta.validation.Valid;
import lombok.*;
import lombok.experimental.SuperBuilder;
import jakarta.validation.constraints.NotEmpty;
import jakarta.validation.constraints.NotNull;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import static io.kestra.core.utils.Rethrow.throwFunction;
@SuperBuilder
@ToString
@EqualsAndHashCode
@Getter
@NoArgsConstructor
@Schema(
title = "Execute Ansible command."
)
@Plugin(
examples = {
@Example(
title = "Execute a list of Ansible CLI commands to orchestrate an Ansible playbook stored in the Editor using [Namespace Files](https://kestra.io/docs/developer-guide/namespace-files).",
full = true,
code = """
id: ansible
namespace: company.team
tasks:
- id: ansible_task
type: io.kestra.plugin.ansible.cli.AnsibleCLI
inputFiles:
inventory.ini: "{{ read('inventory.ini') }}"
myplaybook.yml: "{{ read('myplaybook.yml') }}"
docker:
image: cytopia/ansible:latest-tools
commands:
- ansible-playbook -i inventory.ini myplaybook.yml"""
),
@Example(
title = "Execute a list of Ansible CLI commands to orchestrate an Ansible playbook defined inline in the flow definition.",
full = true,
code = """
id: ansible
namespace: company.team
tasks:
- id: ansible_task
type: io.kestra.plugin.ansible.cli.AnsibleCLI
inputFiles:
inventory.ini: |
localhost ansible_connection=local
myplaybook.yml: |
---
- hosts: localhost
tasks:
- name: Print Hello World
debug:
msg: "Hello, World!"
docker:
image: cytopia/ansible:latest-tools
commands:
- ansible-playbook -i inventory.ini myplaybook.yml"""
)
}
)
public class AnsibleCLI extends Task implements RunnableTask, NamespaceFilesInterface, InputFilesInterface, OutputFilesInterface {
private static final String DEFAULT_IMAGE = "cytopia/ansible:latest-tools";
@Schema(
title = "The commands to run before the main list of commands."
)
@PluginProperty(dynamic = true)
protected List beforeCommands;
@Schema(
title = "The commands to run."
)
@NotNull
@NotEmpty
@PluginProperty(dynamic = true)
protected List commands;
@Schema(
title = "Additional environment variables for the current process."
)
@PluginProperty(
additionalProperties = String.class,
dynamic = true
)
protected Map env;
@Schema(
title = "Deprecated, use 'taskRunner' instead"
)
@PluginProperty
@Deprecated
private DockerOptions docker;
@Schema(
title = "The task runner to use.",
description = "Task runners are provided by plugins, each have their own properties."
)
@PluginProperty
@Builder.Default
@Valid
protected TaskRunner taskRunner = Docker.instance();
@Schema(title = "The task runner container image, only used if the task runner is container-based.")
@PluginProperty(dynamic = true)
@Builder.Default
protected String containerImage = DEFAULT_IMAGE;
private NamespaceFiles namespaceFiles;
private Object inputFiles;
private List outputFiles;
@Override
public ScriptOutput run(RunContext runContext) throws Exception {
CommandsWrapper commandsWrapper = new CommandsWrapper(runContext)
.withWarningOnStdErr(false)
.withDockerOptions(injectDefaults(docker))
.withTaskRunner(this.taskRunner)
.withContainerImage(this.containerImage)
.withCommands(
ScriptService.scriptCommands(
List.of("/bin/bash", "-c"),
Optional.ofNullable(this.beforeCommands).map(throwFunction(runContext::render)).orElse(null),
runContext.render(this.commands)
)
)
.withEnv(Optional.ofNullable(this.env).orElse(new HashMap<>()))
.withNamespaceFiles(namespaceFiles)
.withInputFiles(inputFiles)
.withOutputFiles(outputFiles);
return commandsWrapper.run();
}
private DockerOptions injectDefaults(DockerOptions original) {
if (original == null) {
return null;
}
var builder = original.toBuilder();
if (original.getImage() == null) {
builder.image(DEFAULT_IMAGE);
}
if (original.getEntryPoint() == null || original.getEntryPoint().isEmpty()) {
builder.entryPoint(List.of(""));
}
return builder.build();
}
}