public class ComponentResourceProvider extends AbstractControllerResourceProvider
AbstractResourceProvider.Command<T>
keyPropertyIds, PROPERTIES_ATTRIBUTES_REGEX
Modifier and Type | Method and Description |
---|---|
void |
createComponents(Set<ServiceComponentRequest> requests) |
protected RequestStatus |
createResourcesAuthorized(Request request)
Create the resources defined by the properties in the given request object if authorization was
granted to the authenticated user.
|
protected RequestStatusResponse |
deleteComponents(Set<ServiceComponentRequest> requests) |
protected RequestStatus |
deleteResourcesAuthorized(Request request,
Predicate predicate)
Delete the resources selected by the given predicate if the authenticated user is authorized
to do so.
|
protected Set<ServiceComponentResponse> |
getComponents(Set<ServiceComponentRequest> requests) |
protected Set<String> |
getPKPropertyIds()
Get the set of property ids that uniquely identify the resources
of this provider.
|
Set<Resource> |
getResources(Request request,
Predicate predicate)
Get a set of
resources based on the given request and predicate
information. |
protected RequestStatusResponse |
updateComponents(Set<ServiceComponentRequest> requests,
Map<String,String> requestProperties,
boolean runSmokeTest) |
RequestStatus |
updateResourcesAuthorized(Request request,
Predicate predicate)
Update the resources selected by the given predicate with the properties from the given request
object if the authenticated user is authorized to do so.
|
getClusterId, getClusterResourceId, getClusterResourceId, getManagementController, getResourceProvider, getResourceProvider, init
createResources, deleteResources, getRequiredCreateAuthorizations, getRequiredDeleteAuthorizations, getRequiredGetAuthorizations, getRequiredUpdateAuthorizations, getResourceId, getResourcesAuthorized, getResourceType, isAuthorizedToCreateResources, isAuthorizedToDeleteResources, isAuthorizedToGetResources, isAuthorizedToUpdateResources, setRequiredCreateAuthorizations, setRequiredDeleteAuthorizations, setRequiredGetAuthorizations, setRequiredUpdateAuthorizations, updateResources
addObserver, createResources, getConfigurationRequests, getKeyPropertyIds, getPropertyMaps, getPropertyMaps, getQueryParameterValue, getRequestStatus, getRequestStatus, getRequestStatus, getResources, modifyResources, notifyCreate, notifyDelete, notifyUpdate, parseProperties, updateObservers
checkCategory, checkConfigPropertyIds, checkPropertyIds, containsArguments, getCategoryIds, getPropertyIds, getRegexEntry, getRegexGroups, getRequestPropertyIds, isPatternKey, isPropertyCategoryRequested, isPropertyEntryRequested, isPropertyRequested, setResourceProperty
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
checkPropertyIds
public static final String SERVICE_COMPONENT_INFO
public static final String CLUSTER_NAME_PROPERTY_ID
public static final String SERVICE_NAME_PROPERTY_ID
public static final String COMPONENT_NAME_PROPERTY_ID
public static final String DISPLAY_NAME_PROPERTY_ID
public static final String STATE_PROPERTY_ID
public static final String CATEGORY_PROPERTY_ID
public static final String TOTAL_COUNT_PROPERTY_ID
public static final String STARTED_COUNT_PROPERTY_ID
public static final String INSTALLED_COUNT_PROPERTY_ID
public static final String INSTALLED_AND_MAINTENANCE_OFF_COUNT_PROPERTY_ID
public static final String INIT_COUNT_PROPERTY_ID
public static final String UNKNOWN_COUNT_PROPERTY_ID
public static final String INSTALL_FAILED_COUNT_PROPERTY_ID
public static final String RECOVERY_ENABLED_PROPERTY_ID
public static final String DESIRED_STACK_PROPERTY_ID
public static final String DESIRED_VERSION_PROPERTY_ID
public static final String REPOSITORY_STATE_PROPERTY_ID
public static final String CLUSTER_NAME
public static final String SERVICE_NAME
public static final String COMPONENT_NAME
public static final String DISPLAY_NAME
public static final String STATE
public static final String CATEGORY
public static final String TOTAL_COUNT
public static final String STARTED_COUNT
public static final String INSTALLED_COUNT
public static final String INSTALLED_AND_MAINTENANCE_OFF_COUNT
public static final String INIT_COUNT
public static final String UNKNOWN_COUNT
public static final String INSTALL_FAILED_COUNT
public static final String RECOVERY_ENABLED
public static final String DESIRED_STACK
public static final String DESIRED_VERSION
public static final String REPOSITORY_STATE
protected RequestStatus createResourcesAuthorized(Request request) throws SystemException, UnsupportedPropertyException, ResourceAlreadyExistsException, NoSuchParentResourceException
AbstractAuthorizedResourceProvider
AbstractAuthorizedResourceProvider.createResources(Request)
is not overwritten.createResourcesAuthorized
in class AbstractAuthorizedResourceProvider
request
- the request object which defines the set of properties for the resources to be createdSystemException
- an internal system exception occurredAuthorizationException
- if the authenticated user is not authorized to perform this operationUnsupportedPropertyException
- the request contains unsupported property idsResourceAlreadyExistsException
- attempted to create a resource which already existsNoSuchParentResourceException
- a parent resource of the resource to create doesn't existAbstractAuthorizedResourceProvider.createResources(Request)
public Set<Resource> getResources(Request request, Predicate predicate) throws SystemException, UnsupportedPropertyException, NoSuchResourceException, NoSuchParentResourceException
AbstractAuthorizedResourceProvider
resources
based on the given request and predicate
information.
Note that it is not required for this resource provider to completely filter
the set of resources based on the given predicate. It may not be possible
since some of the properties involved may be provided by another
provider
. This partial filtering is allowed because
the predicate will always be applied by the calling cluster controller. The
predicate is made available at this level so that some pre-filtering can be done
as an optimization.
A simple implementation of a resource provider may choose to just return all of
the resources of a given type and allow the calling cluster controller to filter
based on the predicate.
This implementation attempts to authorize the authenticated user before performing the requested
operation. If authorization fails, an AuthorizationException will be thrown.
This method may be overwritten by implementing classes to avoid performing authorization checks
to get resources.getResources
in interface ResourceProvider
getResources
in class AbstractAuthorizedResourceProvider
request
- the request object which defines the desired set of propertiespredicate
- the predicate object which can be used to filter which
resources are returnedSystemException
- an internal system exception occurredAuthorizationException
- if the authenticated user is not authorized to perform this operationUnsupportedPropertyException
- the request contains unsupported property idsNoSuchResourceException
- the requested resource instance doesn't existNoSuchParentResourceException
- a parent resource of the requested resource doesn't existpublic RequestStatus updateResourcesAuthorized(Request request, Predicate predicate) throws SystemException, UnsupportedPropertyException, NoSuchResourceException, NoSuchParentResourceException
AbstractAuthorizedResourceProvider
AbstractAuthorizedResourceProvider.updateResources(Request, Predicate)
is not overwritten.updateResourcesAuthorized
in class AbstractAuthorizedResourceProvider
request
- the request object which defines the set of properties for the resources to be updatedpredicate
- the predicate object which can be used to filter which resources are updatedSystemException
- an internal system exception occurredAuthorizationException
- if the authenticated user is not authorized to perform this operationUnsupportedPropertyException
- the request contains unsupported property idsNoSuchResourceException
- the resource instance to be updated doesn't existNoSuchParentResourceException
- a parent resource of the resource doesn't existAbstractAuthorizedResourceProvider.updateResources(Request, Predicate)
protected RequestStatus deleteResourcesAuthorized(Request request, Predicate predicate) throws SystemException, UnsupportedPropertyException, NoSuchResourceException, NoSuchParentResourceException
AbstractAuthorizedResourceProvider
ResourceProvider.deleteResources(Request, Predicate)
is not overwritten.deleteResourcesAuthorized
in class AbstractAuthorizedResourceProvider
predicate
- the predicate object which can be used to filter which resources are deletedSystemException
- an internal system exception occurredAuthorizationException
- if the authenticated user is not authorized to perform this operationUnsupportedPropertyException
- the request contains unsupported property idsNoSuchResourceException
- the resource instance to be deleted doesn't existNoSuchParentResourceException
- a parent resource of the resource doesn't existResourceProvider.deleteResources(Request, Predicate)
protected Set<String> getPKPropertyIds()
AbstractResourceProvider
getPKPropertyIds
in class AbstractResourceProvider
public void createComponents(Set<ServiceComponentRequest> requests) throws org.apache.ambari.server.AmbariException, AuthorizationException
org.apache.ambari.server.AmbariException
AuthorizationException
protected Set<ServiceComponentResponse> getComponents(Set<ServiceComponentRequest> requests) throws org.apache.ambari.server.AmbariException
org.apache.ambari.server.AmbariException
protected RequestStatusResponse updateComponents(Set<ServiceComponentRequest> requests, Map<String,String> requestProperties, boolean runSmokeTest) throws org.apache.ambari.server.AmbariException, AuthorizationException
org.apache.ambari.server.AmbariException
AuthorizationException
protected RequestStatusResponse deleteComponents(Set<ServiceComponentRequest> requests) throws org.apache.ambari.server.AmbariException, AuthorizationException
org.apache.ambari.server.AmbariException
AuthorizationException
Copyright © 2022 Apache Software Foundation. All rights reserved.