Skip to content

Component API Multirequest

jbaicoianu edited this page Jul 26, 2012 · 4 revisions

Using the /elation/multirequest facility, it's possible to call multiple server-side components with one HTTP call, and return all of their results in a single encapsulated response. This response can be a mixture of rendered HTML, JSON data, XML, etc. as requested by the frontend scripts.

Let's extend our Search example a bit. Say now we want to query our own database servers and also a third-party search API, and we want to show the results side by side. The files now look like this:

####components/search/search.php class Component_search extends Component { public function controller_search($args) { $query = any($args["query"], "default"); $vars["results_db"] = DataManager::query("db.posts.search#{$query}", "SELECT * FROM posts WHERE tags LIKE :query", array(":query" => "%{$query}%")); $vars["results_api"] = DataManager::query("rest.instasrch.posts#{$query}", array("query" => $query)); return $this->GetComponentResponse("./search.tpl", $vars); } public function controller_result($args) { $vars["result"] = $args["item"]; return $this->GetComponentResponse("./result.tpl", $vars); } }

####components/search/templates/search.tpl

{component name="utils.list" itemcomponent="search.result" items=$results_db.rows}
{component name="utils.list" itemcomponent="search.result" items=$results_api.rows}

####components/search/templates/result.tpl

{$result->title|escape:html}

{$result->contents|escape:html}

{$result->url|escape:html}

If we wanted to make a request with a new query from the client side and update the contents of our two divs automatically, we can accomplish this end to end with a single JavaScript call:

elation.ajax.get("/elation/multirequest.ajax?requests=" + JSON.stringify([
    { component: "search", args: { query: "hello" }, assign: "search" },
    { component: "utils.list", args: { itemcomponent: "search.result", items: "$results_db.rows" }, target="results_db"},
    { component: "utils.list", args: { itemcomponent: "search.result", items: "$results_api.rows" }, target="results_api"}
  ]));

This will render two separate blocks of HTML, one for db results and the other for API results, and automatically inject them into the HTML using the specified target ids.

Clone this wiki locally