All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.arangodb.model.LogOptions Maven / Gradle / Ivy

There is a newer version: 7.15.0
Show newest version
/*
 * DISCLAIMER
 *
 * Copyright 2016 ArangoDB GmbH, Cologne, Germany
 *
 * 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.
 *
 * Copyright holder is ArangoDB GmbH, Cologne, Germany
 */

package com.arangodb.model;

import com.arangodb.entity.LogLevel;

/**
 * @author Mark Vollmary
 * @see API
 * Documentation
 */
public class LogOptions {

    public static final String PROPERTY_UPTO = "upto";
    public static final String PROPERTY_LEVEL = "level";
    public static final String PROPERTY_START = "start";
    public static final String PROPERTY_SIZE = "size";
    public static final String PROPERTY_OFFSET = "offset";
    public static final String PROPERTY_SEARCH = "search";
    public static final String PROPERTY_SORT = "sort";

    public enum SortOrder {
        asc, desc
    }

    private LogLevel upto;
    private LogLevel level;
    private Long start;
    private Integer size;
    private Integer offset;
    private String search;
    private SortOrder sort;

    public LogOptions() {
        super();
    }

    public LogLevel getUpto() {
        return upto;
    }

    /**
     * @param upto Returns all log entries up to log level upto
     * @return options
     */
    public LogOptions upto(final LogLevel upto) {
        this.upto = upto;
        return this;
    }

    public LogLevel getLevel() {
        return level;
    }

    /**
     * @param level Returns all log entries of log level level. Note that the query parameters upto and level are mutually
     *              exclusive
     * @return options
     */
    public LogOptions level(final LogLevel level) {
        this.level = level;
        return this;
    }

    public Long getStart() {
        return start;
    }

    /**
     * @param start Returns all log entries such that their log entry identifier (lid value) is greater or equal to start
     * @return options
     */
    public LogOptions start(final Long start) {
        this.start = start;
        return this;
    }

    public Integer getSize() {
        return size;
    }

    /**
     * @param size Restricts the result to at most size log entries
     * @return options
     */
    public LogOptions size(final Integer size) {
        this.size = size;
        return this;
    }

    public Integer getOffset() {
        return offset;
    }

    /**
     * @param offset Starts to return log entries skipping the first offset log entries. offset and size can be used for
     *               pagination
     * @return options
     */
    public LogOptions offset(final Integer offset) {
        this.offset = offset;
        return this;
    }

    public String getSearch() {
        return search;
    }

    /**
     * @param search Only return the log entries containing the text specified in search
     * @return options
     */
    public LogOptions search(final String search) {
        this.search = search;
        return this;
    }

    public SortOrder getSort() {
        return sort;
    }

    /**
     * @param sort Sort the log entries either ascending (if sort is asc) or descending (if sort is desc) according to
     *             their lid values. Note that the lid imposes a chronological order. The default value is asc
     * @return options
     */
    public LogOptions sort(final SortOrder sort) {
        this.sort = sort;
        return this;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy