Package org.forgerock.openig.heap
Class GenericHeaplet
- java.lang.Object
-
- org.forgerock.openig.heap.GenericHeaplet
-
- All Implemented Interfaces:
Heaplet
- Direct Known Subclasses:
AbstractSamlFederationHeaplet,AbstractScriptableHeapObject.AbstractScriptableHeaplet,AllowOnlyFilter.Heaplet,AmServiceHeaplet,AmSessionIdleTimeoutFilter.Heaplet,AssignmentFilter.Heaplet,AuditServiceObjectHeaplet,Base64EncodedSecretStore.Heaplet,CaffeineCacheAccessTokenResolver.Heaplet,CapturedUserPasswordFilter.Heaplet,CertificateThumbprintFilter.Heaplet,ChainFilterHeaplet,ChainHandlerHeaplet,CircuitBreakerFilter.Heaplet,ClientCredentialsOAuth2ClientFilterHeaplet,ClientRegistration.Heaplet,ClientSecretBasicAuthenticationFilterHeaplet,ClientSecretPostAuthenticationFilterHeaplet,ClientTlsOptionsHeaplet,ConditionalFilterHeaplet,ConditionEnforcementFilter.Heaplet,ConfirmationKeyVerifierAccessTokenResolver.Heaplet,CookieFilter.Heaplet,CorsFilterHeaplet,CrossDomainSingleSignOnFilter.Heaplet,CryptoHeaderFilter.Heaplet,CsrfFilterHeaplet,CustomProxyOptions.Heaplet,DataPreservationFilter.Heaplet,DateHeaderFilter.Heaplet,DefaultRateThrottlingPolicyHeaplet,DelegateHeaplet,DesKeyGenHandler.Heaplet,DispatchHandler.Heaplet,EntityExtractFilter.Heaplet,FapiInteractionIdFilter.Heaplet,FileAttributesFilter.Heaplet,FileSystemSecretStoreHeaplet,ForwardedRequestFilter.Heaplet,FragmentFilter.Heaplet,GrantSwapJwtAssertionOAuth2ClientFilter.Heaplet,HeaderFilter.Heaplet,HsmSecretStoreHeaplet,HttpBasicAuthenticationClientFilterHeaplet,HttpBasicAuthFilter.Heaplet,HttpClientHandlerHeaplet,IdentityAssertionHandlerTechPreview.Heaplet,Issuer.Heaplet,IssuerRepository.Heaplet,JdbcDataSourceHeaplet,JwkPropertyFormatHeaplet,JwkSetHandler.Heaplet,JwkSetSecretStoreHeaplet,JwtBuilderFilter.Heaplet,JwtSessionFilterHeaplet,JwtValidationFilter.Heaplet,KeyManagerHeaplet,KeyStoreHeaplet,KeyStoreSecretStoreHeaplet,LocationHeaderFilter.Heaplet,MappedThrottlingPolicyHeaplet,NoOpAuditService.Heaplet,NoProxyOptions.Heaplet,OAuth2ClientFilter.Heaplet,OAuth2ResourceServerFilterHeaplet,OAuth2TokenExchangeFilter.Heaplet,OpenAmAccessTokenResolverHeaplet,PasswordReplayFilterHeaplet,PemPropertyFormatHeaplet,PolicyEnforcementFilter.Heaplet,PrivateKeyJwtClientAuthenticationFilterHeaplet,RequestResourceUriProvider.Heaplet,ResourceHandler.Heaplet,ResourceOwnerOAuth2ClientFilterHeaplet,RouterHandler.Heaplet,ScheduledExecutorServiceHeaplet,SecretKeyPropertyFormatHeaplet,SecretsKeyManagerHeaplet,SecretsProviderHeaplet,SecretsTrustManagerHeaplet,SequenceHandler.Heaplet,ServerTlsOptionsHeaplet,SessionInfoFilter.Heaplet,SetCookieUpdateFilter.Heaplet,SingleSignOnFilter.Heaplet,SqlAttributesFilter.Heaplet,StatelessAccessTokenResolver.Heaplet,StaticRequestFilter.Heaplet,StaticResponseHandler.Heaplet,SwitchFilter.Heaplet,SystemAndEnvSecretStoreHeaplet,SystemProxyOptions.Heaplet,TemporaryStorageHeaplet,ThrottlingFilterHeaplet,TokenIntrospectionAccessTokenResolverHeaplet,TokenTransformationFilter.Heaplet,TrustAllManager.Heaplet,TrustManagerHeaplet,UmaResourceServerFilter.Heaplet,UmaSharingService.Heaplet,UriPathRewriteFilter.Heaplet,UserProfileFilterHeaplet,UserProfileServiceHeaplet,WelcomeHandler.Heaplet
public abstract class GenericHeaplet extends Object implements Heaplet
A generic base class for heaplets with automatically injected fields.
-
-
Field Summary
Fields Modifier and Type Field Description protected JsonValueconfigThe heaplet's object configuration object.protected HeapheapWhere objects should be put and where object dependencies should be retrieved.protected StringnameThe name of the object to be created and stored in the heap by this heaplet.protected ObjectobjectThe object created by the heaplet'screate()method.protected NamequalifiedThe fully qualified name of the object to be created.
-
Constructor Summary
Constructors Constructor Description GenericHeaplet()
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Deprecated Methods Modifier and Type Method Description abstract Objectcreate()Called to request the heaplet create an object.Objectcreate(Name name, JsonValue config, Heap heap)Called to request the heaplet to create an object.voiddestroy()Called to indicate that the object created by the heaplet is going to be dereferenced.protected EndpointRegistryendpointRegistry()Returns this object'sEndpointRegistry, creating it lazily when requested for the first time.Function<JsonValue,JsonValue,JsonValueException>evaluatedWithHeapProperties()Returns a function that will evaluate the expression hold by aJsonValueusing the properties defined in the heap of this Heaplet.protected <T> Function<JsonValue,Expression<T>,JsonValueException>expression(Class<T> type)Returns a function that will create anExpressionfrom the string by theJsonValueusing the bindings defined in the heap of this Heaplet as initial bindings.JsonValuegetConfig()Returns the config associated to thatHeaplet.HeapgetHeap()Returns the heap associated to thatHeaplet.SecretsServicegetSecretService()Deprecated.UseSecretsProviderinstead.SecretsProvidergetSecretsProvider()Returns theSecretsProviderfrom the heap.protected StringgetType()Returns the type of the IG object.protected BindingsinitialBindings()Return an initial set of bindings based on the heap properties, along with any utility items from the heap, such as the clock.protected org.forgerock.monitoring.api.instrument.MeterRegistryHoldermeterRegistryHolder()Returns this object'sMeterRegistry, creating it lazily when requested for the first time.voidstart()Called to request the heaplet start an object.
-
-
-
Field Detail
-
name
protected String name
The name of the object to be created and stored in the heap by this heaplet.
-
qualified
protected Name qualified
The fully qualified name of the object to be created.
-
config
protected JsonValue config
The heaplet's object configuration object.
-
heap
protected Heap heap
Where objects should be put and where object dependencies should be retrieved.
-
-
Method Detail
-
create
public Object create(Name name, JsonValue config, Heap heap) throws HeapException
Description copied from interface:HeapletCalled to request the heaplet to create an object.- Specified by:
createin interfaceHeaplet- Parameters:
name- the name of the object to be created.config- the heaplet's configuration object.heap- the heap where object dependencies can be retrieved.- Returns:
- the object created by the heaplet.
- Throws:
HeapException- if an exception occurred during creation of the object or any of its dependencies.
-
endpointRegistry
protected EndpointRegistry endpointRegistry() throws HeapException
Returns this object'sEndpointRegistry, creating it lazily when requested for the first time.- Returns:
- this object's
EndpointRegistry(/objects/[name]) - Throws:
HeapException- should never be thrown
-
meterRegistryHolder
protected org.forgerock.monitoring.api.instrument.MeterRegistryHolder meterRegistryHolder() throws HeapExceptionReturns this object'sMeterRegistry, creating it lazily when requested for the first time.- Returns:
- this object's
MeterRegistry - Throws:
HeapException- should never be thrown
-
getType
protected String getType()
Returns the type of the IG object.- Returns:
- the type of the IG object
-
destroy
public void destroy()
Description copied from interface:HeapletCalled to indicate that the object created by the heaplet is going to be dereferenced. This gives the heaplet an opportunity to free any resources that are being held prior to its dereference.
-
create
public abstract Object create() throws HeapException
Called to request the heaplet create an object. Called byHeaplet.create(Name, JsonValue, Heap)after initializing the protected field members. Implementations should parse configuration but not acquire resources, start threads, or log any initialization messages. These tasks should be performed by thestart()method.- Returns:
- The created object.
- Throws:
HeapException- if an exception occurred during creation of the heap object or any of its dependencies.JsonValueException- if the heaplet (or one of its dependencies) has a malformed configuration.
-
start
public void start() throws HeapExceptionCalled to request the heaplet start an object. Called byHeaplet.create(Name, JsonValue, Heap)after creating and configuring the object and once the object's logger and storage have been configured. Implementations should override this method if they need to acquire resources, start threads, or log any initialization messages.- Throws:
HeapException- if an exception occurred while starting the heap object or any of its dependencies.
-
evaluatedWithHeapProperties
public Function<JsonValue,JsonValue,JsonValueException> evaluatedWithHeapProperties()
Returns a function that will evaluate the expression hold by aJsonValueusing the properties defined in the heap of this Heaplet.- Returns:
- a function that will evaluate the expression hold by a
JsonValueusing the properties defined in the heap of this Heaplet.
-
expression
protected <T> Function<JsonValue,Expression<T>,JsonValueException> expression(Class<T> type)
Returns a function that will create anExpressionfrom the string by theJsonValueusing the bindings defined in the heap of this Heaplet as initial bindings.- Type Parameters:
T- The type of the expression's result.- Parameters:
type- The expected result type of theExpression- Returns:
- a function that will create an
Expressionfrom the string by theJsonValueusing the bindings defined in the heap of this Heaplet as initial bindings.
-
initialBindings
protected Bindings initialBindings()
Return an initial set of bindings based on the heap properties, along with any utility items from the heap, such as the clock.- Returns:
- an initial set of bindings based on the heap properties, along with any utility items from the heap, such as the clock.
-
getHeap
public Heap getHeap()
Returns the heap associated to thatHeaplet.- Returns:
- the heap associated to that
Heaplet.
-
getConfig
public JsonValue getConfig()
Returns the config associated to thatHeaplet.- Returns:
- the config associated to that
Heaplet.
-
getSecretService
@Deprecated(since="7.0") public SecretsService getSecretService() throws HeapException
Deprecated.UseSecretsProviderinstead.Returns theSecretsServicefrom the heap.- Returns:
- the
SecretsServicefrom the heap. - Throws:
HeapException- if it cannot retrieve the secret service.
-
getSecretsProvider
public SecretsProvider getSecretsProvider() throws HeapException
Returns theSecretsProviderfrom the heap.- Returns:
- the
SecretsProviderfrom the heap. - Throws:
HeapException- if it cannot retrieve the secret service.
-
-