this.query = query;
this.cacheKey = cacheKey;
}
public QueryMetadata getMetaData(EntityResolver resolver) {
final QueryMetadata metadata = query.getMetaData(resolver);
// the way paginated queries work on the server is that they are never cached
// (IncrementalFaultList interception happens before cache interception). So
// overriding caching settings in the metadata will only affect
// ClientServerChannel behavior
return new QueryMetadata() {
public Query getOrginatingQuery() {
return null;
}
public String getCacheKey() {
return cacheKey;
}
public SQLResultSetMapping getResultSetMapping() {
return metadata.getResultSetMapping();
}
public String[] getCacheGroups() {
return metadata.getCacheGroups();
}
/**
* @deprecated since 3.0 in favor of 'getCacheStrategy'.
*/
public String getCachePolicy() {
return metadata.getCachePolicy();
}
/**
* @since 3.0
*/
public QueryCacheStrategy getCacheStrategy() {
return metadata.getCacheStrategy();
}
public DataMap getDataMap() {
return metadata.getDataMap();
}
public DbEntity getDbEntity() {
return metadata.getDbEntity();
}
public int getFetchLimit() {
return metadata.getFetchLimit();
}
public int getFetchStartIndex() {
return metadata.getFetchStartIndex();
}
public ObjEntity getObjEntity() {
return metadata.getObjEntity();
}
public ClassDescriptor getClassDescriptor() {
return metadata.getClassDescriptor();
}
public int getPageSize() {
return metadata.getPageSize();
}
public PrefetchTreeNode getPrefetchTree() {
return metadata.getPrefetchTree();
}
public Procedure getProcedure() {
return metadata.getProcedure();
}
public Map<String, String> getPathSplitAliases() {
return metadata.getPathSplitAliases();
}
public boolean isFetchingDataRows() {
return metadata.isFetchingDataRows();
}
public boolean isRefreshingObjects() {
return metadata.isRefreshingObjects();
}
public boolean isResolvingInherited() {
return metadata.isResolvingInherited();
}
};
}