public class io.fabric.kubernetes.client.dsl.internal.uploadable.PodUpload extends java.lang.Object
{
private static final int DEFAULT_BUFFER_SIZE;
private static final int DEFAULT_CONNECTION_TIMEOUT_SECONDS;
private static final int DEFAULT_COMPLETE_REQUEST_TIMEOUT_SECONDS;
private static final java.lang.String TAR_PATH_DELIMITER;
private void <init>()
{
io.fabric.kubernetes.client.dsl.internal.uploadable.PodUpload v;
v := @this: io.fabric.kubernetes.client.dsl.internal.uploadable.PodUpload;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static boolean upload(okhttp.OkHttpClient, io.fabric.kubernetes.client.dsl.internal.PodOperationContext, io.fabric.kubernetes.client.dsl.base.OperationSupport, java.nio.file.Path) throws java.io.IOException, java.lang.InterruptedException
{
io.fabric.kubernetes.client.dsl.internal.PodOperationContext v;
java.lang.IllegalArgumentException v;
java.io.File v, v;
io.fabric.kubernetes.client.dsl.base.OperationSupport v;
okhttp.OkHttpClient v;
java.lang.String v, v;
java.nio.file.Path v;
boolean v, v, v, v, v, v;
v := @parameter: okhttp.OkHttpClient;
v := @parameter: io.fabric.kubernetes.client.dsl.internal.PodOperationContext;
v := @parameter: io.fabric.kubernetes.client.dsl.base.OperationSupport;
v := @parameter: java.nio.file.Path;
v = virtualinvoke v.<io.fabric.kubernetes.client.dsl.internal.PodOperationContext: java.lang.String getFile()>();
v = staticinvoke <io.fabric.kubernetes.client.utils.Utils: boolean isNotNullOrEmpty(java.lang.String)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<java.nio.file.Path: java.io.File toFile()>();
v = virtualinvoke v.<java.io.File: boolean isFile()>();
if v == 0 goto label;
v = staticinvoke <io.fabric.kubernetes.client.dsl.internal.uploadable.PodUpload: boolean uploadFile(okhttp.OkHttpClient,io.fabric.kubernetes.client.dsl.internal.PodOperationContext,io.fabric.kubernetes.client.dsl.base.OperationSupport,java.nio.file.Path)>(v, v, v, v);
return v;
label:
v = virtualinvoke v.<io.fabric.kubernetes.client.dsl.internal.PodOperationContext: java.lang.String getDir()>();
v = staticinvoke <io.fabric.kubernetes.client.utils.Utils: boolean isNotNullOrEmpty(java.lang.String)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<java.nio.file.Path: java.io.File toFile()>();
v = virtualinvoke v.<java.io.File: boolean isDirectory()>();
if v == 0 goto label;
v = staticinvoke <io.fabric.kubernetes.client.dsl.internal.uploadable.PodUpload: boolean uploadDirectory(okhttp.OkHttpClient,io.fabric.kubernetes.client.dsl.internal.PodOperationContext,io.fabric.kubernetes.client.dsl.base.OperationSupport,java.nio.file.Path)>(v, v, v, v);
return v;
label:
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("Provided arguments are not valid (file, directory, path)");
throw v;
}
private static boolean uploadFile(okhttp.OkHttpClient, io.fabric.kubernetes.client.dsl.internal.PodOperationContext, io.fabric.kubernetes.client.dsl.base.OperationSupport, java.nio.file.Path) throws java.io.IOException, java.lang.InterruptedException
{
java.lang.Throwable v, v;
byte[] v;
java.lang.Object[] v;
java.net.URL v;
java.util.function.ObjIntConsumer v;
int v;
java.lang.String v, v, v;
java.nio.file.Path v;
io.fabric.kubernetes.client.dsl.internal.uploadable.PodUploadWebSocketListener v;
io.fabric.kubernetes.client.dsl.internal.PodOperationContext v;
java.io.FileInputStream v;
java.io.File v;
io.fabric.kubernetes.client.dsl.base.OperationSupport v;
okhttp.OkHttpClient v;
org.apache.commons.codec.binary.Base64InputStream v;
v := @parameter: okhttp.OkHttpClient;
v := @parameter: io.fabric.kubernetes.client.dsl.internal.PodOperationContext;
v := @parameter: io.fabric.kubernetes.client.dsl.base.OperationSupport;
v := @parameter: java.nio.file.Path;
v = virtualinvoke v.<io.fabric.kubernetes.client.dsl.internal.PodOperationContext: java.lang.String getFile()>();
v = virtualinvoke v.<java.lang.String: int lastIndexOf(int)>(47);
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int,int)>(0, v);
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("mkdir -p %s && base -d - > %s", v);
v = staticinvoke <io.fabric.kubernetes.client.dsl.internal.uploadable.PodUpload: java.net.URL buildCommandUrl(java.lang.String,io.fabric.kubernetes.client.dsl.internal.PodOperationContext,io.fabric.kubernetes.client.dsl.base.OperationSupport)>(v, v, v);
v = staticinvoke <io.fabric.kubernetes.client.dsl.internal.uploadable.PodUpload: io.fabric.kubernetes.client.dsl.internal.uploadable.PodUploadWebSocketListener initWebSocket(java.net.URL,okhttp.OkHttpClient)>(v, v);
v = new java.io.FileInputStream;
v = interfaceinvoke v.<java.nio.file.Path: java.io.File toFile()>();
specialinvoke v.<java.io.FileInputStream: void <init>(java.io.File)>(v);
label:
v = new org.apache.commons.codec.binary.Base64InputStream;
v = newarray (byte)[2];
v[0] = 13;
v[1] = 10;
specialinvoke v.<org.apache.commons.codec.binary.Base64InputStream: void <init>(java.io.InputStream,boolean,int,byte[])>(v, 1, 0, v);
label:
virtualinvoke v.<io.fabric.kubernetes.client.dsl.internal.uploadable.PodUploadWebSocketListener: void waitUntilReady(int)>(10);
virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = staticinvoke <io.fabric.kubernetes.client.dsl.internal.uploadable.PodUpload$send__61: java.util.function.ObjIntConsumer bootstrap$(io.fabric.kubernetes.client.dsl.internal.uploadable.PodUploadWebSocketListener)>(v);
staticinvoke <io.fabric.kubernetes.client.dsl.internal.uploadable.PodUpload: void copy(java.io.InputStream,java.util.function.ObjIntConsumer)>(v, v);
virtualinvoke v.<io.fabric.kubernetes.client.dsl.internal.uploadable.PodUploadWebSocketListener: void waitUntilComplete(int)>(120);
label:
virtualinvoke v.<org.apache.commons.codec.binary.Base64InputStream: void close()>();
label:
virtualinvoke v.<java.io.FileInputStream: void close()>();
return 1;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
throw v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private static boolean uploadDirectory(okhttp.OkHttpClient, io.fabric.kubernetes.client.dsl.internal.PodOperationContext, io.fabric.kubernetes.client.dsl.base.OperationSupport, java.nio.file.Path) throws java.io.IOException, java.lang.InterruptedException
{
byte[] v;
java.net.URL v;
java.util.concurrent.TimeoutException v;
java.util.concurrent.Future v;
java.io.PipedInputStream v;
java.nio.file.Path v;
boolean v;
io.fabric.kubernetes.client.dsl.internal.PodOperationContext v;
java.util.zip.GZIPOutputStream v;
java.lang.Throwable v, v, v, v, v, v, v, v;
java.lang.Object[] v;
java.util.concurrent.Callable v;
java.util.function.ObjIntConsumer v;
java.lang.String v, v, v;
org.apache.commons.codec.binary.Base64OutputStream v;
java.util.concurrent.ExecutorService v;
io.fabric.kubernetes.client.dsl.internal.uploadable.PodUploadWebSocketListener v;
java.io.IOException v;
java.io.PipedOutputStream v;
io.fabric.kubernetes.client.dsl.base.OperationSupport v;
java.util.concurrent.ExecutionException v;
java.util.concurrent.TimeUnit v;
okhttp.OkHttpClient v;
v := @parameter: okhttp.OkHttpClient;
v := @parameter: io.fabric.kubernetes.client.dsl.internal.PodOperationContext;
v := @parameter: io.fabric.kubernetes.client.dsl.base.OperationSupport;
v := @parameter: java.nio.file.Path;
v = newarray (java.lang.Object)[1];
v = virtualinvoke v.<io.fabric.kubernetes.client.dsl.internal.PodOperationContext: java.lang.String getDir()>();
v[0] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("mkdir -p %1$s && base -d - | tar -C %1$s -xzf -", v);
v = staticinvoke <io.fabric.kubernetes.client.dsl.internal.uploadable.PodUpload: java.net.URL buildCommandUrl(java.lang.String,io.fabric.kubernetes.client.dsl.internal.PodOperationContext,io.fabric.kubernetes.client.dsl.base.OperationSupport)>(v, v, v);
v = staticinvoke <io.fabric.kubernetes.client.dsl.internal.uploadable.PodUpload: io.fabric.kubernetes.client.dsl.internal.uploadable.PodUploadWebSocketListener initWebSocket(java.net.URL,okhttp.OkHttpClient)>(v, v);
v = new java.io.PipedOutputStream;
specialinvoke v.<java.io.PipedOutputStream: void <init>()>();
label:
v = new java.io.PipedInputStream;
specialinvoke v.<java.io.PipedInputStream: void <init>(java.io.PipedOutputStream)>(v);
label:
v = new org.apache.commons.codec.binary.Base64OutputStream;
v = newarray (byte)[2];
v[0] = 13;
v[1] = 10;
specialinvoke v.<org.apache.commons.codec.binary.Base64OutputStream: void <init>(java.io.OutputStream,boolean,int,byte[])>(v, 1, 0, v);
label:
v = new java.util.zip.GZIPOutputStream;
specialinvoke v.<java.util.zip.GZIPOutputStream: void <init>(java.io.OutputStream)>(v);
label:
virtualinvoke v.<io.fabric.kubernetes.client.dsl.internal.uploadable.PodUploadWebSocketListener: void waitUntilReady(int)>(10);
v = staticinvoke <io.fabric.kubernetes.client.dsl.internal.uploadable.PodUpload$lambda_uploadDirectory_0__62: java.util.concurrent.Callable bootstrap$(java.util.zip.GZIPOutputStream,java.nio.file.Path)>(v, v);
v = staticinvoke <java.util.concurrent.Executors: java.util.concurrent.ExecutorService newSingleThreadExecutor()>();
v = interfaceinvoke v.<java.util.concurrent.ExecutorService: java.util.concurrent.Future submit(java.util.concurrent.Callable)>(v);
virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = staticinvoke <io.fabric.kubernetes.client.dsl.internal.uploadable.PodUpload$send__63: java.util.function.ObjIntConsumer bootstrap$(io.fabric.kubernetes.client.dsl.internal.uploadable.PodUploadWebSocketListener)>(v);
staticinvoke <io.fabric.kubernetes.client.dsl.internal.uploadable.PodUpload: void copy(java.io.InputStream,java.util.function.ObjIntConsumer)>(v, v);
virtualinvoke v.<io.fabric.kubernetes.client.dsl.internal.uploadable.PodUploadWebSocketListener: void waitUntilComplete(int)>(120);
label:
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit SECONDS>;
interfaceinvoke v.<java.util.concurrent.Future: java.lang.Object get(long,java.util.concurrent.TimeUnit)>(100L, v);
label:
interfaceinvoke v.<java.util.concurrent.ExecutorService: void shutdown()>();
label:
virtualinvoke v.<java.util.zip.GZIPOutputStream: void close()>();
label:
virtualinvoke v.<org.apache.commons.codec.binary.Base64OutputStream: void close()>();
label:
virtualinvoke v.<java.io.PipedInputStream: void close()>();
label:
virtualinvoke v.<java.io.PipedOutputStream: void close()>();
return 1;
label:
v := @caughtexception;
v = virtualinvoke v.<java.util.concurrent.ExecutionException: java.lang.Throwable getCause()>();
v = v instanceof java.io.IOException;
if v == 0 goto label;
v = virtualinvoke v.<java.util.concurrent.ExecutionException: java.lang.Throwable getCause()>();
throw v;
label:
v = new java.io.IOException;
v = virtualinvoke v.<java.util.concurrent.ExecutionException: java.lang.String getMessage()>();
v = virtualinvoke v.<java.util.concurrent.ExecutionException: java.lang.Throwable getCause()>();
specialinvoke v.<java.io.IOException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
v := @caughtexception;
label:
interfaceinvoke v.<java.util.concurrent.ExecutorService: void shutdown()>();
label:
if v == null goto label;
virtualinvoke v.<java.util.zip.GZIPOutputStream: void close()>();
label:
if v == null goto label;
virtualinvoke v.<org.apache.commons.codec.binary.Base64OutputStream: void close()>();
label:
if v == null goto label;
virtualinvoke v.<java.io.PipedInputStream: void close()>();
label:
if v == null goto label;
virtualinvoke v.<java.io.PipedOutputStream: void close()>();
label:
return 0;
label:
v := @caughtexception;
interfaceinvoke v.<java.util.concurrent.ExecutorService: void shutdown()>();
throw v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
throw v;
catch java.util.concurrent.ExecutionException from label to label with label;
catch java.util.concurrent.TimeoutException from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
static void copy(java.io.InputStream, java.util.function.ObjIntConsumer) throws java.io.IOException
{
byte[] v;
int v, v;
java.util.function.ObjIntConsumer v;
java.io.InputStream v;
v := @parameter: java.io.InputStream;
v := @parameter: java.util.function.ObjIntConsumer;
v = newarray (byte)[8192];
label:
v = virtualinvoke v.<java.io.InputStream: int read(byte[])>(v);
v = (int) -1;
if v == v goto label;
interfaceinvoke v.<java.util.function.ObjIntConsumer: void accept(java.lang.Object,int)>(v, v);
goto label;
label:
return;
}
private static void addFileToTar(java.lang.String, java.io.File, org.apache.commons.compress.archivers.tar.TarArchiveOutputStream) throws java.io.IOException
{
java.io.File v, v;
org.apache.commons.compress.archivers.tar.TarArchiveOutputStream v;
org.apache.commons.compress.archivers.tar.TarArchiveEntry v;
int v, v;
java.util.Optional v;
java.lang.Object v;
java.lang.String v, v, v;
java.io.File[] v;
java.nio.file.Path v;
boolean v, v;
v := @parameter: java.lang.String;
v := @parameter: java.io.File;
v := @parameter: org.apache.commons.compress.archivers.tar.TarArchiveOutputStream;
v = staticinvoke <java.util.Optional: java.util.Optional ofNullable(java.lang.Object)>(v);
v = virtualinvoke v.<java.util.Optional: java.lang.Object orElse(java.lang.Object)>("");
v = virtualinvoke v.<java.io.File: java.lang.String getName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u0001/\u0001");
v = new org.apache.commons.compress.archivers.tar.TarArchiveEntry;
specialinvoke v.<org.apache.commons.compress.archivers.tar.TarArchiveEntry: void <init>(java.io.File,java.lang.String)>(v, v);
virtualinvoke v.<org.apache.commons.compress.archivers.tar.TarArchiveOutputStream: void putArchiveEntry(org.apache.commons.compress.archivers.ArchiveEntry)>(v);
v = virtualinvoke v.<java.io.File: boolean isFile()>();
if v == 0 goto label;
v = virtualinvoke v.<java.io.File: java.nio.file.Path toPath()>();
staticinvoke <java.nio.file.Files: long copy(java.nio.file.Path,java.io.OutputStream)>(v, v);
virtualinvoke v.<org.apache.commons.compress.archivers.tar.TarArchiveOutputStream: void closeArchiveEntry()>();
goto label;
label:
v = virtualinvoke v.<java.io.File: boolean isDirectory()>();
if v == 0 goto label;
virtualinvoke v.<org.apache.commons.compress.archivers.tar.TarArchiveOutputStream: void closeArchiveEntry()>();
v = virtualinvoke v.<java.io.File: java.io.File[] listFiles()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
staticinvoke <io.fabric.kubernetes.client.dsl.internal.uploadable.PodUpload: void addFileToTar(java.lang.String,java.io.File,org.apache.commons.compress.archivers.tar.TarArchiveOutputStream)>(v, v, v);
v = v + 1;
goto label;
label:
return;
}
private static io.fabric.kubernetes.client.dsl.internal.uploadable.PodUploadWebSocketListener initWebSocket(java.net.URL, okhttp.OkHttpClient)
{
okhttp.Request v;
okhttp.Request$Builder v, v, v, v;
java.net.URL v;
java.util.concurrent.TimeUnit v;
okhttp.OkHttpClient v, v;
okhttp.OkHttpClient$Builder v, v;
io.fabric.kubernetes.client.dsl.internal.uploadable.PodUploadWebSocketListener v;
v := @parameter: java.net.URL;
v := @parameter: okhttp.OkHttpClient;
v = new io.fabric.kubernetes.client.dsl.internal.uploadable.PodUploadWebSocketListener;
specialinvoke v.<io.fabric.kubernetes.client.dsl.internal.uploadable.PodUploadWebSocketListener: void <init>()>();
v = new okhttp.Request$Builder;
specialinvoke v.<okhttp.Request$Builder: void <init>()>();
v = virtualinvoke v.<okhttp.Request$Builder: okhttp.Request$Builder url(java.net.URL)>(v);
v = virtualinvoke v.<okhttp.Request$Builder: okhttp.Request$Builder header(java.lang.String,java.lang.String)>("Sec-WebSocket-Protocol", "v.channel.k8s.io");
v = virtualinvoke v.<okhttp.Request$Builder: okhttp.Request$Builder get()>();
v = virtualinvoke v.<okhttp.OkHttpClient: okhttp.OkHttpClient$Builder newBuilder()>();
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = virtualinvoke v.<okhttp.OkHttpClient$Builder: okhttp.OkHttpClient$Builder readTimeout(long,java.util.concurrent.TimeUnit)>(0L, v);
v = virtualinvoke v.<okhttp.OkHttpClient$Builder: okhttp.OkHttpClient build()>();
v = virtualinvoke v.<okhttp.Request$Builder: okhttp.Request build()>();
virtualinvoke v.<okhttp.OkHttpClient: okhttp.WebSocket newWebSocket(okhttp.Request,okhttp.WebSocketListener)>(v, v);
return v;
}
private static java.net.URL buildCommandUrl(java.lang.String, io.fabric.kubernetes.client.dsl.internal.PodOperationContext, io.fabric.kubernetes.client.dsl.base.OperationSupport) throws java.io.UnsupportedEncodingException, java.net.MalformedURLException
{
java.net.URL v, v;
java.lang.String[] v;
java.lang.String v, v, v, v, v, v, v, v;
boolean v;
io.fabric.kubernetes.client.dsl.internal.PodOperationContext v;
io.fabric.kubernetes.client.dsl.base.OperationSupport v;
java.lang.StringBuilder v, v;
v := @parameter: java.lang.String;
v := @parameter: io.fabric.kubernetes.client.dsl.internal.PodOperationContext;
v := @parameter: io.fabric.kubernetes.client.dsl.base.OperationSupport;
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("exec?");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("command=sh&command=-c");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("&command=");
v = staticinvoke <io.fabric.kubernetes.client.utils.URLUtils: java.lang.String encodeToUTF(java.lang.String)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = virtualinvoke v.<io.fabric.kubernetes.client.dsl.internal.PodOperationContext: java.lang.String getContainerId()>();
if v == null goto label;
v = virtualinvoke v.<io.fabric.kubernetes.client.dsl.internal.PodOperationContext: java.lang.String getContainerId()>();
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("&container=");
v = virtualinvoke v.<io.fabric.kubernetes.client.dsl.internal.PodOperationContext: java.lang.String getContainerId()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
label:
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("&stdin=true");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("&stderr=true");
v = new java.net.URL;
v = newarray (java.lang.String)[2];
v = virtualinvoke v.<io.fabric.kubernetes.client.dsl.base.OperationSupport: java.net.URL getResourceUrl()>();
v = virtualinvoke v.<java.net.URL: java.lang.String toString()>();
v[0] = v;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
v[1] = v;
v = staticinvoke <io.fabric.kubernetes.client.utils.URLUtils: java.lang.String join(java.lang.String[])>(v);
specialinvoke v.<java.net.URL: void <init>(java.lang.String)>(v);
return v;
}
}