public class CustomFieldValueUserKeyChangeHandler extends Object implements UserKeyChangeHandler
Modifier and Type | Field and Description |
---|---|
static String |
MULTIUSERPICKER_CF_TYPE |
static String |
USERPICKER_CF_TYPE |
DEFAULT_NUMBER_OF_TASKS
Modifier and Type | Method and Description |
---|---|
Collection<AffectedEntity> |
getAffectedEntities(UserPropertyChangeParameter userPropertyChangeParameter)
This class is only called by
DelegatingChangeHandler and this method is not used, to not clutter the UI. |
int |
getNumberOfTasks(UserPropertyChangeParameter userPropertyChangeParameter)
Returns the number of tasks/stages to be executed in
AnonymizationHandler.update(Object) . |
static CustomFieldValueUserKeyChangeHandler |
multiUserPicker(QueryDslAccessor queryDslAccessor,
int numberOfTasks)
Builds CustomFieldValueKeyChangeHandler handling fields with type of "com.atlassian.jira.plugin.system.customfieldtypes:multiuserpicker".
|
static CustomFieldValueUserKeyChangeHandler |
singleUserPicker(QueryDslAccessor queryDslAccessor,
int numberOfTasks)
Builds CustomFieldValueKeyChangeHandler handling fields with type of "com.atlassian.jira.plugin.system.customfieldtypes:userpicker".
|
ServiceResult |
update(UserPropertyChangeParameter userPropertyChangeParameter)
Performs the updates required by the user anonymization.
|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
validateBusinessLogic
public static final String USERPICKER_CF_TYPE
public static final String MULTIUSERPICKER_CF_TYPE
public static CustomFieldValueUserKeyChangeHandler singleUserPicker(QueryDslAccessor queryDslAccessor, int numberOfTasks)
public static CustomFieldValueUserKeyChangeHandler multiUserPicker(QueryDslAccessor queryDslAccessor, int numberOfTasks)
@Nonnull public Collection<AffectedEntity> getAffectedEntities(@Nonnull UserPropertyChangeParameter userPropertyChangeParameter)
DelegatingChangeHandler
and this method is not used, to not clutter the UI.getAffectedEntities
in interface AnonymizationHandler<UserPropertyChangeParameter>
userPropertyChangeParameter
- Data relevant to the handled anonymization step, e.g. previous and new (anonymized) usernameDelegatingChangeHandler.getAffectedEntities(UserPropertyChangeParameter)
@Nonnull public ServiceResult update(@Nonnull UserPropertyChangeParameter userPropertyChangeParameter)
AnonymizationHandler
Implementations must be idempotent - multiple invocations of this method should lead to the same result. In particular, when the method fails we can call it again to finish the operation.
During the execution, implementations can update their the progress by calling Context.start(object);
on the context passed in parameter
, and subsequently call Context.Task.complete();
on the task
object to indicate task has finished.
Implementations can also call Context.setName("Name of current step")
to describe the task that is currently processed.
update
in interface AnonymizationHandler<UserPropertyChangeParameter>
userPropertyChangeParameter
- Data relevant to the handled anonymization step, e.g. previous and new (anonymized) usernamepublic int getNumberOfTasks(@Nonnull UserPropertyChangeParameter userPropertyChangeParameter)
AnonymizationHandler
AnonymizationHandler.update(Object)
. Used for diving the progress bar
between all of the handlers in proportions based on the returned numbers.
Implementations are responsible to execute the corresponding number of calls to Context.start(object);
and Context.Task.complete();
in AnonymizationHandler.update(Object)
.
getNumberOfTasks
in interface AnonymizationHandler<UserPropertyChangeParameter>
AnonymizationHandler.DEFAULT_NUMBER_OF_TASKS
Copyright © 2002-2022 Atlassian. All Rights Reserved.