com.github.dockerjava.jaxrs.AttachContainerCmdExec Maven / Gradle / Ivy
package com.github.dockerjava.jaxrs;
import javax.ws.rs.client.WebTarget;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.github.dockerjava.api.async.ResultCallback;
import com.github.dockerjava.api.command.AttachContainerCmd;
import com.github.dockerjava.api.model.Frame;
import com.github.dockerjava.core.async.FrameStreamProcessor;
import com.github.dockerjava.jaxrs.async.AbstractCallbackNotifier;
import com.github.dockerjava.jaxrs.async.POSTCallbackNotifier;
public class AttachContainerCmdExec extends AbstrAsyncDockerCmdExec implements
AttachContainerCmd.Exec {
private static final Logger LOGGER = LoggerFactory.getLogger(AttachContainerCmdExec.class);
public AttachContainerCmdExec(WebTarget baseResource) {
super(baseResource);
}
@Override
protected AbstractCallbackNotifier callbackNotifier(AttachContainerCmd command,
ResultCallback resultCallback) {
WebTarget webTarget = getBaseResource().path("/containers/{id}/attach")
.resolveTemplate("id", command.getContainerId())
.queryParam("logs", command.hasLogsEnabled() ? "1" : "0")
// .queryParam("stdin", command.hasStdinEnabled() ? "1" : "0")
.queryParam("stdout", command.hasStdoutEnabled() ? "1" : "0")
.queryParam("stderr", command.hasStderrEnabled() ? "1" : "0")
.queryParam("stream", command.hasFollowStreamEnabled() ? "1" : "0");
LOGGER.trace("POST: {}", webTarget);
return new POSTCallbackNotifier(new FrameStreamProcessor(), resultCallback, webTarget.request(), null);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy