All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.dockerjava.netty.exec.LogContainerCmdExec Maven / Gradle / Ivy

package com.github.dockerjava.netty.exec;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.github.dockerjava.api.async.ResultCallback;
import com.github.dockerjava.api.command.LogContainerCmd;
import com.github.dockerjava.api.model.Frame;
import com.github.dockerjava.core.DockerClientConfig;
import com.github.dockerjava.netty.WebTarget;

public class LogContainerCmdExec extends AbstrAsyncDockerCmdExec implements
        LogContainerCmd.Exec {

    private static final Logger LOGGER = LoggerFactory.getLogger(LogContainerCmdExec.class);

    public LogContainerCmdExec(WebTarget baseResource, DockerClientConfig dockerClientConfig) {
        super(baseResource, dockerClientConfig);
    }

    @Override
    protected Void execute0(LogContainerCmd command, ResultCallback resultCallback) {

        WebTarget webTarget = getBaseResource().path("/containers/{id}/logs").resolveTemplate("id",
                command.getContainerId());

        if (command.getTail() != null) {
            webTarget = webTarget.queryParam("tail", command.getTail());
        }

        if (command.getSince() != null) {
            webTarget = webTarget.queryParam("since", command.getSince());
        }

        webTarget = booleanQueryParam(webTarget, "timestamps", command.hasTimestampsEnabled());
        webTarget = booleanQueryParam(webTarget, "stdout", command.hasStdoutEnabled());
        webTarget = booleanQueryParam(webTarget, "stderr", command.hasStderrEnabled());
        webTarget = booleanQueryParam(webTarget, "follow", command.hasFollowStreamEnabled());

        LOGGER.trace("GET: {}", webTarget);

        webTarget.request().get(resultCallback);

        return null;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy