org.graylog2.rest.resources.system.responses.JournalSummaryResponse Maven / Gradle / Ivy
/**
* This file is part of Graylog.
*
* Graylog is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Graylog is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Graylog. If not, see .
*/
package org.graylog2.rest.resources.system.responses;
import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.github.joschi.jadconfig.util.Size;
import com.google.auto.value.AutoValue;
import org.graylog2.plugin.KafkaJournalConfiguration;
import org.joda.time.DateTime;
import javax.annotation.Nullable;
@JsonAutoDetect
@AutoValue
public abstract class JournalSummaryResponse {
public static JournalSummaryResponse createDisabled() {
return new AutoValue_JournalSummaryResponse(false, 0, 0, 0, Size.bytes(0), Size.bytes(0), 0, null, null);
}
public static JournalSummaryResponse createEnabled(long appendEventsPerSec,
long readEventsPerSec,
long uncommittedJournalEntries,
Size journalSize,
Size journalSizeLimit,
int numberOfSegments,
DateTime oldestSegment,
KafkaJournalConfiguration kafkaJournalConfiguration) {
return new AutoValue_JournalSummaryResponse(true,
appendEventsPerSec,
readEventsPerSec,
uncommittedJournalEntries,
journalSize,
journalSizeLimit,
numberOfSegments,
oldestSegment,
kafkaJournalConfiguration);
}
// keep the fields in the same order as the auto value constructor params!
@JsonProperty
public abstract boolean enabled();
@JsonProperty
public abstract long appendEventsPerSecond();
@JsonProperty
public abstract long readEventsPerSecond();
@JsonProperty
public abstract long uncommittedJournalEntries();
@JsonProperty
public abstract Size journalSize();
@JsonProperty
public abstract Size journalSizeLimit();
@JsonProperty
public abstract int numberOfSegments();
@JsonProperty
@Nullable
public abstract DateTime oldestSegment();
@JsonProperty
@Nullable
public abstract KafkaJournalConfiguration journalConfig();
}