Tutorials

Extending FullTextSearch for DataObjects

Posted by Mo on 17 June 2011 | 16 Comments

Tags: , ,

I have been wrestling over the problem of extending the default search functionality in Silverstripe to not only search Page objects, but other DataObjects as well.

In the end I came up with a workable solution thanks to the help of Katja Durrani over at the Silverstripe forum.

It seems that you can't currently get add searchable objects to FullTextSearchable by any means. Instead, you have to perform a bit of a hack (in my opinion) to the results method on your Page_Controller.

Before getting that far though, you first need to allow any DataObjects you want searched to be indexed. Do the following to your DataObject's model:


public static $indexes = array(
    "fulltext (Title, Content)"
);

Then rebuild your database (/dev/build/?flush=all).

Now you can go about adding your search form, as described in the Silverstripe docs. Once this is done, you need to change your results() method in Page_Controller to look more like this:


class Page_Controller extends ContentController {
...
    public function results($data, $form){
        $data = $_REQUEST; 
        
        $query = htmlspecialchars($data['Search'], ENT_QUOTES,'UTF-8'); 
        
        $pages = DataObject::get("SiteTree","MATCH (Title,Content) AGAINST ('$query' IN BOOLEAN MODE)");
        $studies = DataObject::get("CaseStudy","MATCH (Title,Content) AGAINST ('$query' IN BOOLEAN MODE)");
        
        $searchresults = new DataObjectSet();
        $searchresults->merge($pages);
        $searchresults->merge($studies);
        
        if($searchresults){ 
            $data['Results'] = $searchresults;           
        } else { 
            $data['Results'] = ''; 
        } 
        
        $data['Title'] = 'Search Results'; 

        return $this->customise($data)->renderWith(array('Search_results','Page')); 
    }
...
}

What this new method does, is use the submitted search to perform 2 queries:

  1. Query SiteTree and return any Objects that have match the search term
  2. Query the DataObject (in this case "CaseStudy") in the same way.

If you have more than one DataObject you want to query, you would need to add additional queries for each one.

Finally, you need to merge your two returned DataObjectSet's and then check if they contain any data.

Now you can return this to a custom template (for this example, I have used "Search_results') and there you go!

You can also find this code on Pastie

TrackBacks

No TrackBacks have been submitted for this page.

Trackback URL for this page.

Post your comment

Comments

  • If you're still out of luck, calling your banks to cancel all of your debit and credit cards is a very important next step.

    Posted by GHD Dark , 17/02/2012 9:23am (5 days ago)

  • If you visited a place and the wallet or purse was dropped while you were there, someone might have found it and turned it in to lost and found.

    Posted by Chloe Paddington , 17/02/2012 9:23am (5 days ago)

  • you should call any establishment that you have visited recently, including bars, restaurants,

    Posted by lv monogram, 17/02/2012 9:22am (5 days ago)

  • Thank you very much for posting and sharing this great article. It is so interesting. I want to know some other information about this site. So please give me this news quickly. I always will be aware of you.

    Posted by replica masterpiece, 14/02/2012 4:09am (9 days ago)

  • Thank you very much for posting and sharing this great article. It is so interesting. I want to know some other information about this site. So please give me this news quickly. I always will be aware of you.

    Posted by tag heuer Carrera, 13/02/2012 2:49am (10 days ago)

  • excellent read for me. Must agree that you are one of the best bloggers

    Posted by supra tk society, 11/02/2012 6:42am (11 days ago)


  • ater is dried off, - usually they always shake the boat came. Shox R4 Furthermore, nike shox nz they have Discount Nik nothing to sell, toxic heat of the sun to all ①
    ① Zhejiang dialect Yun students. Crops means.
    Nike Shox R4 This Shox R3 lively Nike Shox R4 Shoes modern town a little so he became a half-dead desert island: Cheap Nike Shox R4 the traffic cut off, the lack o..

    Posted by cheap nike shox, 07/02/2012 7:01am (15 days ago)

  • ater is dried off, - usually they always shake the boat came. <strong><a href="http://www.cheapnikeshoesshox.com/nike-shox-r4-shoes-c-10.html" title="Shox R4">Shox R4</a></strong> Furthermore, <strong><a href="http://www.cheapnikeshoesshox.com/" title="nike shox nz">nike shox nz</a></strong> they have <strong><a href="http://www.cheapnikeshoesshox.com/nike-shox-r3-shoes-c-6.html" title="Discount Nik">Discount Nik</a></strong> nothing to sell, toxic heat of the sun to all ① <BR> ① Zhejiang dialect Yun students. Crops means. <BR> <strong><a href="http://www.cheapnikeshoesshox.com/nike-shox-r4-shoes-c-10.html" title="Nike Shox R4">Nike Shox R4</a></strong> This <strong><a href="http://www.cheapnikeshoesshox.com/nike-shox-r3-shoes-c-6.html" title="Shox R3">Shox R3</a></strong> lively <strong><a href="http://www.cheapnikeshoesshox.com/nike-shox-r4-shoes-c-10.html" title="Nike Shox R4 Shoes">Nike Shox R4 Shoes</a></strong> modern town a little so he became a half-dead desert island: <strong><a href="http://www.cheapnikeshoesshox.com/nike-shox-r4-shoes-c-10.html" title="Cheap Nike Shox R4">Cheap Nike Shox R4</a></strong> the traffic cut off, the lack o...

    Posted by cheap nike shox, 07/02/2012 7:01am (15 days ago)

  • own the [b][url=http://www.cheapnikeshoesshox.com/nike-shox-r2-shoes-c-25.html]Nike Shox R2 Shoes[/url][/b] body.
    This [b][url=http://www.cheapnikeshoesshox.com/nike-shox-r2-shoes-c-25.html]Nike Shox R2[/url][/b] night was no moon, river jet [b][url=http://www.cheapnikeshoesshox.com/]mens nike shoes[/url][/b] black, looking down from the top of the bridge, it seems very [b][url=http://www.cheapnikeshoesshox.com/nike-shox-r2-shoes-c-25.html]Shox R2[/url][/b] deep. Gradually saw it, there are two three small flash fire in the [b][url=http://www.cheapnikeshoesshox.com/nike-shox-r2-shoes-c-25.html]Discount Nik[/url][/b] river center. There were vague sound. However, [b][url=http://www.cheapnikeshoesshox.com/nike-shox-oz-shoes-c-22.html]nike shox oz[/url][/b] more recent fire, the [b][url=http://www.cheapnikeshoesshox.com/nike-shox-r3-shoes-c-6.html]Nike Shox R3 Shoes[/url][/b] bridge is coming, and I keep your eyes [b][url=http://www.cheapnikeshoesshox.com/nike-shox-r3-shoes-c-6.html]Nike Shox R3[/url][/b] open t...

    Posted by cheap nike shox, 07/02/2012 7:01am (15 days ago)

  • There is definitely a lot of talent sitting here. I am such a big fan. Keep up the good work.

    Posted by Plagiarism checker, 06/02/2012 11:19am (16 days ago)

RSS feed for comments on this page | RSS feed for all comments