camel-dev mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From Matt Sicker <boa...@gmail.com>
Subject Re: Component Design Question
Date Wed, 18 Jun 2014 03:01:45 GMT
Having type converters available for everything helps a lot in minimising
the need to worry about return formats. You could by default return the
native Node objects and provide type converters to List<Map<String,
Object>>.


On 17 June 2014 20:54, Gregor Zurowski <gregor@zurowski.org> wrote:

> Hi Everyone:
>
> A recent discussion on the camel-users list [1] showed that the
> camel-jcr component needs some enhancements to better support
> real-world use cases. I would like to add query functionality, so that
> users are able to submit JCR-SQL or JCR-XPath queries and retrieve
> matching nodes. A possible implementation could look as follows:
>
> - Add support for new values to CamelJcrOperation header with the
> names "JcrQuerySql" and "JcrQueryXPath" for triggering queries by the
> producer.
> - The actual query is read from the body of the IN message.
> - Matching nodes are returned in the body of the OUT message.
>
> The question is how to return the resulting nodes? I considered the
> following approaches:
>
> 1) Simply return an array of strings where each string is the UUID of
> a matching node, e.g. [c042662a-f5be-11e3-8344-b2227cce2b54,
> c0426b5c-f5be-11e3-8344-b2227cce2b54, ...]. The downside of this
> approach is that the client would need to submit follow-up requests
> for each UUID (e.g. with the CamelJcrGetById operation).
>
> 2) Return a list of javax.jcr.Node [2] instances of all matching
> nodes. This is similar to what the current consumer implementation
> returns (which is a list of javax.jcr.observation.Event instances).
>
> 3) Return a list of custom items. Each item is a translated version of
> the javax.jcr.Node type where each field was converted into a common
> Java type (similar to what the camel-cmis component is doing when
> translating CMIS query results into a List<Map<String, Object>> data
> structure).
>
> What would be the best approach to return query results by the
> producer, i.e. what would be the Camel-way of returning the results?
>
> Thanks in advance,
> Gregor
>
> [1] http://camel.465427.n5.nabble.com/Camel-JCR-examples-td5746406.html
> [2] http://www.day.com/maven/jsr170/javadocs/jcr-2.0/javax/jcr/Node.html
>



-- 
Matt Sicker <boards@gmail.com>

Mime
  • Unnamed multipart/alternative (inline, None, 0 bytes)
View raw message