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

com.gooddata.sdk.service.GoodData Maven / Gradle / Ivy

/*
 * (C) 2023 GoodData Corporation.
 * This source code is licensed under the BSD-style license found in the
 * LICENSE.txt file in the root directory of this source tree.
 */
package com.gooddata.sdk.service;

import com.gooddata.sdk.service.account.AccountService;
import com.gooddata.sdk.service.auditevent.AuditEventService;
import com.gooddata.sdk.service.hierarchicalconfig.HierarchicalConfigService;
import com.gooddata.sdk.service.connector.ConnectorService;
import com.gooddata.sdk.service.dataload.OutputStageService;
import com.gooddata.sdk.service.dataload.processes.ProcessService;
import com.gooddata.sdk.service.dataset.DatasetService;
import com.gooddata.sdk.service.executeafm.ExecuteAfmService;
import com.gooddata.sdk.service.export.ExportService;
import com.gooddata.sdk.service.featureflag.FeatureFlagService;
import com.gooddata.sdk.service.gdc.DataStoreService;
import com.gooddata.sdk.service.gdc.GdcService;
import com.gooddata.sdk.service.httpcomponents.LoginPasswordGoodDataRestProvider;
import com.gooddata.sdk.service.lcm.LcmService;
import com.gooddata.sdk.service.md.MetadataService;
import com.gooddata.sdk.service.md.maintenance.ExportImportService;
import com.gooddata.sdk.service.notification.NotificationService;
import com.gooddata.sdk.service.project.ProjectService;
import com.gooddata.sdk.service.project.model.ModelService;
import com.gooddata.sdk.service.projecttemplate.ProjectTemplateService;
import com.gooddata.sdk.service.warehouse.WarehouseService;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;

import static com.gooddata.sdk.service.GoodDataEndpoint.*;
import static com.gooddata.sdk.common.util.Validate.notNull;

