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

com.sap.cds.services.mt.SaasRegistrySubscriptionOptions Maven / Gradle / Ivy

There is a newer version: 3.6.0
Show newest version
/**************************************************************************
 * (C) 2019-2024 SAP SE or an SAP affiliate company. All rights reserved. *
 **************************************************************************/
package com.sap.cds.services.mt;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

import com.sap.cds.CdsData;
import com.sap.cds.Struct;

/**
 * This interface provides named and type safe access to the {@link HashMap options} provided by
 * {@link SubscribeEventContext#getOptions() }.
 */
// see https://cp-control-client-uc2.cfapps.sap.hana.ondemand.com/index.html#/knowledge_center/articles/2316430f7d804820934910db736cefbf
public interface SaasRegistrySubscriptionOptions extends CdsData {

	/**
	 * Creates a new {@link SaasRegistrySubscriptionOptions}
	 * @return the {@link SaasRegistrySubscriptionOptions}
	 */
	static SaasRegistrySubscriptionOptions create() {
		return Struct.create(SaasRegistrySubscriptionOptions.class);
	}

	/**
	 * Creates a {@link SaasRegistrySubscriptionOptions} view over an existing options map.
	 * @param options the options map
	 * @return the {@link SaasRegistrySubscriptionOptions} view
	 */
	static SaasRegistrySubscriptionOptions create(Map options) {
		return Struct.access(options).as(SaasRegistrySubscriptionOptions.class);
	}

	/**
	 * Unique identifier of the subscription.
	 *
	 * @return unique identifier of the subscription.
	 */
	String getSubscriptionGUID();

	/**
	 * The application ID of the main subscribed application. Generated by XSUAA based on the xsappname.
	 *
	 * @return the application ID of the main subscribed application.
	 */
	String getSubscriptionAppId();

	/**
	 * The name of the main subscribed application, in the SaaS Provisioning.
	 *
	 * @return the name of the main subscribed application, in the SaaS Provisioning.
	 */
	String getSubscriptionAppName();

	/**
	 * The ID of the subscribed consumer XSUAA tenant.
	 *
	 * @return the ID of the subscribed consumer XSUAA tenant.
	 */
	String getSubscribedTenantId();

	/**
	 * The ID of the subscribed consumer zone. This field might be missing for subaccounts that were created before the
	 * Zone ID was introduced.
	 *
	 * @return The ID of the subscribed consumer zone.
	 */
	String getSubscribedZoneId();

	/**
	 * The License Type of the subscription consumer tenant. Values: UNDEFINED | CONSUMER | DEVELOPER | CUSTOMER |
	 * PARTNER | SAPDEV | SAPPROD | CUSTOMER_BETA | SYSTEM | SFSF_EXT_EVAL | TRIAL.
	 *
	 * @return The License Type of the subscription consumer tenant.
	 */
	String getSubscribedLicenseType();

	/**
	 * The CRM ID of the customer whose global account and subaccount triggered the subscription.
	 *
	 * @return The CRM ID of the customer whose global account and subaccount triggered the subscription.
	 */
	String getSubscribedCrmId();

	/**
	 * The Subdomain of the subscription consumer tenant (hostname for the identityzone).
	 *
	 * @return The Subdomain of the subscription consumer tenant (hostname for the identityzone).
	 */
	String getSubscribedSubdomain();

	/**
	 * The ID of the subaccount related to the consumer tenant.
	 *
	 * @return The ID of the subaccount related to the consumer tenant.
	 */
	String getSubscribedSubaccountId();

	/**
	 * The plan of the main subscribed application, as defined in CIS. If the app is not registered in the CIS catalog,
	 * or if the subscription flow is part of the "Stack Services", the subscriptionAppPlan would be null.
	 *
	 * @return The plan of the main subscribed application or null.
	 */
	String getSubscriptionAppPlan();

	/**
	 * The Amount that the customer is entitled to, in CIS.
	 *
	 * @return The Amount that the customer is entitled to.
	 */
	Integer getSubscriptionAppAmount();

	/**
	 * The List of App IDs, generated and returned by XSUAA when creating a subscription of a service instance (aka
	 * cloning). The App ID is a combination of some prefix and client ID of the subscribed service instance. This is
	 * relevant only for the PaaS Multitenancy scenario (aka stack services), therefore this list will be empty for SaaS
	 * applications.
	 *
	 * @return The List of App IDs, generated and returned by XSUAA when creating a subscription of a service instance.
	 */
	List getDependentServiceInstanceAppIds();

	/**
	 * Indicates if the callback called with new subscription (CREATE), or as part of an update dependencies call
	 * (UPDATE), or as part of a context/parameters update (CONTEXT_CHANGE/UPDATE_PARAMETERS).
	 *
	 * @return the event type.
	 */
	String getEventType();

	/**
	 * The ID of the subscribed consumer global account.
	 *
	 * @return The ID of the subscribed consumer global account.
	 */
	String getGlobalAccountGUID();

	/**
	 * The subaccount ID from which this app is provided.
	 *
	 * @return the subaccount ID from which this app is provided.
	 */
	String getProviderSubaccountId();

	/**
	 * The ID of the user who triggered the subscription from the cockpit (can be a clientId in case of client
	 * credentials flow).
	 *
	 * @return The ID of the user who triggered the subscription from the cockpit.
	 */
	String getUserId();

	/**
	 * This section may contain additional information on the user that triggered the subscription. This field is only
	 * relevant for accounts with "feature set B". If you use an account with "feature set A" this field does not exist.
	 *
	 * @return additional information on the user that triggered the subscription or null.
	 */
	SaasRegistryTriggeredByInfo getUserInfo();

	/**
	 * The parameters entered by the user upon subscription to your app.
	 *
	 * @return The parameters entered by the user upon subscription to your app.
	 */
	Map getSubscriptionParams();

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy