Searching Intrinsic ALI Properties Using the PRC

There's a problem with the IDK PRC API for search that's tripped up users in the dev2dev forums and that stymied me for the first time today while coding up a custom search application for one of our customers.

The problem is that there's a hardcoded limitation in the IDK that prevents you from calling PortalField.forID if the passed in object ID is less than 100. This prevents you from searching on some really useful properties, including e-mail address! For the life of me, I can't figure out why this limitation was imposed.

The good news is that I found a workaround. It involves a quick two-file IDK patch that entails subclassing two classes. The only catch is that you need to put the child classes in the same package as the IDK (because the parent classes have package-private constructors).

Here's the source code that does the trick.

com.plumtree.remote.prc.search.IntrinsicPortalField.java:

package com.plumtree.remote.prc.search;

import com.plumtree.remote.prc.search.PortalField;
import com.plumtree.remote.prc.search.xp.*;

public class IntrinsicPortalField extends PortalField {
private IntrinsicPortalField(IntrinsicXPPortalField xpField) {
super(xpField);
}

public static final IntrinsicPortalField EMAIL_ADDRESS;

static {
EMAIL_ADDRESS = new IntrinsicPortalField(IntrinsicXPPortalField.forID(26));
}
}

com.plumtree.remote.prc.search.xp.IntrinsicXPPortalField.java:

package com.plumtree.remote.prc.search.xp;

import com.plumtree.openfoundation.util.XPIllegalArgumentException;

public class IntrinsicXPPortalField extends XPPortalField {

private IntrinsicXPPortalField(String name, boolean isSearchable, boolean isRetrievable) {
super(name, isSearchable, isRetrievable);
}

public static IntrinsicXPPortalField forID(int propertyId) throws XPIllegalArgumentException {
return new IntrinsicXPPortalField("ptportal.propertyid." + propertyId, true, true);
}
}

I used e-mail address (ID = 26) as an example, but you can put any properties in there that you want. Then, when you're setting up your search filter, just use IntrinsicPortalField instead of PortalField. For example:

IFilterClause filter = searchFactory.createOrFilterClause();
filter.addStatement(IntrinsicPortalField.EMAIL_ADDRESS, Operator.Contains, searchQuery);

Since IntrinsicPortalField is a subclass of PortalField, the PRC has no problem with it. I've tested this with e-mail address and it works flawlessly. I'm sure other properties will work perfectly well too.

Enjoy!

Comments

Comments are listed in date ascending order (oldest first)

« Back|Archive|Next »