| // Copyright 2016 The Bazel 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. |
| |
| package com.google.devtools.build.lib.remote; |
| |
| import com.google.devtools.common.options.Option; |
| import com.google.devtools.common.options.OptionsBase; |
| |
| /** Options for remote execution and distributed caching. */ |
| public final class RemoteOptions extends OptionsBase { |
| @Option( |
| name = "rest_cache_url", |
| defaultValue = "null", |
| category = "remote", |
| help = |
| "A base URL for a RESTful cache server for storing build artifacts." |
| + "It has to support PUT, GET, and HEAD requests." |
| ) |
| public String restCacheUrl; |
| |
| @Option( |
| name = "hazelcast_node", |
| defaultValue = "null", |
| category = "remote", |
| help = "A comma separated list of hostnames of hazelcast nodes." |
| ) |
| public String hazelcastNode; |
| |
| @Option( |
| name = "hazelcast_client_config", |
| defaultValue = "null", |
| category = "remote", |
| help = "A file path to a hazelcast client config XML file." |
| ) |
| public String hazelcastClientConfig; |
| |
| @Option( |
| name = "hazelcast_standalone_listen_port", |
| defaultValue = "0", |
| category = "build_worker", |
| help = |
| "Runs an embedded hazelcast server that listens to this port. The server does not join" |
| + " any cluster. This is useful for testing." |
| ) |
| public int hazelcastStandaloneListenPort; |
| |
| @Option( |
| name = "remote_worker", |
| defaultValue = "null", |
| category = "remote", |
| help = "Hostname and port number of remote worker in the form of host:port. " |
| ) |
| public String remoteWorker; |
| |
| @Option( |
| name = "remote_cache", |
| defaultValue = "null", |
| category = "remote", |
| help = "Hostname and port number of remote gRPC cache in the form of host:port. " |
| ) |
| public String remoteCache; |
| |
| @Option( |
| name = "grpc_max_chunk_size_bytes", |
| defaultValue = "16000", |
| category = "remote", |
| help = "The maximal number of data bytes to be sent in a single message." |
| ) |
| public int grpcMaxChunkSizeBytes; |
| |
| @Option( |
| name = "grpc_max_batch_inputs", |
| defaultValue = "100", |
| category = "remote", |
| help = "The maximal number of input files to be sent in a single batch." |
| ) |
| public int grpcMaxBatchInputs; |
| |
| @Option( |
| name = "grpc_max_batch_size_bytes", |
| defaultValue = "10485760", // 10MB |
| category = "remote", |
| help = "The maximal number of input bytes to be sent in a single batch." |
| ) |
| public int grpcMaxBatchSizeBytes; |
| |
| @Option( |
| name = "grpc_timeout_seconds", |
| defaultValue = "60", |
| category = "remote", |
| help = "The maximal number of seconds to wait for remote calls." |
| ) |
| public int grpcTimeoutSeconds; |
| |
| @Option( |
| name = "remote_accept_cached", |
| defaultValue = "true", |
| category = "remote", |
| help = "Whether to accept remotely cached action results." |
| ) |
| public boolean remoteAcceptCached; |
| |
| @Option( |
| name = "remote_allow_local_fallback", |
| defaultValue = "true", |
| category = "remote", |
| help = "Whether to fall back to standalone strategy if remote fails." |
| ) |
| public boolean remoteAllowLocalFallback; |
| |
| @Option( |
| name = "remote_local_exec_upload_results", |
| defaultValue = "true", |
| category = "remote", |
| help = "Whether to upload action results to the remote cache after executing locally." |
| ) |
| public boolean remoteLocalExecUploadResults; |
| |
| @Option( |
| name = "experimental_remote_platform_override", |
| defaultValue = "null", |
| category = "remote", |
| help = "Temporary, for testing only. Manually set a Platform to pass to remote execution." |
| ) |
| public String experimentalRemotePlatformOverride; |
| |
| @Option( |
| name = "auth_enabled", |
| defaultValue = "false", |
| category = "remote", |
| help = "Whether to enable API key authentication." |
| ) |
| public boolean authEnabled; |
| |
| @Option( |
| name = "auth_scope", |
| defaultValue = "null", |
| category = "remote", |
| help = "If server authentication requires a scope, provide it here." |
| ) |
| public String authScope; |
| |
| @Option( |
| name = "auth_credentials_json", |
| defaultValue = "null", |
| category = "remote", |
| help = "Location of credentials JSON file." |
| ) |
| public String authCredentialsJson; |
| |
| @Option( |
| name = "tls_enabled", |
| defaultValue = "false", |
| category = "remote", |
| help = |
| "If set to true, Bazel uses TLS encryption for all connections to remote cache and " |
| + "execution servers." |
| ) |
| public boolean tlsEnabled; |
| |
| @Option( |
| name = "tls_cert", |
| defaultValue = "null", |
| category = "remote", |
| help = "TLS certificate file to use." |
| ) |
| public String tlsCert; |
| |
| @Option( |
| name = "tls_authority_override", |
| defaultValue = "null", |
| category = "remote", |
| help = |
| "If present, consider the value of the flag a valid TLS authority. This is useful for " |
| + "using self-signed test TLS certificates. For testing only." |
| ) |
| public String tlsAuthorityOverride; |
| } |