Class MultiGroupCFType
java.lang.Object
com.atlassian.jira.issue.customfields.impl.AbstractCustomFieldType<Collection<S>,S>
com.atlassian.jira.issue.customfields.impl.AbstractMultiCFType<com.atlassian.crowd.embedded.api.Group>
com.atlassian.jira.issue.customfields.impl.MultiGroupCFType
- All Implemented Interfaces:
ProjectImportableCustomField,CustomFieldType<Collection<com.atlassian.crowd.embedded.api.Group>,,com.atlassian.crowd.embedded.api.Group> GroupSelectorField,SortableCustomField<String>,ExportableCustomFieldType,RestAwareCustomFieldType,RestCustomFieldTypeOperations,UserField
public class MultiGroupCFType
extends AbstractMultiCFType<com.atlassian.crowd.embedded.api.Group>
implements GroupSelectorField, ProjectImportableCustomField, UserField, SortableCustomField<String>, RestAwareCustomFieldType, RestCustomFieldTypeOperations, ExportableCustomFieldType
Multiple User Group Select Type
- Transport Object Type
CollectionofGroups- Singular Object Type
Group- Database Storage Type
Stringof group name
-
Nested Class Summary
Nested ClassesNested classes/interfaces inherited from class com.atlassian.jira.issue.customfields.impl.AbstractCustomFieldType
AbstractCustomFieldType.VisitorBase<X> -
Field Summary
FieldsFields inherited from class com.atlassian.jira.issue.customfields.impl.AbstractMultiCFType
customFieldValuePersister, genericConfigManagerFields inherited from interface com.atlassian.jira.issue.customfields.CustomFieldType
DEFAULT_VALUE_TYPE, RESOURCE_PREVIEW -
Constructor Summary
ConstructorsConstructorDescriptionMultiGroupCFType(CustomFieldValuePersister customFieldValuePersister, GenericConfigManager genericConfigManager, MultiGroupConverter multiGroupConverter, PermissionManager permissionManager, JiraAuthenticationContext authenticationContext, GroupManager groupManager, FieldVisibilityManager fieldVisibilityManager, JiraBaseUrls jiraBaseUrls) -
Method Summary
Modifier and TypeMethodDescriptionintcompare(String customFieldObjectValue1, String customFieldObjectValue2, FieldConfig fieldConfig) Compares the two custom field objects.protected com.atlassian.crowd.embedded.api.GroupconvertDbValueToType(Object dbValue) Converts a given db value to Single form of Transport Objectprotected ObjectconvertTypeToDbValue(com.atlassian.crowd.embedded.api.Group value) Converts a given underlying type to its db storage value.protected PersistenceFieldTypeType of database field needed to store this field.getFieldTypeInfo(FieldTypeInfoContext fieldTypeInfoContext) Returns lower level Information about the field.getIdentifiersForGroup(String groupName) This method should be implemented in your custom type to return a List of identifiers of your group.getJsonDefaultValue(IssueContext issueCtx, CustomField field) Return The default data for this system field.getJsonFromIssue(CustomField field, Issue issue, boolean renderedVersionRequested, FieldLayoutItem fieldLayoutItem) Return a JsonData representation of the field valuegetJsonSchema(CustomField customField) Return a description of the shape of this field when represented as JSON.Returns an instance ofNonNullCustomFieldProviderthat Jira will use to optimize indexing performance.Returns the object that will perform the actual project import functions for the custom field type.getRelatedIndexers(CustomField customField) Returns a list of indexers that will be used for the field.getRepresentationFromIssue(Issue issue, CustomFieldExportContext context) Get the custom field representation of the issue, this object contains the column headers and values for each of theFieldExportPart.getRestFieldOperation(CustomField field) Returns the RestFieldOperationsHandler for this field.com.atlassian.crowd.embedded.api.GroupReturns a Singular Object, given the string value as passed by the presentation tier.getStringFromSingularObject(com.atlassian.crowd.embedded.api.Group o) Returns theStringrepresentation of a single value within the CustomFieldType.getStringValueFromCustomFieldParams(CustomFieldParams parameters) Return the String value object from the CustomFieldParams.protected Comparator<com.atlassian.crowd.embedded.api.Group>Returns a comparator for underlying type of this custom field.Collection<com.atlassian.crowd.embedded.api.Group>getValueFromCustomFieldParams(CustomFieldParams parameters) Retrieves the Transport Object representing the CustomField value instance from the CustomFieldParams of Strings.getVelocityParameters(Issue issue, CustomField field, FieldLayoutItem fieldLayoutItem) The custom field may wish to pass parameters to the velocity context beyond the getValueFromIssue methods (eg managers).booleanvoidvalidateFromParams(CustomFieldParams relevantParams, ErrorCollection errorCollectionToAddTo, FieldConfig config) Ensures that theCustomFieldParamsof Strings is a valid representation of the Custom Field values.Methods inherited from class com.atlassian.jira.issue.customfields.impl.AbstractMultiCFType
convertDbObjectToTypes, convertTypesToDbObjects, createValue, getChangelogValue, getDefaultValue, getValueFromIssue, getValueFromIssue, remove, setDefaultValue, updateValueMethods inherited from class com.atlassian.jira.issue.customfields.impl.AbstractCustomFieldType
assertObjectImplementsType, availableForBulkEdit, getChangelogString, getConfigurationItemTypes, getDescription, getDescriptor, getI18nBean, getKey, getName, getVelocityParameters, init, isRenderable, valuesEqualMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface com.atlassian.jira.issue.customfields.CustomFieldType
areAllRequiredParametersPresent, getCloneOptionConfiguration, getCloneValue, isUserInputRequiredForMove, requiresAdditionalParams
-
Field Details
-
multiGroupConverter
-
-
Constructor Details
-
MultiGroupCFType
public MultiGroupCFType(CustomFieldValuePersister customFieldValuePersister, GenericConfigManager genericConfigManager, MultiGroupConverter multiGroupConverter, PermissionManager permissionManager, JiraAuthenticationContext authenticationContext, GroupManager groupManager, FieldVisibilityManager fieldVisibilityManager, JiraBaseUrls jiraBaseUrls)
-
-
Method Details
-
getTypeComparator
Description copied from class:AbstractMultiCFTypeReturns a comparator for underlying type of this custom field. Used e.g. for sorting values retrieved from the Database- Specified by:
getTypeComparatorin classAbstractMultiCFType<com.atlassian.crowd.embedded.api.Group>- Returns:
- a comparator, null if can't be compared without extra context
-
getValueFromCustomFieldParams
public Collection<com.atlassian.crowd.embedded.api.Group> getValueFromCustomFieldParams(CustomFieldParams parameters) throws FieldValidationException Description copied from interface:CustomFieldTypeRetrieves the Transport Object representing the CustomField value instance from the CustomFieldParams of Strings.- Specified by:
getValueFromCustomFieldParamsin interfaceCustomFieldType<Collection<com.atlassian.crowd.embedded.api.Group>,com.atlassian.crowd.embedded.api.Group> - Parameters:
parameters- CustomFieldParams of String objects. Will contain one value for Singular field types.- Returns:
- Transport Object matching the Object parameter of
CustomFieldType.createValue(com.atlassian.jira.issue.fields.CustomField, com.atlassian.jira.issue.Issue, T),CustomFieldType.updateValue(com.atlassian.jira.issue.fields.CustomField, com.atlassian.jira.issue.Issue, T) - Throws:
FieldValidationException- if the String value fails to convert into Objects- See Also:
-
CustomFieldType.createValue(com.atlassian.jira.issue.fields.CustomField, com.atlassian.jira.issue.Issue, Object)CustomFieldType.updateValue(com.atlassian.jira.issue.fields.CustomField, com.atlassian.jira.issue.Issue, Object)CustomFieldType.getValueFromIssue(com.atlassian.jira.issue.fields.CustomField, com.atlassian.jira.issue.Issue)
-
getStringValueFromCustomFieldParams
Description copied from interface:CustomFieldTypeReturn the String value object from the CustomFieldParams. The object may be a single String (e.g. TextCFType, List of Strings (e.g. MultiSelectCFType) or CustomFieldParams of Strings (e.g. CascadingSelectCFType). Among other things these values are passed to Velocity for rendering edit screens.- Specified by:
getStringValueFromCustomFieldParamsin interfaceCustomFieldType<Collection<com.atlassian.crowd.embedded.api.Group>,com.atlassian.crowd.embedded.api.Group> - Parameters:
parameters- - CustomFieldParams containing String values- Returns:
- String value object from the CustomFieldParams
-
validateFromParams
public void validateFromParams(CustomFieldParams relevantParams, ErrorCollection errorCollectionToAddTo, FieldConfig config) Description copied from interface:CustomFieldTypeEnsures that theCustomFieldParamsof Strings is a valid representation of the Custom Field values. Any errors should be added to theErrorCollectionunder the appropriate key as required.- Specified by:
validateFromParamsin interfaceCustomFieldType<Collection<com.atlassian.crowd.embedded.api.Group>,com.atlassian.crowd.embedded.api.Group> - Parameters:
relevantParams- parameter object of StringserrorCollectionToAddTo- errorCollection to which any errors should be added (never null)config- FieldConfig
-
getStringFromSingularObject
Description copied from interface:CustomFieldTypeReturns theStringrepresentation of a single value within the CustomFieldType. This is the value that is passed to the presentation tier for editing. For single CustomFieldTypes the Singular Object is the same as a Transport Object. However, for multi-dimensional CustomFieldTypes, the Singular Object is the Object contained within theCollectionorMap- Specified by:
getStringFromSingularObjectin interfaceCustomFieldType<Collection<com.atlassian.crowd.embedded.api.Group>,com.atlassian.crowd.embedded.api.Group> - Parameters:
o- the object- Returns:
- String representation of the Object
-
getSingularObjectFromString
public com.atlassian.crowd.embedded.api.Group getSingularObjectFromString(String s) throws FieldValidationException Description copied from interface:CustomFieldTypeReturns a Singular Object, given the string value as passed by the presentation tier. Throws FieldValidationException if the string is an invalid representation of the Object.- Specified by:
getSingularObjectFromStringin interfaceCustomFieldType<Collection<com.atlassian.crowd.embedded.api.Group>,com.atlassian.crowd.embedded.api.Group> - Parameters:
s- the String- Returns:
- singularObject instance
- Throws:
FieldValidationException- if the string is an invalid representation of the Object.
-
getRelatedIndexers
Description copied from interface:CustomFieldTypeReturns a list of indexers that will be used for the field.- Specified by:
getRelatedIndexersin interfaceCustomFieldType<Collection<com.atlassian.crowd.embedded.api.Group>,com.atlassian.crowd.embedded.api.Group> - Overrides:
getRelatedIndexersin classAbstractCustomFieldType<Collection<com.atlassian.crowd.embedded.api.Group>,com.atlassian.crowd.embedded.api.Group> - Parameters:
customField- the custom field to get the related indexers of.- Returns:
- List of instantiated and initialised
FieldIndexerobjects. Null if no related indexers.
-
getVelocityParameters
@Nonnull public Map<String,Object> getVelocityParameters(Issue issue, CustomField field, FieldLayoutItem fieldLayoutItem) Description copied from interface:CustomFieldTypeThe custom field may wish to pass parameters to the velocity context beyond the getValueFromIssue methods (eg managers).The values are added to the context for all velocity views (edit, search, view, xml)
- Specified by:
getVelocityParametersin interfaceCustomFieldType<Collection<com.atlassian.crowd.embedded.api.Group>,com.atlassian.crowd.embedded.api.Group> - Overrides:
getVelocityParametersin classAbstractCustomFieldType<Collection<com.atlassian.crowd.embedded.api.Group>,com.atlassian.crowd.embedded.api.Group> - Parameters:
issue- The issue currently in context (Note: this will be null in cases like 'default value')field- CustomFieldfieldLayoutItem- FieldLayoutItem- Returns:
- A
Mapof parameters to add to the velocity context, or an empty Map otherwise (never null)
-
convertTypeToDbValue
Description copied from class:AbstractMultiCFTypeConverts a given underlying type to its db storage value. Must be compatable withPersistenceFieldTypereturned byAbstractMultiCFType.getDatabaseType()- Specified by:
convertTypeToDbValuein classAbstractMultiCFType<com.atlassian.crowd.embedded.api.Group>- Parameters:
value- Single form of Transport Object- Returns:
- database representation of given Transport Object.
-
convertDbValueToType
Description copied from class:AbstractMultiCFTypeConverts a given db value to Single form of Transport Object- Specified by:
convertDbValueToTypein classAbstractMultiCFType<com.atlassian.crowd.embedded.api.Group>- Parameters:
dbValue- db representation as returned byAbstractMultiCFType.convertTypeToDbValue(Object)- Returns:
- Single form of Transport Object
-
getDatabaseType
Description copied from class:AbstractMultiCFTypeType of database field needed to store this field.- Specified by:
getDatabaseTypein classAbstractMultiCFType<com.atlassian.crowd.embedded.api.Group>- Returns:
- One of the predefined
PersistenceFieldTypetypes.
-
isMultiple
public boolean isMultiple() -
getRepresentationFromIssue
Description copied from interface:ExportableCustomFieldTypeGet the custom field representation of the issue, this object contains the column headers and values for each of theFieldExportPart.- Specified by:
getRepresentationFromIssuein interfaceExportableCustomFieldType- Parameters:
issue- to get the representation forcontext- which contains information such as the i18nHelper and field- Returns:
- the exportable parts of this issue
-
getProjectImporter
Description copied from interface:ProjectImportableCustomFieldReturns the object that will perform the actual project import functions for the custom field type.- Specified by:
getProjectImporterin interfaceProjectImportableCustomField- Returns:
- the object that will perform the actual project import functions for the custom field type.
-
getIdentifiersForGroup
Description copied from interface:GroupSelectorFieldThis method should be implemented in your custom type to return a List of identifiers of your group. Usually the identifier is just thegroupName. However, some custom fields, such asSelectCFTypeassign ids to their values and index the ids. In such a case, the custom field should return all the ids under which thegroupNamewas indexed. These should match the values that were used in the implementation ofFieldIndexer.addIndex(Document, Issue, CustomFieldPrefetchedData)- Specified by:
getIdentifiersForGroupin interfaceGroupSelectorField- Parameters:
groupName- The name of the group- Returns:
- The group identifier that will be used to search for this group in the index
-
compare
public int compare(@Nonnull String customFieldObjectValue1, @Nonnull String customFieldObjectValue2, FieldConfig fieldConfig) Description copied from interface:SortableCustomFieldCompares the two custom field objects.- Specified by:
comparein interfaceSortableCustomField<String>- Parameters:
customFieldObjectValue1- Never nullcustomFieldObjectValue2- Never null- Returns:
- 0, 1 or -1
-
getNonNullCustomFieldProvider
Description copied from interface:CustomFieldTypeReturns an instance ofNonNullCustomFieldProviderthat Jira will use to optimize indexing performance.- Specified by:
getNonNullCustomFieldProviderin interfaceCustomFieldType<Collection<com.atlassian.crowd.embedded.api.Group>,com.atlassian.crowd.embedded.api.Group>
-
accept
- Overrides:
acceptin classAbstractMultiCFType<com.atlassian.crowd.embedded.api.Group>
-
getFieldTypeInfo
Description copied from interface:RestAwareCustomFieldTypeReturns lower level Information about the field. This information contains allowed values and/or the autocomplete url- Specified by:
getFieldTypeInfoin interfaceRestAwareCustomFieldType- Parameters:
fieldTypeInfoContext- context information for generating theFieldTypeInfo.- Returns:
- Low level information about the field.
-
getJsonSchema
Description copied from interface:RestAwareCustomFieldTypeReturn a description of the shape of this field when represented as JSON.- Specified by:
getJsonSchemain interfaceRestAwareCustomFieldType
-
getJsonFromIssue
public FieldJsonRepresentation getJsonFromIssue(CustomField field, Issue issue, boolean renderedVersionRequested, @Nullable FieldLayoutItem fieldLayoutItem) Description copied from interface:RestAwareCustomFieldTypeReturn a JsonData representation of the field value- Specified by:
getJsonFromIssuein interfaceRestAwareCustomFieldType- Parameters:
field- configuration of the current fieldissue- to get field data fromrenderedVersionRequested- whether the use requested the return of rendered/pretty data as well as raw datafieldLayoutItem- field layout for this field.- Returns:
- FieldJsonDataPair containing a json representation of the raw data for this field, and if required, a json representation of the rendered data for easy display.
-
getRestFieldOperation
Description copied from interface:RestCustomFieldTypeOperationsReturns the RestFieldOperationsHandler for this field.- Specified by:
getRestFieldOperationin interfaceRestCustomFieldTypeOperations- Parameters:
field- the Custom Field- Returns:
- the RestFieldOperationsHandler for this field.
-
getJsonDefaultValue
Description copied from interface:RestCustomFieldTypeOperationsReturn The default data for this system field. May be null if there is no default.- Specified by:
getJsonDefaultValuein interfaceRestCustomFieldTypeOperations- Parameters:
issueCtx- Issue (This should really only need to be an issue context, but for historical reasons we need an issue object.field- the Custom Field- Returns:
- The default data for this system field.
-