Class OperationResult
java.lang.Object
com.evolveum.midpoint.schema.result.OperationResult
- All Implemented Interfaces:
- Visitable<OperationResult>,- OperationResultBuilder,- DebugDumpable,- ShortDumpable,- Serializable,- Cloneable
public class OperationResult
extends Object
implements Serializable, DebugDumpable, ShortDumpable, Cloneable, OperationResultBuilder, Visitable<OperationResult>
Provides rich information about an operation being executed; mainly for the sake of error reporting and functional/performance troubleshooting.
 == Information Collected
 There is a lot of information collected, but the following properties are the most important:
 - result *status* (
OperationResultStatus): success, partial/fatal error, warning, ..., along with
 an optional *message* and *Java exception*,
 - operation invocation *parameters*, *return value(s)*, and sometimes information about the execution *context* (e.g. implementation
 class name),
 - *performance-related information*, like start/end timestamps, or duration (for performance diagnostics),
 - TraceType records (for troubleshooting),
 - *logfile lines* produced during the operation execution (for troubleshooting).
 The structure is hierarchical, i.e. an OperationResult instance contains a set of results of inner operations.
 == Typical Uses
 - This object can be used by GUI to display smart (and interactive) error information.
 - It can also be used by the client code (Java or REST) to detect deeper problems in the invocations, retry or otherwise
 compensate for the errors or decide how severe the error was and whether it is possible to proceed.
 - The performance information collected is recorded in tasks (see OperationsPerformanceInformationType) and shown in GUI.
 See also OperationsPerformanceMonitorImpl class.
 - The functional and performance data collected are used for (experimental)
 link:https://docs.evolveum.com/midpoint/reference/diag/troubleshooting/troubleshooting-with-traces/[troubleshooting
 with traces].
 == Developer's Guidelines
 In order to ensure that all necessary information is correctly captured, a developer of any method that writes into
 OperationResult instances has to follow a couple of basic principles:
 === Principle 1: Correct Closure
 Any operation result created has to be correctly _closed_. This means that its status should be changed from
 the initial OperationResultStatus.UNKNOWN value to a more specific one. (Otherwise, a run-time exception is
 thrown in cleanupResult(Throwable) method.) Also, to ensure correct fulfillment of the other duties,
 recordEnd() method has be - directly or indirectly - called as well (see below).
 === Principle 2: Single Result Per Thread
 At any instant, in any thread, there should be at most one OperationResult "active", i.e. opened by
 createSubresult(String) or its variants (e.g. createMinorSubresult(String), subresult(String), ...),
 and not yet closed nor "superseded" by creating its own child result. This is to ensure that logfile lines will be correctly
 captured, if tracing is enabled. It is also required for correct collection of performance data.
 === Principle 3: Opening-Closure Pairing
 Because the operation result is used also to troubleshoot performance issues, it should be clear where (in the code)
 the result is created and where it is closed.
 When is result closed, anyway? The result is automatically closed when the status is recorded: either _explicitly_
 (like in recordSuccess()) or _implicitly_ (e.g. in computeStatus()). All those methods invoke
 recordEnd() that does all the magic related to performance information capturing, log records capturing,
 and (occasionally used) method call logging.
 To ensure easy, clear and unambiguous interpretation of the performance data, the developer should make sure that
 for each OperationResult created, it is obvious _where_ the result is closed. The best way how to ensure
 this is to create the result at the beginning (or near the beginning) of a related method, and close it - including writing
 the status - at the end (or near the end) of the same method. No recording of the status should be done between these points.
 If there's a need to set the value of status somewhere during the operation execution (assuming that
 there's non-negligible processing after that point), setStatus(OperationResultStatus) method or its variants
 (like setSuccess()) can be used. These fill-in status field without closing the whole operation result.
 === Principle 4: Preserve component boundaries
 OperationResult objects are used to monitor processing time spent in individual midPoint components.
 (See BasicComponentStructure for the mostly used structure.) Hence, it's crucial that an operation result
 is created when crossing component boundaries.
 A special case are result handlers, where the control flows upwards the structure.
 See ResultHandler.providingOwnOperationResult(String) for more information.
 === Note: Recording Exceptions
 The Correct Closure Principle (#1) dictates that the operation result has to be correctly closed even in the case
 of exception occurring. That is why we usually create a "try-catch" block for the code covered by a single operation result.
 Traditionally, the recordFatalError(Throwable) call was put into the `catch` code.
 However, there may be situations where a different handling is required:
 . If the exception is non-fatal or even completely benign. This may be the case of e.g. expected ("allowed")
 object-not-found conditions. See ObjectNotFoundException.getSeverity().
 . If the exception was processed by other means. For example, a custom error message was already provided.
 To handle these cases, recordException(Throwable) should be used instead of recordFatalError(Throwable).
 The difference is that the former checks the exceptionRecorded flag to see if the exception was already
 processed. See also markExceptionRecorded().
 NOTE: This mechanism is *experimental*.
 === Suggested Use
 Stemming from the above, the following can be seen as a suggested way how to use the operation result:
 [source,java]
 ----
 private static final OP_SOME_METHOD = ThisClass.class.getName() + ".someMethod";
 void someMethod(String param1, Object param2, OperationResult parentResult) throws SomeException {
     OperationResult result = parentResult.subresult(OP_SOME_METHOD)
                     .addParam("param1", param1)
                     .addArbitraryObjectAsParam("param2", param2)
                     .build();
     try {
         // ... some meat here ...
     } catch (SomeException | RuntimeException e) {
         result.recordException(e);
         throw e;
     } finally {
         result.close();
     }
 }
 ----
 Note that the close() method (a newer form of legacy computeStatusIfUnknown()) automatically computes
 the result based on subresults (assuming success if there's no indication of a failure). In theory we could put it inside
 the `try` block (because `recordFatalError` effectively closes the result as well), but using `finally` is perhaps more
 explicit. It may be also more future-proof if we would decide to add some extra functionality right into close()
 method itself.- Author:
- lazyman, Radovan Semancik
- See Also:
- 
Nested Class SummaryNested Classes
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final StringStandard name for a method that handles an object found in a search operation.static final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final StringFields inherited from interface com.evolveum.midpoint.util.DebugDumpableINDENT_STRING
- 
Constructor SummaryConstructorsConstructorDescriptionOperationResult(String operation) OperationResult(String operation, OperationResultStatus status, LocalizableMessage userFriendlyMessage) OperationResult(String operation, OperationResultStatus status, String message) OperationResult(String operation, Map<String, Collection<String>> params, OperationResultStatus status, long token, String messageCode, String message, LocalizableMessage userFriendlyMessage, Throwable cause, List<OperationResult> subresults) OperationResult(String operation, Map<String, Collection<String>> params, Map<String, Collection<String>> context, Map<String, Collection<String>> returns, OperationResultStatus status, long token, String messageCode, String message, LocalizableMessage userFriendlyMessage, Throwable cause, List<OperationResult> subresults) 
- 
Method SummaryModifier and TypeMethodDescriptionvoidaccept(Visitor<OperationResult> visitor) addArbitraryObjectAsContext(String name, Object value) addArbitraryObjectAsParam(String paramName, Object paramValue) voidaddArbitraryObjectAsReturn(String name, Object value) addArbitraryObjectCollectionAsContext(String paramName, Collection<?> paramValue) addArbitraryObjectCollectionAsParam(String name, Collection<?> value) voidaddArbitraryObjectCollectionAsReturn(String paramName, Collection<?> paramValue) addContext(String name, boolean value) addContext(String name, int value) addContext(String name, long value) addContext(String name, ObjectDelta<?> value) addContext(String name, PolyString value) addContext(String name, PrismObject<? extends ObjectType> value) addContext(String name, ObjectQuery value) addContext(String name, ObjectType value) addContext(String name, Class<?> value) addContext(String name, String value) addContext(String name, String... values) addContext(String name, QName value) addParam(String name, ObjectDelta<?> value) addParam(String name, PolyString value) addParam(String name, PrismObject<? extends ObjectType> value) addParam(String name, ObjectQuery value) addParam(String name, ObjectType value) addQualifier(String value) voidaddReturn(String name, ObjectDelta<?> value) voidaddReturn(String name, PolyString value) voidaddReturn(String name, PrismObject<? extends ObjectType> value) voidaddReturn(String name, ObjectQuery value) voidaddReturn(String name, ObjectType value) voidvoidvoidvoidvoidvoidvoidvoidaddReturnComment(String comment) voidaddSubresult(OperationResult subresult) voidvoidappendDetail(String detailLine) static voidapplyOperationResultHandlingStrategy(@NotNull List<OperationResultHandlingStrategyType> configuredStrategies) build()booleanvoidChecks if the recorder was correctly flushed.voidcleanup()AscleanupResult(Throwable)but uses the recorded exception for diagnostics.voidDeprecated.voidDeprecated.voidvoidvoidvoidclone()voidclose()voidComputes operation result status based on subtask status.voidcomputeStatus(boolean skipFinish) voidcomputeStatus(String errorMessage) Computes operation result status based on subtask status and sets an error message if the status is FATAL_ERROR.voidcomputeStatus(String errorMessage, String warnMessage) voidUsed when the result contains several composite sub-result that are of equivalent meaning.voidvoidAscreateOperationResultType()but does not export minor success entries.AscreateOperationResultType()but exports only the root result.static OperationResultBuildercreateMinorSubresult(String operation) static OperationResult@NotNull OperationResultType@NotNull OperationResultTypecreateOperationResultType(Function<LocalizableMessage, String> resolveKeys) createSubresult(String operation) static OperationResultcreateSubResultOrNewResult(OperationResult parentResult, String operation) debugDump(int indent) voidvoidRemoves subresults if they can be safely removed.dump(boolean withStack) voiddumpBasicInfo(StringBuilder sb, String prefix, int indent) boolean@Nullable StringThis method partially duplicates functionality of computeStatus.@Nullable StringA convenience method.findSubresult(String operation) findSubresults(String operation) Finds given operation among subresults of the current op.@NotNull List<OperationResult>findSubresultsDeeply(@NotNull String operation) Finds given operation in a subtree rooted by the current op.findSubResultStrictly(String operation) @Nullable StringA convenience method.Reference to an asynchronous operation that can be used to retrieve the status of the running operation.getCause()@NotNull Map<String,Collection<String>> @Nullable ParamsTypeintgetCount()getEnd()<T> TgetFirstTrace(Class<T> traceClass) intContains message code based on module error catalog.Contains operation name.@NotNull Map<String,Collection<String>> Method returnsMapwith operation parameters.@Nullable ParamsTypegetParamSingle(String name) @NotNull Map<String,Collection<String>> @Nullable ParamsTypegetReturnSingle(String name) getStart()Contains operation status as defined inOperationResultStatus@NotNull List<OperationResult>Method returns list of operation subresultsOperationResult.longgetToken()@NotNull TracingLevelTypegetTracingLevel(Class<? extends TraceType> traceClass) inthashCode()booleanReturns true if result status is UNKNOWN or any of the subresult status is unknown (recursive).booleanReturns true if the result is acceptable for further processing.booleanisClosed()booleanisEmpty()booleanisError()booleanbooleanbooleanstatic booleanbooleanisMinor()booleanbooleanbooleanbooleanReturns true if the result is success.booleanbooleanbooleanstatic booleanbooleanisTraced()booleanisTracing(Class<? extends TraceType> traceClass, TracingLevelType threshold) booleanisTracingAny(Class<? extends TraceType> traceClass) booleanisTracingDetailed(Class<? extends TraceType> traceClass) booleanisTracingNormal(Class<? extends TraceType> traceClass) booleanbooleanstatic OperationResultkeepRootOnly(OperationResult result) voidMarks the current exception (that is expected to be throws outside the context of the current operation) as already processed - so no further actions (besides closing the result) are necessary.voidvoidIf the operation is an error then it will switch the status to HANDLED_ERROR.voidSet all error status in this result and all subresults as handled.voidoperationKind(OperationKindType value) preserve()voidvoidrecomputeStatus(String errorMessage) voidrecomputeStatus(String errorMessage, String warningMessage) voidrecord(CommonException exception) Records result from a common exception type.voidvoidrecordException(@NotNull Throwable cause) Convenience version ofrecordException(String, Throwable)(with no custom message).voidrecordException(String message, @NotNull Throwable cause) A more sophisticated replacement forrecordFatalError(String, Throwable).voidrecordExceptionNotFinish(@NotNull Throwable cause) Convenience version ofrecordExceptionNotFinish(String, Throwable)(with no custom message).voidrecordExceptionNotFinish(String message, @NotNull Throwable cause) AsrecordException(String, Throwable)but does not mark operation as finished.voidrecordFatalError(String message) voidrecordFatalError(String message, Throwable cause) voidrecordFatalError(Throwable cause) voidrecordHandledError(String message) voidrecordHandledError(String message, Throwable cause) voidrecordHandledError(Throwable cause) voidvoidvoidrecordNotApplicable(String message) voidvoidrecordPartialError(String message) voidrecordPartialError(String message, Throwable cause) voidrecordPartialError(Throwable cause) voidrecordStatus(OperationResultStatus status) voidrecordStatus(OperationResultStatus status, String message) voidrecordStatus(OperationResultStatus status, String message, Throwable cause) voidrecordStatus(OperationResultStatus status, Throwable cause) voidvoidvoidvoidrecordWarning(String message) voidrecordWarning(String message, Throwable cause) voidrecordWarning(Throwable cause) voidrecordWarningNotFinish(String message, Throwable cause) static StringreferenceToCaseOid(String ref) static StringreferenceToTaskOid(String ref) voidvoidsetAsynchronousOperationReference(String asynchronousOperationReference) voidvoidsetCallerReason(String callerReason) voidsetCaseOid(String oid) voidsetCount(int count) voidsetCpuMicroseconds(Long cpuMicroseconds) voidvoidsetExtractedDictionary(TraceDictionaryType extractedDictionary) voidsetFatalError(String message, Throwable cause) voidsetFatalError(Throwable cause) voidsetHiddenRecordsCount(int hiddenRecordsCount) voidvoidsetInProgress(String message) voidsetInvocationId(Long invocationId) voidsetMessage(String message) voidsetMicroseconds(Long microseconds) setMinor()voidvoidvoidsetNotApplicable(String message) voidsetOwnMicroseconds(Long ownMicroseconds) voidsetPartialError(String message) voidsetPropagateHandledErrorAsSuccess(boolean propagateHandledErrorAsSuccess) voidvoidsetStatus(OperationResultStatus status) Sets the status _without_ recording operation end.voidvoidsetSummarizeErrors(boolean summarizeErrors) voidsetSummarizePartialErrors(boolean summarizePartialErrors) voidsetSummarizeSuccesses(boolean summarizeSuccesses) static voidsetThreadLocalHandlingStrategy(@Nullable String strategyName) voidvoidsetUserFriendlyMessage(LocalizableMessage userFriendlyMessage) voidShow the content of the object intended for diagnostics.voidvoidsummarize(boolean alsoSubresults) voidThis is used in situations where handled error is actually the success.toString()tracingProfile(CompiledTracingProfile profile) void"Un-marks" the exception as being recorded.Methods inherited from class java.lang.Objectfinalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface com.evolveum.midpoint.util.DebugDumpabledebugDump, debugDumpLazily, debugDumpLazilyMethods inherited from interface com.evolveum.midpoint.util.ShortDumpableshortDump, shortDumpLazily
- 
Field Details- 
CONTEXT_IMPLEMENTATION_CLASS- See Also:
 
- 
CONTEXT_PROGRESS- See Also:
 
- 
CONTEXT_OID- See Also:
 
- 
CONTEXT_OBJECT- See Also:
 
- 
CONTEXT_ITEM- See Also:
 
- 
CONTEXT_REASON- See Also:
 
- 
PARAM_OID- See Also:
 
- 
PARAM_NAME- See Also:
 
- 
PARAM_TYPE- See Also:
 
- 
PARAM_OPTIONS- See Also:
 
- 
PARAM_RESOURCE- See Also:
 
- 
PARAM_TASK- See Also:
 
- 
PARAM_OBJECT- See Also:
 
- 
PARAM_QUERY- See Also:
 
- 
PARAM_PROJECTION- See Also:
 
- 
PARAM_LANGUAGE- See Also:
 
- 
PARAM_POLICY_RULE- See Also:
 
- 
PARAM_POLICY_RULE_ID- See Also:
 
- 
RETURN_COUNT- See Also:
 
- 
RETURN_COMMENT- See Also:
 
- 
DEFAULT- See Also:
 
- 
HANDLE_OBJECT_FOUNDStandard name for a method that handles an object found in a search operation. SeeResultHandler.providingOwnOperationResult(String).- See Also:
 
 
- 
- 
Constructor Details- 
OperationResult
- 
OperationResultpublic OperationResult(String operation, OperationResultStatus status, LocalizableMessage userFriendlyMessage) 
- 
OperationResult
- 
OperationResultpublic OperationResult(String operation, Map<String, Collection<String>> params, OperationResultStatus status, long token, String messageCode, String message, LocalizableMessage userFriendlyMessage, Throwable cause, List<OperationResult> subresults) 
- 
OperationResultpublic OperationResult(String operation, Map<String, Collection<String>> params, Map<String, Collection<String>> context, Map<String, Collection<String>> returns, OperationResultStatus status, long token, String messageCode, String message, LocalizableMessage userFriendlyMessage, Throwable cause, List<OperationResult> subresults) 
 
- 
- 
Method Details- 
keepRootOnly
- 
keepRootOnly
- 
subresult
- 
createFor
- 
build- Specified by:
- buildin interface- OperationResultBuilder
 
- 
createSubresult
- 
createMinorSubresult
- 
recordEndpublic void recordEnd()
- 
checkLogRecorderFlushedpublic void checkLogRecorderFlushed()Checks if the recorder was correctly flushed. Used before writing the trace file.
- 
getAsynchronousOperationReferenceReference to an asynchronous operation that can be used to retrieve the status of the running operation. This may be a task identifier, identifier of a ticket in ITSM system or anything else. The exact format of this reference depends on the operation which is being executed. Looks only in the current result. SeefindAsynchronousOperationReference()for the recursive version.
- 
setAsynchronousOperationReference
- 
clearAsynchronousOperationReferencesDeeply@VisibleForTesting public void clearAsynchronousOperationReferencesDeeply()
- 
findAsynchronousOperationReferenceThis method partially duplicates functionality of computeStatus. However, computeStatus currently does not propagate taskOid from tasks switched to background, because switchToBackground sets its result to SUCCESS (not IN_PROGRESS) because of some historical reasons. So, until this is fixed somehow, this is a bit of hack to fetch asynchronous operation reference even in such cases.
- 
findTaskOidA convenience method. (Assumes we have only a single asynchronous operation reference in the tree.)
- 
findCaseOidA convenience method. (Assumes we have only a single asynchronous operation reference in the tree.)
- 
isTaskOid
- 
referenceToTaskOid
- 
referenceToCaseOid
- 
getOperationContains operation name. Operation name must be defined asStringconstant in module interface with description and possible parameters. It can be used for further processing. It will be used as key for translation in admin-gui.- Returns:
- always return non null, non empty string
 
- 
getCountpublic int getCount()
- 
setCountpublic void setCount(int count) 
- 
getHiddenRecordsCountpublic int getHiddenRecordsCount()
- 
setHiddenRecordsCountpublic void setHiddenRecordsCount(int hiddenRecordsCount) 
- 
isSummarizeErrorspublic boolean isSummarizeErrors()
- 
setSummarizeErrorspublic void setSummarizeErrors(boolean summarizeErrors) 
- 
isSummarizePartialErrorspublic boolean isSummarizePartialErrors()
- 
setSummarizePartialErrorspublic void setSummarizePartialErrors(boolean summarizePartialErrors) 
- 
isSummarizeSuccessespublic boolean isSummarizeSuccesses()
- 
setSummarizeSuccessespublic void setSummarizeSuccesses(boolean summarizeSuccesses) 
- 
isEmptypublic boolean isEmpty()
- 
getSubresultsMethod returns list of operation subresultsOperationResult.
- 
getLastSubresult- Returns:
- last subresult, or null if there are no subresults.
 
- 
removeLastSubresultpublic void removeLastSubresult()
- 
getLastSubresultStatus- Returns:
- last subresult status, or null if there are no subresults.
 
- 
addSubresult
- 
findSubresult
- 
findSubresultsDeeply@NotNull public @NotNull List<OperationResult> findSubresultsDeeply(@NotNull @NotNull String operation) Finds given operation in a subtree rooted by the current op. result. Includes this one!
- 
findSubresultsFinds given operation among subresults of the current op. result.
- 
getStatusContains operation status as defined inOperationResultStatus- Returns:
- never returns null
 
- 
getStatusBean
- 
setStatusSets the status _without_ recording operation end.
- 
isSuccesspublic boolean isSuccess()Returns true if the result is success.This returns true if the result is absolute success. Presence of partial failures or warnings fail this test. - Returns:
- true if the result is success.
 
- 
isWarningpublic boolean isWarning()
- 
isAcceptablepublic boolean isAcceptable()Returns true if the result is acceptable for further processing.In other words: if there were no fatal errors. Warnings and partial errors are acceptable. Yet, this test also fails if the operation state is not known. - Returns:
- true if the result is acceptable for further processing.
 
- 
isUnknownpublic boolean isUnknown()
- 
isInProgresspublic boolean isInProgress()
- 
isErrorpublic boolean isError()
- 
isFatalErrorpublic boolean isFatalError()
- 
isPartialErrorpublic boolean isPartialError()
- 
isHandledErrorpublic boolean isHandledError()
- 
isNotApplicablepublic boolean isNotApplicable()
- 
muteErrorsRecursivelypublic void muteErrorsRecursively()Set all error status in this result and all subresults as handled.
- 
computeStatusComputes operation result status based on subtask status and sets an error message if the status is FATAL_ERROR.- Parameters:
- errorMessage- error message
 
- 
computeStatus
- 
computeStatuspublic void computeStatus()Computes operation result status based on subtask status.
- 
computeStatuspublic void computeStatus(boolean skipFinish) 
- 
computeStatusCompositepublic void computeStatusComposite()Used when the result contains several composite sub-result that are of equivalent meaning. If all of them fail the result will be fatal error as well. If only some of them fail the result will be partial error. Handled error is considered a success.
- 
addTrace
- 
tracingProfile- Specified by:
- tracingProfilein interface- OperationResultBuilder
 
- 
getFirstTrace
- 
addReturnComment
- 
isTracingNormal
- 
isTracingAny
- 
isTracingDetailed
- 
isTracing
- 
getTracingLevel
- 
clearTracingProfilepublic void clearTracingProfile()
- 
accept- Specified by:
- acceptin interface- Visitable<OperationResult>
 
- 
getResultStream
- 
findSubResultStrictly
- 
switchHandledErrorToSuccessThis is used in situations where handled error is actually the success. For example, when writing an operation execution record to an object which we expect to be deleted, we consider such an operation to be a success. We do not want to bother user or administrator with the information that there was something that went wrong - when, in fact, it was really expected.
- 
deleteSubresultsIfPossiblepublic void deleteSubresultsIfPossible()Removes subresults if they can be safely removed. Used in places where we can expect a lot of children (although possibly summarized). Must be called on closed result, in order to avoid mis-computation of own time.
- 
computePreview
- 
getComputeStatus
- 
closepublic void close()
- 
isClosedpublic boolean isClosed()
- 
computeStatusIfUnknownpublic void computeStatusIfUnknown()
- 
computeStatusIfUnknownCompositepublic void computeStatusIfUnknownComposite()
- 
recomputeStatuspublic void recomputeStatus()
- 
recomputeStatus
- 
recomputeStatus
- 
recordSuccessIfUnknownpublic void recordSuccessIfUnknown()
- 
recordNotApplicableIfUnknownpublic void recordNotApplicableIfUnknown()
- 
recordNotApplicablepublic void recordNotApplicable()
- 
recordNotApplicable
- 
setNotApplicablepublic void setNotApplicable()
- 
setNotApplicable
- 
isMinorpublic boolean isMinor()
- 
getParamsMethod returnsMapwith operation parameters. Parameters keys are described in module interface for every operation.
- 
getParamsBean
- 
getParam
- 
getParamSingle
- 
addQualifier- Specified by:
- addQualifierin interface- OperationResultBuilder
 
- 
addParam- Specified by:
- addParamin interface- OperationResultBuilder
 
- 
addParam- Specified by:
- addParamin interface- OperationResultBuilder
 
- 
addParam- Specified by:
- addParamin interface- OperationResultBuilder
 
- 
addParam- Specified by:
- addParamin interface- OperationResultBuilder
 
- 
addParam- Specified by:
- addParamin interface- OperationResultBuilder
 
- 
addParam- Specified by:
- addParamin interface- OperationResultBuilder
 
- 
addParam- Specified by:
- addParamin interface- OperationResultBuilder
 
- 
addParam- Specified by:
- addParamin interface- OperationResultBuilder
 
- 
addParam- Specified by:
- addParamin interface- OperationResultBuilder
 
- 
addParam- Specified by:
- addParamin interface- OperationResultBuilder
 
- 
addParam- Specified by:
- addParamin interface- OperationResultBuilder
 
- 
addParam- Specified by:
- addParamin interface- OperationResultBuilder
 
- 
addArbitraryObjectAsParam- Specified by:
- addArbitraryObjectAsParamin interface- OperationResultBuilder
 
- 
addArbitraryObjectCollectionAsParam- Specified by:
- addArbitraryObjectCollectionAsParamin interface- OperationResultBuilder
 
- 
getContext
- 
getContextBean
- 
addContext- Specified by:
- addContextin interface- OperationResultBuilder
 
- 
addContext- Specified by:
- addContextin interface- OperationResultBuilder
 
- 
addContext- Specified by:
- addContextin interface- OperationResultBuilder
 
- 
addContext- Specified by:
- addContextin interface- OperationResultBuilder
 
- 
addContext- Specified by:
- addContextin interface- OperationResultBuilder
 
- 
addContext- Specified by:
- addContextin interface- OperationResultBuilder
 
- 
addContext- Specified by:
- addContextin interface- OperationResultBuilder
 
- 
addContext- Specified by:
- addContextin interface- OperationResultBuilder
 
- 
addContext- Specified by:
- addContextin interface- OperationResultBuilder
 
- 
addContext- Specified by:
- addContextin interface- OperationResultBuilder
 
- 
addContext- Specified by:
- addContextin interface- OperationResultBuilder
 
- 
addContext- Specified by:
- addContextin interface- OperationResultBuilder
 
- 
addArbitraryObjectAsContext- Specified by:
- addArbitraryObjectAsContextin interface- OperationResultBuilder
 
- 
addArbitraryObjectCollectionAsContextpublic OperationResult addArbitraryObjectCollectionAsContext(String paramName, Collection<?> paramValue) - Specified by:
- addArbitraryObjectCollectionAsContextin interface- OperationResultBuilder
 
- 
getReturns
- 
getReturnsBean
- 
getReturn
- 
getReturnSingle
- 
addReturn
- 
addReturn
- 
addReturn
- 
addReturn
- 
addReturn
- 
addReturn
- 
addReturn
- 
addReturn
- 
addReturn
- 
addReturn
- 
addReturn
- 
addReturn
- 
addArbitraryObjectAsReturn
- 
addArbitraryObjectCollectionAsReturn
- 
getTokenpublic long getToken()- Returns:
- Contains random long number, for better searching in logs.
 
- 
getMessageCodeContains message code based on module error catalog.- Returns:
- Can return null.
 
- 
getMessage- Returns:
- Method returns operation result message. Message is required. It will be key for translation in admin-gui.
 
- 
setMessage
- 
getUserFriendlyMessage
- 
setUserFriendlyMessage
- 
getCause- Returns:
- Method returns operation result exception. Not required, can be null.
 
- 
recordSuccesspublic void recordSuccess()
- 
setSuccesspublic void setSuccess()
- 
recordInProgresspublic void recordInProgress()
- 
setInProgresspublic void setInProgress()
- 
setInProgress
- 
setUnknownpublic void setUnknown()
- 
recordFatalError
- 
recordExceptionA more sophisticated replacement forrecordFatalError(String, Throwable). . Takes care not to overwrite the exception if it was already processed. . Marks the exception as processed. . Sets the appropriate result status. See the class javadoc.
- 
recordExceptionConvenience version ofrecordException(String, Throwable)(with no custom message).
- 
recordExceptionNotFinishAsrecordException(String, Throwable)but does not mark operation as finished.
- 
recordExceptionNotFinishConvenience version ofrecordExceptionNotFinish(String, Throwable)(with no custom message).
- 
markExceptionRecordedMarks the current exception (that is expected to be throws outside the context of the current operation) as already processed - so no further actions (besides closing the result) are necessary. See also the class javadoc.- See Also:
 
- 
unmarkExceptionRecordedpublic void unmarkExceptionRecorded()"Un-marks" the exception as being recorded. To be used when the code decides e.g. that the exception will not be thrown out of the context of the current operation.
- 
setFatalError
- 
setFatalError
- 
muteErrorpublic void muteError()If the operation is an error then it will switch the status to HANDLED_ERROR. This is used if the error is expected and properly handled.
- 
muteAllSubresultErrorspublic void muteAllSubresultErrors()
- 
muteLastSubresultErrorpublic void muteLastSubresultError()
- 
clearLastSubresultErrorpublic void clearLastSubresultError()
- 
deleteLastSubresultIfErrorpublic void deleteLastSubresultIfError()
- 
recordPartialError
- 
recordWarning
- 
recordStatus
- 
recordFatalError
- 
recordPartialError
- 
recordWarning
- 
recordWarningNotFinish
- 
recordHandledError
- 
recordHandledError
- 
recordHandledError
- 
recordStatus
- 
setPropagateHandledErrorAsSuccesspublic void setPropagateHandledErrorAsSuccess(boolean propagateHandledErrorAsSuccess) 
- 
recordFatalError
- 
recordPartialError
- 
setPartialError
- 
recordWarning
- 
recordRecords result from a common exception type. This automatically determines status and also sets appropriate message.- Parameters:
- exception- common exception
 
- 
recordStatus
- 
recordStatus
- 
hasUnknownStatuspublic boolean hasUnknownStatus()Returns true if result status is UNKNOWN or any of the subresult status is unknown (recursive).May come handy in tests to check if all the operations fill out the status as they should. 
- 
appendDetail
- 
getDetail
- 
createOperationResult@Contract("null -> null; !null -> !null") public static OperationResult createOperationResult(OperationResultType bean) 
- 
createBeanReducedAscreateOperationResultType()but does not export minor success entries. This is needed to reduce the size of e.g.ShadowTypeobjects with fetchResult that includes full traced clockwork processing.
- 
createBeanRootOnlyAscreateOperationResultType()but exports only the root result.
- 
createOperationResultType
- 
createOperationResultType@NotNull public @NotNull OperationResultType createOperationResultType(Function<LocalizableMessage, String> resolveKeys) 
- 
summarizepublic void summarize()
- 
summarizepublic void summarize(boolean alsoSubresults) 
- 
cleanupResultDeeplypublic void cleanupResultDeeply()
- 
cleanuppublic void cleanup()AscleanupResult(Throwable)but uses the recorded exception for diagnostics. It is more convenient than that method, as it can be used in the `finally` block - assuming that the exception was recorded in the `catch` block or earlier.
- 
cleanupResultDeprecated.Removes all the successful minor results. Also checks if the result is roughly consistent and complete. (e.g. does not have unknown operation status, etc.)
- 
cleanupResultDeprecated.Removes all the successful minor results. Also checks if the result is roughly consistent and complete. (e.g. does not have unknown operation status, etc.)The argument "e" is for easier use of the cleanup in the exceptions handlers. The original exception is passed to the IAE that this method produces for easier debugging. 
- 
canBeCleanedUppublic boolean canBeCleanedUp()
- 
isLesserThanpublic static boolean isLesserThan(OperationResultImportanceType x, @NotNull @NotNull OperationResultImportanceType y) - Returns:
- true if x < y
 
- 
debugDump- Specified by:
- debugDumpin interface- DebugDumpable
 
- 
dump
- 
dumpBasicInfo
- 
shortDumpDescription copied from interface:ShortDumpableShow the content of the object intended for diagnostics. This method is supposed to append a compact, human-readable output in a single line. Unlike toString() method, there is no requirement to identify the actual class or type of the object. It is assumed that the class/type will be obvious from the context in which the output is used.- Specified by:
- shortDumpin interface- ShortDumpable
- Parameters:
- sb- StringBuilder to which to a compact one-line content of the object intended for diagnostics by system administrator should be appended.
 
- 
toString
- 
setBackgroundTaskOid
- 
setCaseOid
- 
operationKind- Specified by:
- operationKindin interface- OperationResultBuilder
 
- 
getOperationKind
- 
preserve- Specified by:
- preservein interface- OperationResultBuilder
 
- 
isPreservepublic boolean isPreserve()
- 
setMinor- Specified by:
- setMinorin interface- OperationResultBuilder
 
- 
getImportance
- 
setImportance- Specified by:
- setImportancein interface- OperationResultBuilder
 
- 
recordThrowableIfNeeded
- 
createSubResultOrNewResultpublic static OperationResult createSubResultOrNewResult(OperationResult parentResult, String operation) 
- 
clone
- 
clone
- 
applyOperationResultHandlingStrategypublic static void applyOperationResultHandlingStrategy(@NotNull @NotNull List<OperationResultHandlingStrategyType> configuredStrategies) 
- 
setThreadLocalHandlingStrategy
- 
equals
- 
hashCodepublic int hashCode()
- 
getStart
- 
setStart
- 
getEnd
- 
setEnd
- 
getMicroseconds
- 
setMicroseconds
- 
getOwnMicroseconds
- 
setOwnMicroseconds
- 
getCpuMicroseconds
- 
setCpuMicroseconds
- 
getInvocationId
- 
setInvocationId
- 
isTracedpublic boolean isTraced()
- 
getTracingProfile
- 
getTraces
- 
getMonitoredOperations
- 
setMonitoredOperations
- 
getQualifiers
- 
getCallerReason
- 
setCallerReason
- 
getLogSegments
- 
getExtractedDictionary
- 
setExtractedDictionary
 
-