mirror of
https://github.com/google/nomulus
synced 2025-12-23 14:25:44 +00:00
Add nomulus deployment and service manifests (#2389)
This commit is contained in:
@@ -49,6 +49,15 @@ tasks.register('buildNomulusImage', Exec) {
|
|||||||
dependsOn(tasks.named('stage'))
|
dependsOn(tasks.named('stage'))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
tasks.register('tagNomulusImage', Exec) {
|
||||||
|
commandLine 'docker', 'tag', 'nomulus', "gcr.io/${rootProject.gcpProject}/nomulus"
|
||||||
|
dependsOn(tasks.named('buildNomulusImage'))
|
||||||
|
}
|
||||||
|
|
||||||
|
tasks.register('pushNomulusImage', Exec) {
|
||||||
|
commandLine 'docker', 'push', "gcr.io/${rootProject.gcpProject}/nomulus"
|
||||||
|
}
|
||||||
|
|
||||||
tasks.register('run', JavaExec) {
|
tasks.register('run', JavaExec) {
|
||||||
// We do the check when the task actually runs, not when we define it.
|
// We do the check when the task actually runs, not when we define it.
|
||||||
// This way if one doesn't set the value, one can still run other tasks.
|
// This way if one doesn't set the value, one can still run other tasks.
|
||||||
@@ -66,4 +75,10 @@ tasks.register('run', JavaExec) {
|
|||||||
dependsOn(tasks.named('stage'))
|
dependsOn(tasks.named('stage'))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
tasks.register('deployNomulus', Exec) {
|
||||||
|
dependsOn(tasks.named('pushNomulusImage'), tasks.named(":proxy:pushProxyImage"))
|
||||||
|
configure verifyDeploymentConfig
|
||||||
|
commandLine './deploy-nomulus-for-env.sh', "${rootProject.environment}"
|
||||||
|
}
|
||||||
|
|
||||||
project.build.dependsOn(tasks.named('buildNomulusImage'))
|
project.build.dependsOn(tasks.named('buildNomulusImage'))
|
||||||
|
|||||||
42
jetty/deploy-nomulus-for-env.sh
Executable file
42
jetty/deploy-nomulus-for-env.sh
Executable file
@@ -0,0 +1,42 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# Copyright 2024 The Nomulus Authors. All Rights Reserved.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
#
|
||||||
|
# This script prepares the proxy k8s manifest, pushes it to the clusters, and
|
||||||
|
# kills all running pods to force k8s to create new pods using the just-pushed
|
||||||
|
# manifest.
|
||||||
|
|
||||||
|
if [[ $# -ne 1 ]]; then
|
||||||
|
echo "Usage: $0 alpha|crash|qa"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
environment=${1}
|
||||||
|
project="domain-registry-"${environment}
|
||||||
|
current_context=$(kubectl config current-context)
|
||||||
|
while read line
|
||||||
|
do
|
||||||
|
parts=(${line})
|
||||||
|
echo "Updating cluster ${parts[0]} in location ${parts[1]}..."
|
||||||
|
gcloud container clusters get-credentials "${parts[0]}" \
|
||||||
|
--project "${project}" --location "${parts[1]}"
|
||||||
|
sed s/GCP_PROJECT/${project}/g "./kubernetes/nomulus-deployment.yaml" | \
|
||||||
|
sed s/ENVIRONMENT/${environment}/g | \
|
||||||
|
kubectl apply -f -
|
||||||
|
kubectl apply -f "./kubernetes/nomulus-service.yaml"
|
||||||
|
#kubectl apply -f "./kubernetes/nomulus-gateway.yaml"
|
||||||
|
# Kills all running pods, new pods created will be pulling the new image.
|
||||||
|
kubectl delete pods --all
|
||||||
|
done < <(gcloud container clusters list --project ${project} | grep nomulus)
|
||||||
|
kubectl config use-context "$current_context"
|
||||||
69
jetty/kubernetes/nomulus-deployment.yaml
Normal file
69
jetty/kubernetes/nomulus-deployment.yaml
Normal file
@@ -0,0 +1,69 @@
|
|||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: nomulus
|
||||||
|
labels:
|
||||||
|
app: nomulus
|
||||||
|
spec:
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: nomulus
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: nomulus
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: nomulus
|
||||||
|
image: gcr.io/GCP_PROJECT/nomulus
|
||||||
|
ports:
|
||||||
|
- containerPort: 8080
|
||||||
|
name: http
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
cpu: "500m"
|
||||||
|
args: [ENVIRONMENT]
|
||||||
|
- name: proxy
|
||||||
|
image: gcr.io/GCP_PROJECT/proxy
|
||||||
|
ports:
|
||||||
|
- containerPort: 30001
|
||||||
|
name: whois
|
||||||
|
- containerPort: 30002
|
||||||
|
name: epp
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
cpu: "500m"
|
||||||
|
args: [--env, ENVIRONMENT, --log, --local]
|
||||||
|
env:
|
||||||
|
- name: POD_ID
|
||||||
|
valueFrom:
|
||||||
|
fieldRef:
|
||||||
|
fieldPath: metadata.name
|
||||||
|
- name: NAMESPACE_ID
|
||||||
|
valueFrom:
|
||||||
|
fieldRef:
|
||||||
|
fieldPath: metadata.namespace
|
||||||
|
- name: CONTAINER_NAME
|
||||||
|
value: proxy
|
||||||
|
---
|
||||||
|
apiVersion: autoscaling/v2
|
||||||
|
kind: HorizontalPodAutoscaler
|
||||||
|
metadata:
|
||||||
|
name: nomulus
|
||||||
|
labels:
|
||||||
|
app: nomulus
|
||||||
|
spec:
|
||||||
|
scaleTargetRef:
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
name: nomulus
|
||||||
|
minReplicas: 1
|
||||||
|
maxReplicas: 20
|
||||||
|
metrics:
|
||||||
|
- type: Resource
|
||||||
|
resource:
|
||||||
|
name: cpu
|
||||||
|
target:
|
||||||
|
type: Utilization
|
||||||
|
averageUtilization: 100
|
||||||
|
|
||||||
31
jetty/kubernetes/nomulus-gateway.yaml
Normal file
31
jetty/kubernetes/nomulus-gateway.yaml
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
kind: Gateway
|
||||||
|
apiVersion: gateway.networking.k8s.io/v1beta1
|
||||||
|
metadata:
|
||||||
|
name: nomulus
|
||||||
|
spec:
|
||||||
|
gatewayClassName: gke-l7-global-external-managed-mc
|
||||||
|
listeners:
|
||||||
|
- name: http
|
||||||
|
protocol: HTTP
|
||||||
|
port: 80
|
||||||
|
allowedRoutes:
|
||||||
|
kinds:
|
||||||
|
- kind: HTTPRoute
|
||||||
|
---
|
||||||
|
kind: HTTPRoute
|
||||||
|
apiVersion: gateway.networking.k8s.io/v1beta1
|
||||||
|
metadata:
|
||||||
|
name: nomulus
|
||||||
|
labels:
|
||||||
|
app: nomulus
|
||||||
|
spec:
|
||||||
|
parentRefs:
|
||||||
|
- kind: Gateway
|
||||||
|
name: nomulus
|
||||||
|
rules:
|
||||||
|
- backendRefs:
|
||||||
|
- group: net.gke.io
|
||||||
|
kind: ServiceImport
|
||||||
|
name: nomulus
|
||||||
|
port: 80
|
||||||
|
|
||||||
22
jetty/kubernetes/nomulus-service.yaml
Normal file
22
jetty/kubernetes/nomulus-service.yaml
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: nomulus
|
||||||
|
spec:
|
||||||
|
selector:
|
||||||
|
app: nomulus
|
||||||
|
ports:
|
||||||
|
- port: 80
|
||||||
|
targetPort: http
|
||||||
|
name: http
|
||||||
|
- port: 43
|
||||||
|
targetPort: whois
|
||||||
|
name: whois
|
||||||
|
- port: 700
|
||||||
|
targetPort: epp
|
||||||
|
name: epp
|
||||||
|
#---
|
||||||
|
#kind: ServiceExport
|
||||||
|
#apiVersion: net.gke.io/v1
|
||||||
|
#metadata:
|
||||||
|
# name: nomulus
|
||||||
@@ -18,19 +18,17 @@ task buildProxyImage(dependsOn: deployJar, type: Exec) {
|
|||||||
commandLine 'docker', 'build', '-t', 'proxy', '.'
|
commandLine 'docker', 'build', '-t', 'proxy', '.'
|
||||||
}
|
}
|
||||||
|
|
||||||
task deployProxy(dependsOn: buildProxyImage) {
|
task tagProxyImage(dependsOn: buildProxyImage, type: Exec) {
|
||||||
|
commandLine 'docker', 'tag', 'proxy', "gcr.io/${rootProject.gcpProject}/proxy"
|
||||||
|
}
|
||||||
|
|
||||||
|
task pushProxyImage(dependsOn: tagProxyImage, type: Exec) {
|
||||||
|
commandLine 'docker', 'push', "gcr.io/${rootProject.gcpProject}/proxy"
|
||||||
|
}
|
||||||
|
|
||||||
|
task deployProxy(dependsOn: pushProxyImage, type: Exec) {
|
||||||
configure verifyDeploymentConfig
|
configure verifyDeploymentConfig
|
||||||
doLast {
|
commandLine './deploy-proxy-for-env.sh', "${rootProject.environment}"
|
||||||
exec {
|
|
||||||
commandLine 'docker', 'tag', 'proxy', "gcr.io/${rootProject.gcpProject}/proxy"
|
|
||||||
}
|
|
||||||
exec {
|
|
||||||
commandLine 'docker', 'push', "gcr.io/${rootProject.gcpProject}/proxy"
|
|
||||||
}
|
|
||||||
exec {
|
|
||||||
commandLine './deploy-proxy-for-env.sh', "${rootProject.environment}"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
project.build.dependsOn buildProxyImage
|
project.build.dependsOn buildProxyImage
|
||||||
|
|||||||
@@ -18,8 +18,8 @@
|
|||||||
# manifest.
|
# manifest.
|
||||||
|
|
||||||
if [[ $# -ne 1 ]]; then
|
if [[ $# -ne 1 ]]; then
|
||||||
echo "Usage: $0 alpha|crash"
|
echo "Usage: $0 alpha|crash|qa"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
environment=${1}
|
environment=${1}
|
||||||
|
|||||||
@@ -70,12 +70,14 @@ public final class EppProtocolModule {
|
|||||||
ProxyConfig config,
|
ProxyConfig config,
|
||||||
@EppProtocol int eppPort,
|
@EppProtocol int eppPort,
|
||||||
@EppProtocol ImmutableList<Provider<? extends ChannelHandler>> handlerProviders,
|
@EppProtocol ImmutableList<Provider<? extends ChannelHandler>> handlerProviders,
|
||||||
@HttpsRelayProtocol BackendProtocol.Builder backendProtocolBuilder) {
|
@HttpsRelayProtocol BackendProtocol.Builder backendProtocolBuilder,
|
||||||
|
@HttpsRelayProtocol boolean localRelay) {
|
||||||
return Protocol.frontendBuilder()
|
return Protocol.frontendBuilder()
|
||||||
.name(PROTOCOL_NAME)
|
.name(PROTOCOL_NAME)
|
||||||
.port(eppPort)
|
.port(eppPort)
|
||||||
.handlerProviders(handlerProviders)
|
.handlerProviders(handlerProviders)
|
||||||
.relayProtocol(backendProtocolBuilder.host(config.epp.relayHost).build())
|
.relayProtocol(
|
||||||
|
backendProtocolBuilder.host(localRelay ? "localhost" : config.epp.relayHost).build())
|
||||||
.build();
|
.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -114,7 +116,7 @@ public final class EppProtocolModule {
|
|||||||
config.epp.headerLengthBytes,
|
config.epp.headerLengthBytes,
|
||||||
// Adjustment applied to the header field value in order to obtain message length.
|
// Adjustment applied to the header field value in order to obtain message length.
|
||||||
-config.epp.headerLengthBytes,
|
-config.epp.headerLengthBytes,
|
||||||
// Initial bytes to strip (i.e. strip the length header).
|
// Initial bytes to strip (i.e., strip the length header).
|
||||||
config.epp.headerLengthBytes);
|
config.epp.headerLengthBytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -150,9 +152,14 @@ public final class EppProtocolModule {
|
|||||||
@Named("idToken") Supplier<String> idTokenSupplier,
|
@Named("idToken") Supplier<String> idTokenSupplier,
|
||||||
@Named("hello") byte[] helloBytes,
|
@Named("hello") byte[] helloBytes,
|
||||||
FrontendMetrics metrics,
|
FrontendMetrics metrics,
|
||||||
ProxyConfig config) {
|
ProxyConfig config,
|
||||||
|
@HttpsRelayProtocol boolean localRelay) {
|
||||||
return new EppServiceHandler(
|
return new EppServiceHandler(
|
||||||
config.epp.relayHost, config.epp.relayPath, idTokenSupplier, helloBytes, metrics);
|
localRelay ? "localhost" : config.epp.relayHost,
|
||||||
|
config.epp.relayPath,
|
||||||
|
idTokenSupplier,
|
||||||
|
helloBytes,
|
||||||
|
metrics);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Singleton
|
@Singleton
|
||||||
|
|||||||
@@ -35,11 +35,19 @@ import javax.inject.Provider;
|
|||||||
import javax.inject.Qualifier;
|
import javax.inject.Qualifier;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Module that provides a {@link BackendProtocol.Builder} for HTTPS protocol.
|
* Module that provides a {@link BackendProtocol.Builder} for HTTP(S) protocol.
|
||||||
*
|
*
|
||||||
* <p>Only a builder is provided because the client protocol itself depends on the remote host
|
* <p>Only a builder is provided because the client protocol itself depends on the remote host
|
||||||
* address, which is provided in the server protocol module that relays to this client protocol
|
* address, which is provided in the server protocol module that relays to this client protocol
|
||||||
* module, e. g. {@link WhoisProtocolModule}.
|
* module, e.g., {@link WhoisProtocolModule}.
|
||||||
|
*
|
||||||
|
* <p>The protocol can be configured without TLS. In this case, the remote host has to be
|
||||||
|
* "localhost". Plan HTTP is only expected to be used when communication with Nomulus is via local
|
||||||
|
* loopback (for security reasons), as is the case when both the proxy and Nomulus container live in
|
||||||
|
* the same Kubernetes pod.
|
||||||
|
*
|
||||||
|
* @see <a href=https://kubernetes.io/docs/concepts/services-networking/>The Kubernetes network
|
||||||
|
* model</a>
|
||||||
*/
|
*/
|
||||||
@Module
|
@Module
|
||||||
public class HttpsRelayProtocolModule {
|
public class HttpsRelayProtocolModule {
|
||||||
@@ -54,10 +62,12 @@ public class HttpsRelayProtocolModule {
|
|||||||
@HttpsRelayProtocol
|
@HttpsRelayProtocol
|
||||||
static BackendProtocol.Builder provideProtocolBuilder(
|
static BackendProtocol.Builder provideProtocolBuilder(
|
||||||
ProxyConfig config,
|
ProxyConfig config,
|
||||||
|
@HttpsRelayProtocol boolean localRelay,
|
||||||
@HttpsRelayProtocol ImmutableList<Provider<? extends ChannelHandler>> handlerProviders) {
|
@HttpsRelayProtocol ImmutableList<Provider<? extends ChannelHandler>> handlerProviders) {
|
||||||
return Protocol.backendBuilder()
|
return Protocol.backendBuilder()
|
||||||
.name(PROTOCOL_NAME)
|
.name(PROTOCOL_NAME)
|
||||||
.port(config.httpsRelay.port)
|
.isLocal(localRelay)
|
||||||
|
.port(localRelay ? config.httpsRelay.localPort : config.httpsRelay.port)
|
||||||
.handlerProviders(handlerProviders);
|
.handlerProviders(handlerProviders);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -74,6 +84,7 @@ public class HttpsRelayProtocolModule {
|
|||||||
@Provides
|
@Provides
|
||||||
@HttpsRelayProtocol
|
@HttpsRelayProtocol
|
||||||
static ImmutableList<Provider<? extends ChannelHandler>> provideHandlerProviders(
|
static ImmutableList<Provider<? extends ChannelHandler>> provideHandlerProviders(
|
||||||
|
@HttpsRelayProtocol boolean localRelay,
|
||||||
@HttpsRelayProtocol
|
@HttpsRelayProtocol
|
||||||
Provider<SslClientInitializer<NioSocketChannel>> sslClientInitializerProvider,
|
Provider<SslClientInitializer<NioSocketChannel>> sslClientInitializerProvider,
|
||||||
Provider<HttpClientCodec> httpClientCodecProvider,
|
Provider<HttpClientCodec> httpClientCodecProvider,
|
||||||
@@ -81,13 +92,17 @@ public class HttpsRelayProtocolModule {
|
|||||||
Provider<BackendMetricsHandler> backendMetricsHandlerProvider,
|
Provider<BackendMetricsHandler> backendMetricsHandlerProvider,
|
||||||
Provider<LoggingHandler> loggingHandlerProvider,
|
Provider<LoggingHandler> loggingHandlerProvider,
|
||||||
Provider<FullHttpResponseRelayHandler> relayHandlerProvider) {
|
Provider<FullHttpResponseRelayHandler> relayHandlerProvider) {
|
||||||
return ImmutableList.of(
|
ImmutableList.Builder<Provider<? extends ChannelHandler>> builder =
|
||||||
sslClientInitializerProvider,
|
new ImmutableList.Builder<>();
|
||||||
httpClientCodecProvider,
|
if (!localRelay) {
|
||||||
httpObjectAggregatorProvider,
|
builder.add(sslClientInitializerProvider);
|
||||||
backendMetricsHandlerProvider,
|
}
|
||||||
loggingHandlerProvider,
|
builder.add(httpClientCodecProvider);
|
||||||
relayHandlerProvider);
|
builder.add(httpObjectAggregatorProvider);
|
||||||
|
builder.add(backendMetricsHandlerProvider);
|
||||||
|
builder.add(loggingHandlerProvider);
|
||||||
|
builder.add(relayHandlerProvider);
|
||||||
|
return builder.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Provides
|
@Provides
|
||||||
|
|||||||
@@ -47,8 +47,9 @@ public interface Protocol {
|
|||||||
return new AutoValue_Protocol_FrontendProtocol.Builder().hasBackend(true);
|
return new AutoValue_Protocol_FrontendProtocol.Builder().hasBackend(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** A builder for {@link FrontendProtocol}, by default it connects to a remote host. */
|
||||||
static BackendProtocol.Builder backendBuilder() {
|
static BackendProtocol.Builder backendBuilder() {
|
||||||
return new AutoValue_Protocol_BackendProtocol.Builder();
|
return new AutoValue_Protocol_BackendProtocol.Builder().isLocal(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -121,10 +122,26 @@ public interface Protocol {
|
|||||||
/** The hostname that the proxy connects to. */
|
/** The hostname that the proxy connects to. */
|
||||||
public abstract String host();
|
public abstract String host();
|
||||||
|
|
||||||
|
/** Whether the protocol is expected to connect to localhost. */
|
||||||
|
public abstract boolean isLocal();
|
||||||
|
|
||||||
/** Builder of {@link BackendProtocol}. */
|
/** Builder of {@link BackendProtocol}. */
|
||||||
@AutoValue.Builder
|
@AutoValue.Builder
|
||||||
public abstract static class Builder extends Protocol.Builder<Builder, BackendProtocol> {
|
public abstract static class Builder extends Protocol.Builder<Builder, BackendProtocol> {
|
||||||
public abstract Builder host(String value);
|
public abstract Builder host(String value);
|
||||||
|
|
||||||
|
public abstract Builder isLocal(boolean value);
|
||||||
|
|
||||||
|
abstract BackendProtocol autoBuild();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public BackendProtocol build() {
|
||||||
|
BackendProtocol protocol = autoBuild();
|
||||||
|
Preconditions.checkState(
|
||||||
|
!protocol.isLocal() || protocol.host().equals("localhost"),
|
||||||
|
"Local backend protocol must connect to localhost");
|
||||||
|
return autoBuild();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -103,6 +103,7 @@ public class ProxyConfig {
|
|||||||
/** Configuration options that apply to HTTPS relay protocol. */
|
/** Configuration options that apply to HTTPS relay protocol. */
|
||||||
public static class HttpsRelay {
|
public static class HttpsRelay {
|
||||||
public int port;
|
public int port;
|
||||||
|
public int localPort;
|
||||||
public int maxMessageLengthBytes;
|
public int maxMessageLengthBytes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -37,6 +37,7 @@ import google.registry.networking.module.CertificateSupplierModule;
|
|||||||
import google.registry.networking.module.CertificateSupplierModule.Mode;
|
import google.registry.networking.module.CertificateSupplierModule.Mode;
|
||||||
import google.registry.proxy.EppProtocolModule.EppProtocol;
|
import google.registry.proxy.EppProtocolModule.EppProtocol;
|
||||||
import google.registry.proxy.HealthCheckProtocolModule.HealthCheckProtocol;
|
import google.registry.proxy.HealthCheckProtocolModule.HealthCheckProtocol;
|
||||||
|
import google.registry.proxy.HttpsRelayProtocolModule.HttpsRelayProtocol;
|
||||||
import google.registry.proxy.Protocol.FrontendProtocol;
|
import google.registry.proxy.Protocol.FrontendProtocol;
|
||||||
import google.registry.proxy.ProxyConfig.Environment;
|
import google.registry.proxy.ProxyConfig.Environment;
|
||||||
import google.registry.proxy.WebWhoisProtocolsModule.HttpWhoisProtocol;
|
import google.registry.proxy.WebWhoisProtocolsModule.HttpWhoisProtocol;
|
||||||
@@ -91,6 +92,13 @@ public class ProxyModule {
|
|||||||
@Parameter(names = "--https_whois", description = "Port for HTTPS WHOIS")
|
@Parameter(names = "--https_whois", description = "Port for HTTPS WHOIS")
|
||||||
private Integer httpsWhoisPort;
|
private Integer httpsWhoisPort;
|
||||||
|
|
||||||
|
@Parameter(
|
||||||
|
names = "--local",
|
||||||
|
description =
|
||||||
|
"Whether EPP/WHOIS traffic should be forwarded to localhost using HTTP on port defined in"
|
||||||
|
+ " httpsRelay.localPort")
|
||||||
|
private boolean local = false;
|
||||||
|
|
||||||
@Parameter(names = "--env", description = "Environment to run the proxy in")
|
@Parameter(names = "--env", description = "Environment to run the proxy in")
|
||||||
private Environment env = Environment.LOCAL;
|
private Environment env = Environment.LOCAL;
|
||||||
|
|
||||||
@@ -168,6 +176,13 @@ public class ProxyModule {
|
|||||||
return config.oauthClientId;
|
return config.oauthClientId;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Provides
|
||||||
|
@HttpsRelayProtocol
|
||||||
|
@Singleton
|
||||||
|
boolean provideIsLocal() {
|
||||||
|
return local;
|
||||||
|
}
|
||||||
|
|
||||||
@Provides
|
@Provides
|
||||||
@WhoisProtocol
|
@WhoisProtocol
|
||||||
int provideWhoisPort(ProxyConfig config) {
|
int provideWhoisPort(ProxyConfig config) {
|
||||||
@@ -204,7 +219,7 @@ public class ProxyModule {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provides shared logging handler.
|
* Provides a shared logging handler.
|
||||||
*
|
*
|
||||||
* <p>Note that this handler always records logs at {@code LogLevel.DEBUG}, it is up to the JUL
|
* <p>Note that this handler always records logs at {@code LogLevel.DEBUG}, it is up to the JUL
|
||||||
* logger that it contains to decide if logs at this level should actually be captured. The log
|
* logger that it contains to decide if logs at this level should actually be captured. The log
|
||||||
|
|||||||
@@ -61,12 +61,14 @@ public final class WhoisProtocolModule {
|
|||||||
ProxyConfig config,
|
ProxyConfig config,
|
||||||
@WhoisProtocol int whoisPort,
|
@WhoisProtocol int whoisPort,
|
||||||
@WhoisProtocol ImmutableList<Provider<? extends ChannelHandler>> handlerProviders,
|
@WhoisProtocol ImmutableList<Provider<? extends ChannelHandler>> handlerProviders,
|
||||||
@HttpsRelayProtocol BackendProtocol.Builder backendProtocolBuilder) {
|
@HttpsRelayProtocol BackendProtocol.Builder backendProtocolBuilder,
|
||||||
|
@HttpsRelayProtocol boolean localRelay) {
|
||||||
return Protocol.frontendBuilder()
|
return Protocol.frontendBuilder()
|
||||||
.name(PROTOCOL_NAME)
|
.name(PROTOCOL_NAME)
|
||||||
.port(whoisPort)
|
.port(whoisPort)
|
||||||
.handlerProviders(handlerProviders)
|
.handlerProviders(handlerProviders)
|
||||||
.relayProtocol(backendProtocolBuilder.host(config.whois.relayHost).build())
|
.relayProtocol(
|
||||||
|
backendProtocolBuilder.host(localRelay ? "localhost" : config.whois.relayHost).build())
|
||||||
.build();
|
.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -94,9 +96,13 @@ public final class WhoisProtocolModule {
|
|||||||
static WhoisServiceHandler provideWhoisServiceHandler(
|
static WhoisServiceHandler provideWhoisServiceHandler(
|
||||||
ProxyConfig config,
|
ProxyConfig config,
|
||||||
@Named("idToken") Supplier<String> idTokenSupplier,
|
@Named("idToken") Supplier<String> idTokenSupplier,
|
||||||
FrontendMetrics metrics) {
|
FrontendMetrics metrics,
|
||||||
|
@HttpsRelayProtocol boolean localRelay) {
|
||||||
return new WhoisServiceHandler(
|
return new WhoisServiceHandler(
|
||||||
config.whois.relayHost, config.whois.relayPath, idTokenSupplier, metrics);
|
localRelay ? "localhost" : config.whois.relayHost,
|
||||||
|
config.whois.relayPath,
|
||||||
|
idTokenSupplier,
|
||||||
|
metrics);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Provides
|
@Provides
|
||||||
|
|||||||
@@ -177,7 +177,7 @@ healthCheck:
|
|||||||
|
|
||||||
httpsRelay:
|
httpsRelay:
|
||||||
port: 443
|
port: 443
|
||||||
|
localPort: 8080
|
||||||
# Maximum size of an HTTP message in bytes.
|
# Maximum size of an HTTP message in bytes.
|
||||||
maxMessageLengthBytes: 524288
|
maxMessageLengthBytes: 524288
|
||||||
|
|
||||||
|
|||||||
@@ -67,7 +67,7 @@ import org.junit.jupiter.api.BeforeEach;
|
|||||||
/**
|
/**
|
||||||
* Base class for end-to-end tests of a {@link Protocol}.
|
* Base class for end-to-end tests of a {@link Protocol}.
|
||||||
*
|
*
|
||||||
* <p>The end-to-end tests ensures that the business logic that a {@link Protocol} defines are
|
* <p>The end-to-end tests ensure that the business logic that a {@link Protocol} defines are
|
||||||
* correctly performed by various handlers attached to its pipeline. Non-business essential handlers
|
* correctly performed by various handlers attached to its pipeline. Non-business essential handlers
|
||||||
* should be excluded.
|
* should be excluded.
|
||||||
*
|
*
|
||||||
@@ -91,7 +91,7 @@ public abstract class ProtocolModuleTest {
|
|||||||
// The PROXY protocol is only used when the proxy is behind the GCP load balancer. It is
|
// The PROXY protocol is only used when the proxy is behind the GCP load balancer. It is
|
||||||
// not part of any business logic.
|
// not part of any business logic.
|
||||||
ProxyProtocolHandler.class,
|
ProxyProtocolHandler.class,
|
||||||
// SSL is part of the business logic for some protocol (EPP for example), but its
|
// SSL is part of the business logic for some protocol (EPP, for example), but its
|
||||||
// impact is isolated. Including it makes tests much more complicated. It should be tested
|
// impact is isolated. Including it makes tests much more complicated. It should be tested
|
||||||
// separately in its own unit tests.
|
// separately in its own unit tests.
|
||||||
SslClientInitializer.class,
|
SslClientInitializer.class,
|
||||||
@@ -152,7 +152,7 @@ public abstract class ProtocolModuleTest {
|
|||||||
void initializeChannel(Consumer<Channel> initializer) {
|
void initializeChannel(Consumer<Channel> initializer) {
|
||||||
channel =
|
channel =
|
||||||
new EmbeddedChannel(
|
new EmbeddedChannel(
|
||||||
new ChannelInitializer<Channel>() {
|
new ChannelInitializer<>() {
|
||||||
@Override
|
@Override
|
||||||
protected void initChannel(Channel ch) {
|
protected void initChannel(Channel ch) {
|
||||||
initializer.accept(ch);
|
initializer.accept(ch);
|
||||||
@@ -218,8 +218,8 @@ public abstract class ProtocolModuleTest {
|
|||||||
*
|
*
|
||||||
* <p>Most of the binding provided in this module should be either a fake, or a {@link
|
* <p>Most of the binding provided in this module should be either a fake, or a {@link
|
||||||
* ChannelHandler} that is excluded, and annotated with {@code @Singleton}. This module acts as a
|
* ChannelHandler} that is excluded, and annotated with {@code @Singleton}. This module acts as a
|
||||||
* replacement for {@link ProxyModule} used in production component. Providing a handler that is
|
* replacement for {@link ProxyModule} used in the production component. Providing a handler that
|
||||||
* part of the business logic of a {@link Protocol} from this module is a sign that the binding
|
* is part of the business logic of a {@link Protocol} from this module is a sign that the binding
|
||||||
* should be provided in the respective {@code ProtocolModule} instead.
|
* should be provided in the respective {@code ProtocolModule} instead.
|
||||||
*/
|
*/
|
||||||
@Module
|
@Module
|
||||||
@@ -306,12 +306,19 @@ public abstract class ProtocolModuleTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// This method is only here to satisfy Dagger binding, but is never used. In test environment,
|
// This method is only here to satisfy Dagger binding, but is never used. In test environment,
|
||||||
// it is the self-signed certificate and its key that end up being used.
|
// it is the self-signed certificate and its key that ends up being used.
|
||||||
@Singleton
|
@Singleton
|
||||||
@Provides
|
@Provides
|
||||||
@Named("pemBytes")
|
@Named("pemBytes")
|
||||||
static byte[] providePemBytes() {
|
static byte[] providePemBytes() {
|
||||||
return new byte[0];
|
return new byte[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Singleton
|
||||||
|
@Provides
|
||||||
|
@HttpsRelayProtocol
|
||||||
|
static boolean provideLocalRelay() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user