/**
 * Entry point for GoodData SDK usage.
 * 

* Configure connection to GoodData using one of constructors. One can then get initialized service he needs from * the newly constructed instance. This instance can be also used later for logout from GoodData Platform. *

* Usage example: *


 *     GoodData gd = new GoodData("[email protected]", "Roman1");
 *     // do something useful like: gd.getSomeService().doSomething()
 *     gd.logout();
 * 
*/ public class GoodData { private final GoodDataServices services; /** * Create instance configured to communicate with GoodData Platform under user with given credentials. * * @param login GoodData user's login * @param password GoodData user's password */ public GoodData(String login, String password) { this(HOSTNAME, login, password, new GoodDataSettings()); } /** * Create instance configured to communicate with GoodData Platform under user with given credentials. * * @param login GoodData user's login * @param password GoodData user's password * @param settings additional settings */ public GoodData(String login, String password, GoodDataSettings settings) { this(HOSTNAME, login, password, settings); } /** * Create instance configured to communicate with GoodData Platform running on given host using given user's * credentials. * * @param hostname GoodData Platform's host name (e.g. secure.gooddata.com) * @param login GoodData user's login * @param password GoodData user's password */ public GoodData(String hostname, String login, String password) { this(hostname, login, password, PORT, PROTOCOL, new GoodDataSettings()); } /** * Create instance configured to communicate with GoodData Platform running on given host using given user's * credentials. * * @param hostname GoodData Platform's host name (e.g. secure.gooddata.com) * @param login GoodData user's login * @param password GoodData user's password * @param settings additional settings */ public GoodData(String hostname, String login, String password, GoodDataSettings settings) { this(hostname, login, password, PORT, PROTOCOL, settings); } /** * Create instance configured to communicate with GoodData Platform running on given host and port using given user's * credentials. * * @param hostname GoodData Platform's host name (e.g. secure.gooddata.com) * @param login GoodData user's login * @param password GoodData user's password * @param port GoodData Platform's API port (e.g. 443) */ public GoodData(String hostname, String login, String password, int port) { this(hostname, login, password, port, PROTOCOL, new GoodDataSettings()); } /** * Create instance configured to communicate with GoodData Platform running on given host and port using given user's * credentials. * * @param hostname GoodData Platform's host name (e.g. secure.gooddata.com) * @param login GoodData user's login * @param password GoodData user's password * @param port GoodData Platform's API port (e.g. 443) * @param settings additional settings */ public GoodData(String hostname, String login, String password, int port, GoodDataSettings settings) { this(hostname, login, password, port, PROTOCOL, settings); } /** * Create instance configured to communicate with GoodData Platform running on given host, port and protocol using * given user's credentials. * * @param hostname GoodData Platform's host name (e.g. secure.gooddata.com) * @param login GoodData user's login * @param password GoodData user's password * @param port GoodData Platform's API port (e.g. 443) * @param protocol GoodData Platform's API protocol (e.g. https) * @param settings additional settings */ public GoodData(String hostname, String login, String password, int port, String protocol, GoodDataSettings settings) { this(new LoginPasswordGoodDataRestProvider( new GoodDataEndpoint(hostname, port, protocol), settings, login, password )); } /** * Create instance based on given {@link GoodDataRestProvider}. * @param goodDataRestProvider configured provider */ protected GoodData(final GoodDataRestProvider goodDataRestProvider) { this.services = new GoodDataServices(notNull(goodDataRestProvider, "goodDataRestProvider")); } /** * @return underlying RestTemplate */ protected RestTemplate getRestTemplate() { return services.getRestTemplate(); } /** * Logout from GoodData Platform */ public void logout() { getAccountService().logout(); } /** * Get initialized service for project management (to list projects, create a project, ...) * * @return initialized service for project management */ @Bean("goodDataProjectService") public ProjectService getProjectService() { return services.getProjectService(); } /** * Get initialized service for account management (to get current account information, logout, ...) * * @return initialized service for account management */ @Bean("goodDataAccountService") public AccountService getAccountService() { return services.getAccountService(); } /** * Get initialized service for metadata management (to query, create and update project metadata like attributes, * facts, metrics, reports, ...) * * @return initialized service for metadata management */ @Bean("goodDataMetadataService") public MetadataService getMetadataService() { return services.getMetadataService(); } /** * Get initialized service for model management (to get model diff, update model, ...) * * @return initialized service for model management */ @Bean("goodDataModelService") public ModelService getModelService() { return services.getModelService(); } /** * Get initialized service for API root management (to get API root links, ...) * * @return initialized service for API root management */ @Bean("goodDataGdcService") public GdcService getGdcService() { return services.getGdcService(); } /** * Get initialized service for data store (user staging/WebDAV) management (to upload, download, delete, ...) * * @return initialized service for data store management */ @Bean("goodDataDataStoreService") public DataStoreService getDataStoreService() { return services.getDataStoreService(); } /** * Get initialized service for dataset management (to list manifest, get datasets, load dataset, ...) * * @return initialized service for dataset management */ @Bean("goodDataDatasetService") public DatasetService getDatasetService() { return services.getDatasetService(); } /** * Get initialized service for exports management (export report,...) * * @return initialized service for exports */ @Bean("goodDataExportService") public ExportService getExportService() { return services.getExportService(); } /** * Get initialized service for dataload processes management and process executions. * * @return initialized service for dataload processes management and process executions */ @Bean("goodDataProcessService") public ProcessService getProcessService() { return services.getProcessService(); } /** * Get initialized service for ADS management (create, access and delete ads instances). * * @return initialized service for ADS management */ @Bean("goodDataWarehouseService") public WarehouseService getWarehouseService() { return services.getWarehouseService(); } /** * Get initialized service for connector integration management (create, update, start process, ...). * * @return initialized service for connector integration management */ @Bean("goodDataConnectorService") public ConnectorService getConnectorService() { return services.getConnectorService(); } /** * Get initialized service for project notifications management. * * @return initialized service for project notifications management */ @Bean("goodDataNotificationService") public NotificationService getNotificationService() { return services.getNotificationService(); } /** * Get initialized service for metadata export/import. * * @return initialized service for metadata export/import */ @Bean("goodDataExportImportService") public ExportImportService getExportImportService() { return services.getExportImportService(); } /** * Get initialized service for feature flag management. * * @return initialized service for feature flag management * @deprecated Use {@link HierarchicalConfigService} instead. */ @Deprecated @Bean("goodDataFeatureFlagService") public FeatureFlagService getFeatureFlagService() { return services.getFeatureFlagService(); } /** * Get initialized service for output stage management. * * @return initialized service for output stage management */ @Bean("goodDataOutputStageService") public OutputStageService getOutputStageService() { return services.getOutputStageService(); } /** * Get initialized service for project templates * * @return initialized service for project templates * * @deprecated The project templates are deprecated and stopped working on May 15, 2019. * See https://support.gooddata.com/hc/en-us/articles/360016126334-April-4-2019 * Deprecated since version 3.0.1. Will be removed in one of future versions. */ @Deprecated @Bean("goodDataProjectTemplateService") public ProjectTemplateService getProjectTemplateService() { return services.getProjectTemplateService(); } /** * Get initialized service for audit events * @return initialized service for audit events */ @Bean("goodDataAuditEventService") public AuditEventService getAuditEventService() { return services.getAuditEventService(); } /** * Get initialized service for afm execution * @return initialized service for afm execution */ @Bean("goodDataExecuteAfmService") public ExecuteAfmService getExecuteAfmService() { return services.getExecuteAfmService(); } /** * Get initialized service for Life Cycle Management * @return initialized service for Life Cycle Management */ @Bean("goodDataLcmService") public LcmService getLcmService() { return services.getLcmService(); } /** * Get initialized service for hierarchical config management * @return hierarchical config service */ @Bean("goodDataHierarchicalConfigService") public HierarchicalConfigService getHierarchicalConfigService() { return services.getHierarchicalConfigService(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy