<link field="metarecord" reltype="has_a" key="id" map="" class="mmr"/>
</links>
</class>
+ <class id="mfae" controller="open-ils.cstore open-ils.pcrud" oils_obj:fieldmapper="metabib::facet_entry" reporter:label="Combined Facet Entry View" oils_persist:readonly="true">
+ <oils_persist:source_definition>
+ SELECT * FROM (
+ SELECT * FROM metabib.author_field_entry
+ UNION ALL
+ SELECT * FROM metabib.keyword_field_entry
+ UNION ALL
+ SELECT * FROM metabib.title_field_entry
+ UNION ALL
+ SELECT * FROM metabib.subject_field_entry
+ UNION ALL
+ SELECT * FROM metabib.series_field_entry
+ )x
+ WHERE x.index_vector = ''
+ </oils_persist:source_definition>
+ <fields>
+ <field name="field" reporter:datatype="link"/>
+ <field name="id" reporter:datatype="id" />
+ <field name="source" reporter:datatype="link"/>
+ <field name="value" reporter:datatype="text"/>
+ </fields>
+ <links>
+ <link field="source" reltype="has_a" key="id" map="" class="bre"/>
+ <link field="field" reltype="has_a" key="id" map="" class="cmf"/>
+ </links>
+ </class>
+ <class id="mfe" controller="open-ils.cstore open-ils.pcrud" oils_obj:fieldmapper="metabib::field_entry" reporter:label="Combined Field Entry View" oils_persist:readonly="true">
+ <oils_persist:source_definition>
+ SELECT * FROM metabib.author_field_entry
+ UNION ALL
+ SELECT * FROM metabib.keyword_field_entry
+ UNION ALL
+ SELECT * FROM metabib.title_field_entry
+ UNION ALL
+ SELECT * FROM metabib.subject_field_entry
+ UNION ALL
+ SELECT * FROM metabib.series_field_entry
+ </oils_persist:source_definition>
+ <fields>
+ <field name="field" reporter:datatype="link"/>
+ <field name="id" reporter:datatype="id" />
+ <field name="source" reporter:datatype="link"/>
+ <field name="value" reporter:datatype="text"/>
+ </fields>
+ <links>
+ <link field="source" reltype="has_a" key="id" map="" class="bre"/>
+ <link field="field" reltype="has_a" key="id" map="" class="cmf"/>
+ </links>
+ </class>
<class id="mkfe" controller="open-ils.cstore" oils_obj:fieldmapper="metabib::keyword_field_entry" oils_persist:tablename="metabib.keyword_field_entry" reporter:label="Keyword Field Entry">
<fields oils_persist:primary="id" oils_persist:sequence="metabib.keyword_field_entry_id_seq">
<field name="field" reporter:datatype="link"/>
# pull any existing results from the cache
my $key = search_cache_key($method, $search_hash);
+ my $facet_key = $key.'_facets';
my $cache_data = $cache->get_cache($key) || {};
# keep retrieving results until we find enough to
my $current_page_summary = {};
my $global_summary = {checked => 0, visible => 0, excluded => 0, deleted => 0, total => 0};
my $is_real_hit_count = 0;
+ my $new_ids = [];
for($page = 0; $page < $max_superpages; $page++) {
$results = [map {[$_->{id}, $_->{rel}, $_->{record}]} @$results];
}
+ push @$new_ids, grep {defined($_)} map {$_->[0]} @$results;
+
$results = [grep {defined $_->[0]} @$results];
cache_staged_search_page($key, $page, $summary, $results) if $docache;
}
}
}
- return {
+ $conn->respond_complete({
count => $est_hit_count,
core_limit => $search_hash->{core_limit},
superpage_size => $search_hash->{check_limit},
superpage_summary => $current_page_summary,
+ facet_key => $facet_key,
ids => \@results
- };
+ });
+
+ cache_facets($facet_key, $new_ids) if $docache;
+ return undef;
}
# creates a unique token to represent the query in the cache
return $pfx . md5_hex($method . $s);
}
+sub retrieve_cached_facets {
+ my $self = shift;
+ my $client = shift;
+ my $key = shift;
+
+ return undef unless ($key =~ /_facets$/);
+
+ return $cache->get_cache($key) || {};
+}
+__PACKAGE__->register_method(
+ method => "retrieve_cached_facets",
+ api_name=> "open-ils.search.facet_cache.retrieve"
+);
+
+
+sub cache_facets {
+ # add facets for this search to the facet cache
+ my($key, $results) = @_;
+ my $data = $cache->get_cache($key);
+ $data ||= {};
+
+ return undef unless (@$results);
+
+ # The query we're constructing
+ #
+ # select cmf.id,
+ # mfae.value,
+ # count(distinct mfae.source)
+ # from metabib.facet_entry mfae
+ # join config.metabib_field cmf on (mfae.field = cmf.id)
+ # where cmf.facet_field
+ # and mfae.source in IDLIST
+ # group by 1,2;
+
+ my $facets = $U->cstorereq( "open-ils.cstore.json_query.atomic",
+ { select => {
+ cmf => [ 'id' ],
+ mfae => [
+ 'value',
+ {
+ transform => 'count',
+ distinct => 1,
+ column => 'source',
+ alias => 'count',
+ aggregate => 1
+ }
+ ]
+ },
+ from => { mfae => 'cmf' },
+ where => { '+cmf' => 'facet_field', '+mfae' => { source => $results } }
+ }
+ );
+
+ for my $facet (@$facets) {
+ next unless ($facet->{value});
+ $data->{$facet->{id}}->{$facet->{value}} += $facet->{count};
+ }
+
+ $logger->info("facet compilation: cached with key=$key");
+
+ $cache->put_cache($key, $data, $cache_timeout);
+}
+
sub cache_staged_search_page {
# puts this set of results into the cache
my($key, $page, $summary, $results) = @_;