Class CaptureDecorator
java.lang.Object
org.forgerock.openig.decoration.helper.AbstractDecorator
org.forgerock.openig.decoration.capture.CaptureDecorator
- All Implemented Interfaces:
Decorator
The capture decorator can decorates both
Filter
and Handler
instances. It enables
the user to see the messages coming in and out of the decorated object.
Multiple input/output can be intercepted:
CapturePoint.ALL
: Prints all of the messagesCapturePoint.FILTERED_REQUEST
: Prints the outgoing request (Filter only)CapturePoint.FILTERED_RESPONSE
: Prints the outgoing responseCapturePoint.REQUEST
: Prints incoming + outgoing requestCapturePoint.RESPONSE
: Prints incoming + outgoing responseCapturePoint.NONE
: Disable capture
{
"name": "capture",
"type": "CaptureDecorator",
"config": {
"captureEntity": false,
"captureContext": false
}
}
The capture decorator can be configured to globally enable entity capture using the captureEntity
boolean attribute (default to false
). To set a limit on the maximum length of entities to capture, use
maxEntityLength and set it to a value in bytes, the default is 512K.
To capture the context at the capture point as well, use the captureContext boolean attribute
(default to false
).
To mask values from headers and/or values from the attributes context, use the optional masks section
to match by header and/or attribute name and mask the actual value. The name to match can be a regular expression.
To override the default mask value of *****, provide the optional mask to set a different mask value.
{
"name": "capture",
"type": "CaptureDecorator",
"config": {
"masks": {
"headers": [ "x-token" ],
"attributes": [ "replay" ],
"mask": "*** my mask value ***"
}
}
}
To decorate a component, just add the decorator declaration next to the config
element:
{
"type": "...",
"capture": [ "FILTERED_REQUEST", "RESPONSE" ],
"config": { ... }
}
Notice that the attribute name in the decorated object has to be the same as the decorator
heap object name (capture
in our example).
A default capture decorator is automatically created when IG starts. It can be overridden
in the configuration files if default values are not satisfying.-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic class
Creates and initializes a CaptureDecorator in a heap environment. -
Constructor Summary
ConstructorsConstructorDescriptionCaptureDecorator
(String name, boolean captureEntity, boolean captureContext) Builds a newcapture
decorator.CaptureDecorator
(String name, boolean captureEntity, boolean captureContext, int maxEntityLength, KeyValueProcessor headerProcessor, KeyValueProcessor attributeProcessor, KeyValueProcessor trailerProcessor) Builds a newcapture
decorator. -
Method Summary
Modifier and TypeMethodDescriptionboolean
Returnstrue
if this decorator is compatible with the provided component type.Decorates the provideddelegate
instance with the provideddecoratorConfig
configuration.Methods inherited from class org.forgerock.openig.decoration.helper.AbstractDecorator
getLogger
-
Constructor Details
-
CaptureDecorator
Builds a newcapture
decorator.- Parameters:
name
- The name of this decoratorcaptureEntity
-true
if the decorator needs to capture the entity,false
otherwisecaptureContext
-true
if the decorator needs to capture the context,false
otherwise
-
CaptureDecorator
public CaptureDecorator(String name, boolean captureEntity, boolean captureContext, int maxEntityLength, KeyValueProcessor headerProcessor, KeyValueProcessor attributeProcessor, KeyValueProcessor trailerProcessor) Builds a newcapture
decorator.- Parameters:
name
- The name of this decoratorcaptureEntity
-true
if the decorator needs to capture the entity,false
otherwisecaptureContext
-true
if the decorator needs to capture the context,false
otherwisemaxEntityLength
- Set the maximum entity length to capture ifcaptureEntity
is enabled.headerProcessor
- TheKeyValueProcessor
to apply to header values.attributeProcessor
- TheKeyValueProcessor
to apply to attribute values.trailerProcessor
- TheKeyValueProcessor
to apply to trailer values.
-
-
Method Details
-
accepts
Description copied from interface:Decorator
Returnstrue
if this decorator is compatible with the provided component type. Note that a return value oftrue
does not necessarily indicate that decoration will be performed since it may also depend on other factors- Parameters:
type
- type under test- Returns:
true
if the decorator can decorate instance of the given type,false
otherwise.
-
decorate
public DecorationHandle decorate(Object delegate, JsonValue decoratorConfig, Context context) throws HeapException Description copied from interface:Decorator
Decorates the provideddelegate
instance with the provideddecoratorConfig
configuration. The implementation should take care of not changing the base type of the delegate.- Parameters:
delegate
- instance to be decorateddecoratorConfig
- the decorator configuration to applycontext
- contextual information of the decorated instance- Returns:
- a handle of the decoration that was setup, never
null
. - Throws:
HeapException
- when decoration fails
-