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

com.flowcentraltech.flowcentral.dashboard.business.DashboardModuleService Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2021-2024 FlowCentral Technologies Limited.
 * 
 * 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.flowcentraltech.flowcentral.dashboard.business;

import java.util.List;

import com.flowcentraltech.flowcentral.dashboard.entities.Dashboard;
import com.flowcentraltech.flowcentral.dashboard.entities.DashboardQuery;
import com.flowcentraltech.flowcentral.common.business.FlowCentralService;
import com.flowcentraltech.flowcentral.common.constants.RecordStatus;
import com.flowcentraltech.flowcentral.dashboard.data.DashboardDef;
import com.tcdng.unify.core.UnifyException;
import com.tcdng.unify.core.data.Listable;

/**
 * Dashboard business service.
 * 
 * @author FlowCentral Technologies Limited
 * @since 1.0
 */
public interface DashboardModuleService extends FlowCentralService {

    /**
     * Clears dashboard cache.
     * 
     * @throws UnifyException
     *                        if an error occurs
     */
    void clearDashboardCache() throws UnifyException;
    
	/**
	 * Finds dashboard by ID.
	 * 
	 * @param dashboardId the dashboard ID
	 * @return the dashboard
	 * @throws UnifyException if dashboard with ID is not found. If an error occurs
	 */
	Dashboard findDashboard(Long dashboardId) throws UnifyException;

	/**
	 * Finds dashboard ID list for application.
	 * 
	 * @param applicationName the application name
	 * @return list of application dashboard IDs
	 * @throws UnifyException if an error occurs
	 */
	List findCustomDashboardIdList(String applicationName) throws UnifyException;

	/**
	 * Gets application dashboard definition.
	 * 
	 * @param dashboardName the dashboard long name
	 * @return the dashboard definition
	 * @throws UnifyException if an error occurs
	 */
	DashboardDef getDashboardDef(String dashboardName) throws UnifyException;

	/**
	 * Updates status of dashboards that match query
	 * 
	 * @param query  the query to use
	 * @param status the status to set
	 * @throws UnifyException if an error occurs
	 */
	void updateDashboardStatus(DashboardQuery query, RecordStatus status) throws UnifyException;

    /**
     * Get dashboard option list.
     * 
     * @param dashboard
     *                          the dashboard long name
     * @return the options list
     * @throws UnifyException if an error occurs
     */
    List getDashboardOptionList(String dashboard) throws UnifyException;

    /**
     * Get dashboard option chart data source list.
     * 
     * @param entity
     *                          the entity
     * @return the chart datasource list
     * @throws UnifyException if an error occurs
     */
    List getDashboardOptionChartDataSourceList(String entity) throws UnifyException;

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy