aw/ezp-fetch-bundle

This package is abandoned and no longer maintained. No replacement package was suggested.

A content query language for ezpublish 5

Installs: 44

Dependents: 0

Suggesters: 0

Security: 0

Stars: 5

Watchers: 4

Forks: 2

Type:ezpublish-bundle

dev-master 2015-09-02 09:04 UTC

This package is not auto-updated.

Last update: 2020-02-21 15:52:27 UTC


README

This project is no longer maintained

AwEzpFetchBundle

Presentation

AwEzpFetchBundle is a facade for the search service. It brings a content query language for eZ Publish 5.

Bundle documentation

The bundle documentation is available in Resources/doc/index.rst

Read the Documentation

Installation

  1. With Composer add the following to your composer.json file, then run composer update command:

        {
            require: {
                "aw/ezp-fetch-bundle": "dev-master",
            }
        }
  2. Register AwEzpFetchBundle by adding following to EzPublishKernel.php file:

    
        <?php
    
        // EzPublishKernel.php
        $bundles = array(
            // ...
            new Aw\Ezp\FetchBundle\AwEzpFetchBundle(),
            // ...
        );

Usage examples

Example 1

<?php

// In controller get the fetch service
$fetcher = $this->get('aw_ezp_fetch');

$query = "{filter: {parent_location_id {EQ 2}}, limit: 20, sort: {date_modified DESC}}";

$result = $fetcher->fetch($query);

Example 2

<?php

// In controller get the fetch service
$fetcher = $this->get('aw_ezp_fetch');

$query = "{filter: {AND [subtree: {EQ '/1/2'}, visibility: {EQ true}]}, limit: 20}";

$result = $fetcher->fetch($query);

Example 3

<?php
// In controller get the fetch service
$fetcher = $this->get('aw_ezp_fetch');

$query = <<<EOS
filter:
      AND:
           - parent_location_id: {IN [2, 60]}
           - date_metadata.modified: {BETWEEN [2012-12-14, 2013-01-25]}
           - visibility: {EQ  true}
           - OR:
              - field.name: {EQ News}
              - full_text: {LIKE 'Press Release*'}

sort: {field.landing_page/name ASC, date_modified DESC}
limit: 12
offset: 14

EOS;

$result = $fetcher->fetch($query);

Example 4

<?php

// In controller get the fetch service
$fetcher = $this->get('aw_ezp_fetch');

$query = <<<EOS
filter:
      AND:
           - parent_location_id: {IN [2, 60]}
           - date_metadata.modified: {BETWEEN [2012-12-14, 2013-01-25]}
           - visibility: {EQ  true}
           - OR:
              - field.name: {EQ News}
              - full_text: {LIKE Press Release*}

sort:
     field.landing_page/name: ASC
     date_modified: DESC

limit: 12
offset: 14

EOS;

$result = $fetcher->fetch($query);

Example 5

<?php

// In controller get the fetch service
$fetcher = $this->get('aw_ezp_fetch');

$query = "{filter: {AND [subtree: {EQ @subtree}, visibility: {EQ true}]}  , limit: @limit, offset: @offset}";

$preparedFetch = $fetcher->prepare($query);

$preparedFetch->bindParam('@subtree', '/1/2');
$preparedFetch->bindParam('@offset', 0);
$preparedFetch->bindParam('@limit', 20);

$result = $preparedFetch->fetch();

//you can rebind any parameter and refetch

$preparedFetch->bindParam('@offset', 20);

$result = $preparedFetch->fetch();

License

The code is released under the MIT License. You can find in Resources/meta/LICENCE