| | |
| | | |
| | | |
| | | import static com.sun.opends.sdk.messages.Messages.*; |
| | | import static org.opends.sdk.schema.SchemaConstants.*; |
| | | import static org.opends.sdk.schema.SchemaConstants.EMR_CASE_IGNORE_LIST_OID; |
| | | import static org.opends.sdk.schema.SchemaConstants.SMR_CASE_IGNORE_LIST_OID; |
| | | import static org.opends.sdk.schema.SchemaConstants.SYNTAX_OTHER_MAILBOX_NAME; |
| | | |
| | | import org.opends.sdk.ByteSequence; |
| | | import org.opends.sdk.LocalizableMessageBuilder; |
| | | |
| | | |
| | | |
| | | |
| | | /** |
| | | * This class implements the other mailbox attribute syntax, which |
| | | * consists of a printable string component (the mailbox type) followed |
| | | * by a dollar sign and an IA5 string component (the mailbox). Equality |
| | | * and substring matching will be allowed by default. |
| | | * This class implements the other mailbox attribute syntax, which consists of a |
| | | * printable string component (the mailbox type) followed by a dollar sign and |
| | | * an IA5 string component (the mailbox). Equality and substring matching will |
| | | * be allowed by default. |
| | | */ |
| | | final class OtherMailboxSyntaxImpl extends AbstractSyntaxImpl |
| | | { |
| | |
| | | |
| | | |
| | | /** |
| | | * Indicates whether the provided value is acceptable for use in an |
| | | * attribute with this syntax. If it is not, then the reason may be |
| | | * appended to the provided buffer. |
| | | * |
| | | * Indicates whether the provided value is acceptable for use in an attribute |
| | | * with this syntax. If it is not, then the reason may be appended to the |
| | | * provided buffer. |
| | | * |
| | | * @param schema |
| | | * The schema in which this syntax is defined. |
| | | * @param value |
| | | * The value for which to make the determination. |
| | | * @param invalidReason |
| | | * The buffer to which the invalid reason should be appended. |
| | | * @return <CODE>true</CODE> if the provided value is acceptable for |
| | | * use with this syntax, or <CODE>false</CODE> if not. |
| | | * @return <CODE>true</CODE> if the provided value is acceptable for use with |
| | | * this syntax, or <CODE>false</CODE> if not. |
| | | */ |
| | | public boolean valueIsAcceptable(Schema schema, ByteSequence value, |
| | | LocalizableMessageBuilder invalidReason) |
| | | public boolean valueIsAcceptable(final Schema schema, |
| | | final ByteSequence value, final LocalizableMessageBuilder invalidReason) |
| | | { |
| | | // Check to see if the provided value was null. If so, then that's |
| | | // not acceptable. |
| | | if (value == null) |
| | | { |
| | | |
| | | invalidReason.append(ERR_ATTR_SYNTAX_OTHER_MAILBOX_EMPTY_VALUE |
| | | .get()); |
| | | invalidReason.append(ERR_ATTR_SYNTAX_OTHER_MAILBOX_EMPTY_VALUE.get()); |
| | | return false; |
| | | } |
| | | |
| | |
| | | if (valueLength == 0) |
| | | { |
| | | |
| | | invalidReason.append(ERR_ATTR_SYNTAX_OTHER_MAILBOX_EMPTY_VALUE |
| | | .get()); |
| | | invalidReason.append(ERR_ATTR_SYNTAX_OTHER_MAILBOX_EMPTY_VALUE.get()); |
| | | return false; |
| | | } |
| | | |
| | |
| | | else if (!PrintableStringSyntaxImpl.isPrintableCharacter(c)) |
| | | { |
| | | |
| | | invalidReason |
| | | .append(ERR_ATTR_SYNTAX_OTHER_MAILBOX_ILLEGAL_MBTYPE_CHAR |
| | | .get(valueString, String.valueOf(c), pos)); |
| | | invalidReason.append(ERR_ATTR_SYNTAX_OTHER_MAILBOX_ILLEGAL_MBTYPE_CHAR |
| | | .get(valueString, String.valueOf(c), pos)); |
| | | return false; |
| | | } |
| | | } |
| | |
| | | if (c != (c & 0x7F)) |
| | | { |
| | | |
| | | invalidReason |
| | | .append(ERR_ATTR_SYNTAX_OTHER_MAILBOX_ILLEGAL_MB_CHAR.get( |
| | | valueString, String.valueOf(c), pos)); |
| | | invalidReason.append(ERR_ATTR_SYNTAX_OTHER_MAILBOX_ILLEGAL_MB_CHAR.get( |
| | | valueString, String.valueOf(c), pos)); |
| | | return false; |
| | | } |
| | | } |