/*
* 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.doctor.config;
import com.facebook.buck.model.BuildId;
import com.facebook.buck.util.immutables.BuckStyleImmutable;
import java.util.Optional;
import org.immutables.value.Value;
@Value.Immutable
@BuckStyleImmutable
abstract class AbstractDoctorEndpointRequest {
@Value.Parameter
abstract Optional<BuildId> getBuildId();
/** @return the directory where all logs are under. */
@Value.Parameter
abstract String getLogDirPath();
/**
* For more information how MachineReadableLog works check {@link
* com.facebook.buck.event.listener.MachineReadableLoggerListener}.
*
* @return the contents of the machine readable logs. Each line marks a different key to json.
*/
@Value.Parameter
abstract Optional<String> getMachineReadableLog();
/** @return the contents of the message that rage returned. */
@Value.Parameter
abstract Optional<String> getRageMessage();
/** @return if rage command returned a redirect link this will be saved here. */
@Value.Parameter
abstract Optional<String> getRageUrl();
}