ckanext-sitesearch
Index different CKAN entities in Solr, not just datasets
Requirements
This extension requires CKAN 2.9 or higher and Python 3
Features
Search actions
ckanext-sitesearch allows Solr-powered searches on the following CKAN entities:
| Entity | Action | Permissions | Notes | 
|---|---|---|---|
| Organizations | organization_search | Public | |
| Groups | group_search | Public | |
| Users | user_search | Sysadmins only | |
| Pages | page_search | Public (individual page permissions apply) | Requires ckanext-pages | 
All *_search actions support most of the same paramters that package_search, except the facet* and include_* ones. That includes q, fq, rows, start and sort.
In all actions, the output matches the one of package_search as well, an object with a count key and a results one, wich is a list of the corresponding entities dict (ie the result of organization_show, user_show etc):
{
    "count": 2,
    "results": [
        
    
     ,
        
     
      ,
    ]
}
      
     Additionally the plugin registers a site_search action that performs a search across all entities that the user is allowed to, including datasets. Results are returned in an object including the keys for which the user has permission to search on. For instance for a sysadmin user that has access to all searches:
{
    "datasets": 
       
        ,
    "organizations": 
        
         ,
    "groups": 
         
          ,
    "users": 
          
           ,
    "pages": 
           
             } 
            
           
          
         
        For each item, the results object is the one described above (count and results keys).
Note that all parameters are passed unchanged to each of the search actions, so this site-wide search is mostly useful for free-text searches like q=flood.
CLI
The plugin inlcudes a ckan command to reindex the current entities in the database in Solr:
ckan sitesearch rebuild 
   
    Where entity_type is one of organizations, groups, users or pages. You can also pass the id or name of a particular entity to index just that particular one:
ckan sitesearch rebuild organization department-of-transport
Check the command help for additional options:
ckan sitesearch rebuild --help
Installation
To install ckanext-sitesearch:
-  Activate your CKAN virtual environment, for example: . /usr/lib/ckan/default/bin/activate 
-  Clone the source and install it on the virtualenv git clone https://github.com/okfn/ckanext-sitesearch.git cd ckanext-sitesearch pip install -e . pip install -r requirements.txt 
-  Add sitesearchto theckan.pluginssetting in your CKAN config file (by default the config file is located at/etc/ckan/default/ckan.ini).
-  Restart CKAN 
Config settings
None at present
Developer installation
To install ckanext-sitesearch for development, activate your CKAN virtualenv and do:
git clone https://github.com/okfn/ckanext-sitesearch.git
cd ckanext-sitesearch
python setup.py develop
Tests
To run the tests, do:
pytest --ckan-ini=test.ini