Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/* SPDX-License-Identifier: Apache 2.0 */
/* Copyright Contributors to the ODPi Egeria project. */
package org.odpi.openmetadata.commonservices.generichandlers;
import org.odpi.openmetadata.frameworks.connectors.ffdc.InvalidParameterException;
import org.odpi.openmetadata.repositoryservices.connectors.stores.metadatacollectionstore.properties.instances.InstanceProperties;
import org.odpi.openmetadata.repositoryservices.connectors.stores.metadatacollectionstore.repositoryconnector.OMRSRepositoryHelper;
import org.odpi.openmetadata.repositoryservices.ffdc.exception.TypeErrorException;
import java.util.Date;
/**
* ITInfrastructureBuilder provides the builder functions for classifications and relationships.
*/
public class ITInfrastructureBuilder extends OpenMetadataAPIGenericBuilder
{
/**
* Create constructor
*
* @param repositoryHelper helper methods
* @param serviceName name of this OMAS
* @param serverName name of local server
*/
ITInfrastructureBuilder(OMRSRepositoryHelper repositoryHelper,
String serviceName,
String serverName)
{
super(OpenMetadataAPIMapper.IT_INFRASTRUCTURE_TYPE_GUID,
OpenMetadataAPIMapper.IT_INFRASTRUCTURE_TYPE_NAME,
repositoryHelper,
serviceName,
serverName);
}
/**
* Return the supplied bean properties in an InstanceProperties object.
*
* @param methodName name of the calling method
* @return InstanceProperties object
* @throws InvalidParameterException there is a problem with the properties
*/
@Override
public InstanceProperties getInstanceProperties(String methodName) throws InvalidParameterException
{
return super.getInstanceProperties(methodName);
}
/**
* Return the bean properties describing a the link between a host and a software server platform in an InstanceProperties object.
*
* @param deploymentTime date/time that the capability was deployed
* @param deployer user who issued the deploy command
* @param platformStatus operational status of the platform
* @param methodName name of the calling method
* @throws InvalidParameterException there is a problem with the properties
* @return InstanceProperties object
*/
InstanceProperties getSoftwareServerPlatformDeploymentProperties(Date deploymentTime,
String deployer,
int platformStatus,
String methodName) throws InvalidParameterException
{
InstanceProperties properties;
properties = repositoryHelper.addDatePropertyToInstance(serviceName,
null,
OpenMetadataAPIMapper.DEPLOYMENT_TIME_PROPERTY_NAME,
deploymentTime,
methodName);
properties = repositoryHelper.addStringPropertyToInstance(serviceName,
properties,
OpenMetadataAPIMapper.DEPLOYER_PROPERTY_NAME,
deployer,
methodName);
try
{
return repositoryHelper.addEnumPropertyToInstance(serviceName,
properties,
OpenMetadataAPIMapper.PLATFORM_STATUS_PROPERTY_NAME,
OpenMetadataAPIMapper.OPERATIONAL_STATUS_ENUM_TYPE_GUID,
OpenMetadataAPIMapper.OPERATIONAL_STATUS_ENUM_TYPE_NAME,
platformStatus,
methodName);
}
catch (TypeErrorException error)
{
throw new InvalidParameterException(error, OpenMetadataAPIMapper.PLATFORM_STATUS_PROPERTY_NAME);
}
}
/**
* Return the bean properties describing a the link between a host and a software server platform in an InstanceProperties object.
*
* @param deploymentTime date/time that the capability was deployed
* @param deployer user who issued the deploy command
* @param serverStatus operational status of the platform
* @param methodName name of the calling method
* @throws InvalidParameterException there is a problem with the properties
* @return InstanceProperties object
*/
InstanceProperties getSoftwareServerDeploymentProperties(Date deploymentTime,
String deployer,
int serverStatus,
String methodName) throws InvalidParameterException
{
InstanceProperties properties;
properties = repositoryHelper.addDatePropertyToInstance(serviceName,
null,
OpenMetadataAPIMapper.DEPLOYMENT_TIME_PROPERTY_NAME,
deploymentTime,
methodName);
properties = repositoryHelper.addStringPropertyToInstance(serviceName,
properties,
OpenMetadataAPIMapper.DEPLOYER_PROPERTY_NAME,
deployer,
methodName);
try
{
return repositoryHelper.addEnumPropertyToInstance(serviceName,
properties,
OpenMetadataAPIMapper.SERVER_STATUS_PROPERTY_NAME,
OpenMetadataAPIMapper.OPERATIONAL_STATUS_ENUM_TYPE_GUID,
OpenMetadataAPIMapper.OPERATIONAL_STATUS_ENUM_TYPE_NAME,
serverStatus,
methodName);
}
catch (TypeErrorException error)
{
throw new InvalidParameterException(error, OpenMetadataAPIMapper.SERVER_STATUS_PROPERTY_NAME);
}
}
/**
* Return the bean properties describing a the link between a software server and a software server capability in an InstanceProperties object.
*
* @param deploymentTime date/time that the capability was deployed
* @param deployer user who issued the deploy command
* @param serverCapabilityStatus operational status of the capability
* @param methodName name of the calling method
* @throws InvalidParameterException there is a problem with the properties
* @return InstanceProperties object
*/
InstanceProperties getSoftwareServerSupportedCapabilitiesProperties(Date deploymentTime,
String deployer,
int serverCapabilityStatus,
String methodName) throws InvalidParameterException
{
InstanceProperties properties;
properties = repositoryHelper.addDatePropertyToInstance(serviceName,
null,
OpenMetadataAPIMapper.DEPLOYMENT_TIME_PROPERTY_NAME,
deploymentTime,
methodName);
properties = repositoryHelper.addStringPropertyToInstance(serviceName,
properties,
OpenMetadataAPIMapper.DEPLOYER_PROPERTY_NAME,
deployer,
methodName);
try
{
return repositoryHelper.addEnumPropertyToInstance(serviceName,
properties,
OpenMetadataAPIMapper.SERVER_CAPABILITY_STATUS_PROPERTY_NAME,
OpenMetadataAPIMapper.OPERATIONAL_STATUS_ENUM_TYPE_GUID,
OpenMetadataAPIMapper.OPERATIONAL_STATUS_ENUM_TYPE_NAME,
serverCapabilityStatus,
methodName);
}
catch (TypeErrorException error)
{
throw new InvalidParameterException(error, OpenMetadataAPIMapper.SERVER_CAPABILITY_STATUS_PROPERTY_NAME);
}
}
/**
* Return the bean properties describing a the link between a software server and a software server capability in an InstanceProperties object.
*
* @param description description of the use
* @param useType server asset use type
* @param methodName name of the calling method
* @throws InvalidParameterException there is a problem with the properties
* @return InstanceProperties object
*/
InstanceProperties getSoftwareServerCapabilitiesAssetUseProperties(String description,
int useType,
String methodName) throws InvalidParameterException
{
InstanceProperties properties;
properties = repositoryHelper.addStringPropertyToInstance(serviceName,
null,
OpenMetadataAPIMapper.DESCRIPTION_PROPERTY_NAME,
description,
methodName);
try
{
return repositoryHelper.addEnumPropertyToInstance(serviceName,
properties,
OpenMetadataAPIMapper.USE_TYPE_PROPERTY_NAME,
OpenMetadataAPIMapper.SERVER_ASSET_USE_TYPE_TYPE_GUID,
OpenMetadataAPIMapper.SERVER_ASSET_USE_TYPE_TYPE_NAME,
useType,
methodName);
}
catch (TypeErrorException error)
{
throw new InvalidParameterException(error, OpenMetadataAPIMapper.USE_TYPE_PROPERTY_NAME);
}
}
/**
* Return the bean properties describing a cloud provider in an InstanceProperties object.
*
* @param providerName name of the cloud provider
* @param methodName name of the calling method
* @return InstanceProperties object
*/
InstanceProperties getCloudProviderProperties(String providerName,
String methodName)
{
return repositoryHelper.addStringPropertyToInstance(serviceName,
null,
OpenMetadataAPIMapper.PROVIDER_NAME_PROPERTY_NAME,
providerName,
methodName);
}
/**
* Return the bean properties describing a cloud platform in an InstanceProperties object.
*
* @param implementationType type of cloud platform implementation
* @param methodName name of the calling method
* @return InstanceProperties object
*/
InstanceProperties getCloudPlatformProperties(String implementationType,
String methodName)
{
return repositoryHelper.addStringPropertyToInstance(serviceName,
null,
OpenMetadataAPIMapper.DEPLOYED_IMPLEMENTATION_TYPE_PROPERTY_NAME,
implementationType,
methodName);
}
/**
* Return the bean properties describing a Cloud Tenant in an InstanceProperties object.
*
* @param tenantName name of the tenant
* @param tenantType type of tenant
* @param methodName name of the calling method
* @return InstanceProperties object
*/
InstanceProperties getCloudTenantProperties(String tenantName,
String tenantType,
String methodName)
{
InstanceProperties properties;
properties = repositoryHelper.addStringPropertyToInstance(serviceName,
null,
OpenMetadataAPIMapper.TENANT_NAME_PROPERTY_NAME,
tenantName,
methodName);
properties = repositoryHelper.addStringPropertyToInstance(serviceName,
properties,
OpenMetadataAPIMapper.TENANT_TYPE_PROPERTY_NAME,
tenantType,
methodName);
return properties;
}
/**
* Return the bean properties describing a Cloud Service in an InstanceProperties object.
*
* @param offeringName name of the service
* @param serviceType type of service
* @param methodName name of the calling method
* @return InstanceProperties object
*/
InstanceProperties getCloudServiceProperties(String offeringName,
String serviceType,
String methodName)
{
InstanceProperties properties;
properties = repositoryHelper.addStringPropertyToInstance(serviceName,
null,
OpenMetadataAPIMapper.OFFERING_NAME_PROPERTY_NAME,
offeringName,
methodName);
properties = repositoryHelper.addStringPropertyToInstance(serviceName,
properties,
OpenMetadataAPIMapper.SERVICE_TYPE_PROPERTY_NAME,
serviceType,
methodName);
return properties;
}
}