aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/main/java/com/google
diff options
context:
space:
mode:
authorGravatar Jakob Buchgraber <buchgr@google.com>2018-02-08 12:19:57 -0800
committerGravatar Copybara-Service <copybara-piper@google.com>2018-02-08 12:21:43 -0800
commitcf3f81aef7c32019d70cbce218a64a03276268f0 (patch)
tree91e53806bed5441f4e93c43c999ac1ace3ce0c8f /src/main/java/com/google
parent1c6d061ea448ee19022f6e609099515a25a5a131 (diff)
remote: Add support for HTTP Basic Auth
Closes #4609. PiperOrigin-RevId: 185032751
Diffstat (limited to 'src/main/java/com/google')
-rw-r--r--src/main/java/com/google/devtools/build/lib/remote/blobstore/http/AbstractHttpHandler.java9
1 files changed, 9 insertions, 0 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/remote/blobstore/http/AbstractHttpHandler.java b/src/main/java/com/google/devtools/build/lib/remote/blobstore/http/AbstractHttpHandler.java
index 5b7df8a106..fc8c14a005 100644
--- a/src/main/java/com/google/devtools/build/lib/remote/blobstore/http/AbstractHttpHandler.java
+++ b/src/main/java/com/google/devtools/build/lib/remote/blobstore/http/AbstractHttpHandler.java
@@ -14,10 +14,13 @@
package com.google.devtools.build.lib.remote.blobstore.http;
import com.google.auth.Credentials;
+import com.google.common.base.Charsets;
+import com.google.common.io.BaseEncoding;
import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelOutboundHandler;
import io.netty.channel.ChannelPromise;
import io.netty.channel.SimpleChannelInboundHandler;
+import io.netty.handler.codec.http.HttpHeaderNames;
import io.netty.handler.codec.http.HttpObject;
import io.netty.handler.codec.http.HttpRequest;
import java.io.IOException;
@@ -53,6 +56,12 @@ abstract class AbstractHttpHandler<T extends HttpObject> extends SimpleChannelIn
}
protected void addCredentialHeaders(HttpRequest request, URI uri) throws IOException {
+ String userInfo = uri.getUserInfo();
+ if (userInfo != null) {
+ String value = BaseEncoding.base64Url().encode(userInfo.getBytes(Charsets.UTF_8));
+ request.headers().set(HttpHeaderNames.AUTHORIZATION, "Basic " + value);
+ return;
+ }
if (credentials == null || !credentials.hasRequestMetadata()) {
return;
}