org.dashbuilder.dataset.DataSetLookupBuilder Maven / Gradle / Ivy
/*
* Copyright 2014 Red Hat, Inc. and/or its affiliates.
*
* 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 org.dashbuilder.dataset;
import org.dashbuilder.dataset.filter.ColumnFilter;
import org.dashbuilder.dataset.group.AggregateFunctionType;
import org.dashbuilder.dataset.group.DateIntervalType;
import org.dashbuilder.dataset.sort.SortOrder;
import org.dashbuilder.dataset.date.DayOfWeek;
import org.dashbuilder.dataset.date.Month;
/**
* A DataSetLookupBuilder allows for the assembly of a DataSetLookup instance (i.e. a DataSet lookup request)
* in a friendly manner. It allows the issuing of a request to obtain a view over a specific DataSet.
*
*
* DataSetFactory.newLookupBuilder()
* .dataset("target-dataset-uuid")
* .group("department")
* .column("id", COUNT, "occurrences")
* .column("amount", SUM, "totalAmount")
* .sort("totalAmount", "asc")
* .buildLookup();
*
*
*/
public interface DataSetLookupBuilder {
/**
* The UUID reference to the source data set.
*/
T dataset(String uuid);
/**
* Set a row offset for the data set.
* @param offset The row offset for the resulting data set (starting at 0).
* @return The DataSetLookupBuilder instance that is being used to configure a DataSetLookup request.
*/
T rowOffset(int offset);
/**
* Set the number of rows for the data set.
* @param rows The number of rows for the resulting data set.
* @return The DataSetLookupBuilder instance that is being used to configure a DataSetLookup request.
*/
T rowNumber(int rows);
/**
* Group the data set by one of the columns
* @param columnId The column identifier of the column to be grouped
* @return The DataSetLookupBuilder instance that is being used to configure a DataSetLookup request.
*/
T group(String columnId);
/**
* Group the data set by one of the columns. The resulting group will be given the new column identifier.
* @param columnId The column identifier
* @param newColumnId The identifier for the group column
* @return The DataSetLookupBuilder instance that is being used to configure a DataSetLookup request.
*/
T group(String columnId, String newColumnId);
/**
* This call will operate only on a previously grouped data set (i.e. one of the group() methods has been called
* previously on the data set lookup), and it's used to indicate that the group results must be joined with the
* group results of a previous group operation (if any). Example:
*
*
* - .group(PIPELINE)
* - .group(COUNTRY).join()
* - .column(PIPELINE)
* - .column(COUNTRY)
* - .column(AMOUNT, SUM, "TOTAL")
*
*
* Group by PIPELINE:
*
*
* --------------------------
* | PIPELINE | TOTAL |
* --------------------------
* | EARLY | 369.09 |
* | ADVANCED | 246.06 |
* --------------------------
*
*
* Group by COUNTRY:
*
*
* ------------------------
* | COUNTRY | TOTAL |
* ------------------------
* | USA | 369.09 |
* | UK | 246.06 |
* | Spain | 369.09 |
* ------------------------
*
*
* Result:
*
*
* ---------------------------------------
* | PIPELINE | COUNTRY | TOTAL |
* ---------------------------------------
* | EARLY | USA | 123.03 |
* | EARLY | UK | 123.03 |
* | EARLY | Spain | 123.03 |
* | ADVANCED | USA | 123.03 |
* | ADVANCED | Spain | 123.03 |
* | STANDBY | USA | 123.03 |
* | STANDBY | UK | 123.03 |
* | STANDBY | Spain | 123.03 |
* ---------------------------------------
*
* A joined data set grouped by PIPELINE/COUNTRY is returned.
*
* @return The DataSetLookupBuilder instance that is being used to configure a DataSetLookup request.
*/
T join();
/**
* This call will operate only on a previously grouped data set (i.e. one of the group() methods has been called
* previously on the data set lookup), and will result in that the grouped column is ordered in ascending order.
* @return The DataSetLookupBuilder instance that is being used to configure a DataSetLookup request.
*/
T asc();
/**
* This call will operate only on a previously grouped data set (i.e. one of the group() methods has been called
* previously on the data set lookup), and will result in that the grouped column is ordered in descending order.
* @return The DataSetLookupBuilder instance that is being used to configure a DataSetLookup request.
*/
T desc();
/**
* Group the data set by one of the columns, of type ColumnType.Date, specifying the size of the date interval
* by which the column should be grouped. By default the DYNAMIC GroupStrategy will be applied.
* @see org.dashbuilder.dataset.group.GroupStrategy
* @param maxIntervals The maximum number of date intervals that should appear on the graph. The DYNAMIC GroupStrategy
* implies that if, after grouping, more intervals are generated than the specified amount, a 'greater' DateIntervalType
* will be applied.
* For example:
*
* DataSetFactory.newDataSetLookupBuilder()
* .dataset(SALES_OPPS)
* .group(CLOSING_DATE).dynamic(80, MONTH)
*
* will group the data set by its closing date column, in monthly intervals, up to a maximum 80 months. If this
* dataset's time-span exceeds this number of months, then the next bigger DateIntervalType (i.e. QUARTER) will be applied.
* @param intervalSize The size of the date interval.
* @param emptyAllowed If true then empty intervals will be also considered part of the resulting data set.
* @see org.dashbuilder.dataset.group.DateIntervalType
* @return The DataSetLookupBuilder instance that is being used to configure a DataSetLookup request.
*/
T dynamic(int maxIntervals, DateIntervalType intervalSize, boolean emptyAllowed);
/**
* Same as "dynamic(int maxIntervals, DateIntervalType intervalSize)" but in this case the
* "intervalSize" is dynamically calculated to the minimum size that generates less intervals
* than the "maxIntervals" specified.
*/
T dynamic(int maxIntervals, boolean emptyAllowed);
/**
* Same as "dynamic(int maxIntervals, DateIntervalType intervalSize)" but taking
* "maxIntervals=15" as default.
*/
T dynamic(DateIntervalType intervalSize, boolean emptyAllowed);
/**
* Set the grouping strategy to a fixed date interval on a previously defined date group operation.
*
* Example:
*
* DataSetFactory.newDataSetLookupBuilder()
* .dataset(SALES_OPPS)
* .group(CLOSING_DATE)
* .fixed(MONTH).firstMonth(JANUARY)
*
* will group the data set by a column identified by 'CLOSING_DATE', into a fixed monthly interval, starting with
* January as the first month interval.
*
* @param type The size of the date interval. Only the following types are supported: QUARTER, MONTH,
* DAY_OF_WEEK, HOUR, MINUTE, SECOND
* @param emptyAllowed If true then empty intervals will be also considered part of the resulting data set.
* @see org.dashbuilder.dataset.group.DateIntervalType
* @return The DataSetLookupBuilder instance that is being used to configure a DataSetLookup request.
*/
T fixed(DateIntervalType type, boolean emptyAllowed);
/**
* This call requires a previously grouped data set with fixed DateIntervalType.DAY_OF_WEEK intervals, i.e. both
* group() and fixed(DateIntervalType.DAY_OF_WEEK) have to be invoked previously. It will indicate the resulting
* data set that it has to show the specified day of the week as the first interval.
* @see org.dashbuilder.dataset.group.DateIntervalType
* @param dayOfWeek The day of the week that should be shown as the graph's first interval.
* @return The DataSetLookupBuilder instance that is being used to configure a DataSetLookup request.
*/
T firstDay(DayOfWeek dayOfWeek);
/**
* This call requires a previously grouped data set with fixed DateIntervalType.MONTH intervals, i.e. both
* group() and fixed(DateIntervalType.MONTH) have to be invoked previously. It will indicate the resulting
* data set that it has to show the specified month as the first interval.
* @see org.dashbuilder.dataset.group.DateIntervalType
* @param month The month that should be shown as the graph's first interval.
* @return The DataSetLookupBuilder instance that is being used to configure a DataSetLookup request.
*/
T firstMonth(Month month);
/**
* The function will reduce the generated data set by selecting some of the intervals that were previously generated
* through a group operation.
*
* For example:
*
* DataSetFactory.newDataSetLookupBuilder()
* .dataset(EXPENSE_REPORTS)
* .group("department", "Department")
* .select("Services", "Engineering", "Support")
* .count( "Occurrences" )
* .buildLookup());
*
* Will group the expense reports data set by department, select only the "Services", "Engineering" and "Support"
* intervals, and count how many times each of those occurs respectively.
* @param intervalNames The interval names that should be preserved in the data set that is being generated.
* @return The DataSetLookupBuilder instance that is being used to configure a DataSetLookup request.
*/
T select(String... intervalNames);
/**
* Filter the data set according to the specified column filters. All column filters will need to explicitly reference
* the column (through its corresponding identifier) that they need to be applied on.
*
* For example:
*
* DataSetFactory.newDataSetLookupBuilder()
* .dataset(EXPENSE_REPORTS)
* .filter(AND(
* equalsTo("department", "Sales"),
* OR(
* NOT(lowerThan("amount", 300)),
* equalsTo("city", "Madrid")
* )
* )
* )
* .buildLookup());
*
* Will limit the expense reports data set such that for all obtained records, the department will always equal "Sales",
* and either the amount will not be lower than 300, or the city will be equal to "Madrid".
* @see org.dashbuilder.dataset.filter.ColumnFilter
* @see org.dashbuilder.dataset.filter.FilterFactory
* @param filter The filters to be applied on the data set's column
* @return The DataSetLookupBuilder instance that is being used to configure a DataSetLookup request.
*/
T filter(ColumnFilter... filter);
/**
* Filter the data set according to the specified column filters. The specified column identifier allows to specify
* column filters without explicitly passing in the column identifier with them, they will simply 'inherit'.
*
* For example:
*
* DataSetFactory.newDataSetLookupBuilder()
* .dataset(EXPENSE_REPORTS)
* .filter("amount",
* AND(
* equalsTo("department", "Sales"),
* OR(
* NOT(lowerThan(300)),
* equalsTo("city", "Madrid")
* )
* )
* )
* .buildLookup());
*
* Will limit the expense reports data set such that for all obtained records, the department will always equal "Sales",
* and either the amount will not be lower than 300, or the city will be equal to "Madrid". Since the lowerThan filter
* does not reference a column, it implicitly refers to the amount column.
* @see org.dashbuilder.dataset.filter.ColumnFilter
* @see org.dashbuilder.dataset.filter.FilterFactory
* @param columnId The identifier of the column that the filter array should be applied on
* @param filter The filters to be applied on the data set's column
* @return The DataSetLookupBuilder instance that is being used to configure a DataSetLookup request.
*/
T filter(String columnId, ColumnFilter... filter);
/**
* Will apply the specified sort order over the indicated data set column.
* @param columnId The identifier of the column that should be sorted.
* @param order The sort order, specified as a String. Accepted values are "asc" and "desc".
* @return The DataSetLookupBuilder instance that is being used to configure a DataSetLookup request.
*/
T sort(String columnId, String order);
/**
* Will apply the specified sort order over the indicated data set column.
* @param columnId The identifier of the column that should be sorted.
* @param order The sort order.
* @see org.dashbuilder.dataset.sort.SortOrder
* @return The DataSetLookupBuilder instance that is being used to configure a DataSetLookup request.
*/
T sort(String columnId, SortOrder order);
/**
* Select the specified column as part of the resulting data set.
*
* @param columnId The identifier of the source column.
* @return The DisplayerSettingsBuilder instance that is being used to configure a DisplayerSettings.
*/
T column(String columnId);
/**
* Select the specified column as part of the resulting data set.
*
* @param columnId The identifier of the source column.
* @param newColumnId A new identifier for the column into the resulting data set.
* @return The DisplayerSettingsBuilder instance that is being used to configure a DisplayerSettings.
*/
T column(String columnId, String newColumnId);
/**
* Generates a new column on the resulting data set by which values will be the result of applying the specified
* aggregation function on the source data set column.
*
* @param columnId The identifier of the source column.
* @param function The AggregationFunction for calculating the column values.
* @return The DisplayerSettingsBuilder instance that is being used to configure a DisplayerSettings.
*/
T column(String columnId, AggregateFunctionType function);
/**
* Generates a new column on the resulting data set by which values will be the result of applying the specified
* aggregation function on the source data set column.
* This variant requires a previous group() method invocation as it's not possible to apply aggregation
* functions on non-grouped data sets.
*
* @param columnId The identifier of the source column.
* @param function The aggregation function for calculating the column values.
* @param newColumnId A new identifier for the column into the resulting data set.
* @return The DisplayerSettingsBuilder instance that is being used to configure a DisplayerSettings.
*/
T column(String columnId, AggregateFunctionType function, String newColumnId);
/**
* Generates a new column on the resulting data set by which values will be the result of applying the specified
* aggregation function on the source data set column.
*
This variant does not require a source column which is fine for some aggregation functions like
* AggregateFunctionType.COUNT
*
* @param function The aggregation function for calculating the column values.
* @param newColumnId A new identifier for the column into the resulting data set.
* @return The DisplayerSettingsBuilder instance that is being used to configure a DisplayerSettings.
*/
T column(AggregateFunctionType function, String newColumnId);
/**
* @return The DataSetLookup request instance that has been configured.
*/
DataSetLookup buildLookup();
}