/* * Copyright 2016-present Facebook, Inc. * * 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.facebook.buck.util.network; import com.facebook.buck.cli.BuckConfig; import com.facebook.buck.slb.SlbBuckConfig; import java.util.concurrent.TimeUnit; import okhttp3.OkHttpClient; public class RemoteLogBuckConfig { private static final String LOG_SECTION_NAME = "log"; private static final String REQUEST_TIMEOUT_MILLIS = "remote_log_timeout_millis"; private static final long DEFAULT_REQUEST_TIMEOUT_MILLIS = 3000; private static final String REQUEST_MAX_THREADS = "remote_log_max_threads"; private static final int DEFAULT_REQUEST_MAX_THREADS = 5; private final SlbBuckConfig frontendConfig; private final BuckConfig buckConfig; public RemoteLogBuckConfig(BuckConfig config) { this.buckConfig = config; this.frontendConfig = new SlbBuckConfig(config, LOG_SECTION_NAME); } public SlbBuckConfig getFrontendConfig() { return frontendConfig; } public OkHttpClient createOkHttpClient() { long timeout = buckConfig .getLong(LOG_SECTION_NAME, REQUEST_TIMEOUT_MILLIS) .orElse(DEFAULT_REQUEST_TIMEOUT_MILLIS); return new OkHttpClient.Builder() .connectTimeout(timeout, TimeUnit.MILLISECONDS) .readTimeout(timeout, TimeUnit.MILLISECONDS) .writeTimeout(timeout, TimeUnit.MILLISECONDS) .build(); } /** @return max. threads to be used for concurrent remote log requests. */ public int getMaxThreads() { return buckConfig .getInteger(LOG_SECTION_NAME, REQUEST_MAX_THREADS) .orElse(DEFAULT_REQUEST_MAX_THREADS); } }