[ 
https://issues.apache.org/jira/browse/SOLR-7054?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Noble Paul updated SOLR-7054:
-----------------------------
    Comment: was deleted

(was: Thanks Alexandre. I opened this ticket as a place to discus and finalize 
a clean interface instead of our myriad different APIs. Please feel free to 
suggest alternatives
 
bq.Commit. How do you express that?

same as the /update handler 
POST /docs?commit=true

bq. Default, etc. parameters? UpdateRequestChains? Do they just apply 
universally? 
haven't yet though through it fully. I would like to use the useParams feature

my suggestion:
different http method gets a separate paramset  ,

write-params="update_param_set" read-params="select_paramset"

{{write-params}} could be  a short form for a union of {{post-params}}, 
{{put-params}}, {{delete-params}}
whereas {{read-params}} could be a short form for a union of {{get-params}} , 
{{head-params}}

Going forward we should open up full REST support to all paths . So we should 
adopt a common mechanism for separate param sets all HTTP methods

example:
{code:xml}
<requestHandler name="/docs" class="solr.RESTHandler"  
write-params="update_paramset" read-params="select_paramset" />
<requestHandler name="/update" class="solr.UpdaterequestHandler"  
useParams="update_paramset" />
<requestHandler name="/select" class="solr.SearchHandler"  
useParams="update_paramset" />
{code}
bq.What happens with custom end-points? Or is /docs just a new end-point and 
the rest maintain the old syntax?
yes, you are right,  /docs just a new end-point and mainly a replacement for 
{{/update/*}} , {{/select}} and {{/get}}



)

> a pure REST interface for all operations in Solr
> ------------------------------------------------
>
>                 Key: SOLR-7054
>                 URL: https://issues.apache.org/jira/browse/SOLR-7054
>             Project: Solr
>          Issue Type: Improvement
>            Reporter: Noble Paul
>
> It would be a single handler say {{/docs}}
> GET would do a query
> GET /docs is equivalent to /select/q=*:*
> GET /docs?q=a:b will be equivalent to /select?q=a:b
> GET /docs/docId will be equivalent to /select?q=id:docId
> PUT/POST /docs is equivalent to /update and the default format for json would 
> be that of /update/json/docs
> DELETE /docs/id will do a delete by id
> DELETE /docs?q=x:val is delete by query
> We can think of implementing this as a new {{RequestHandler}} without 
> changing anything in Solr. Itcan be configured as follows
> {code:xml}
> <requestHandler name="/docs" class="RestRequestHandler" 
>   get="/select" <!--This will just use the /select handler to handle http GET 
> -->
>   post="/update/json/docs" <!-- All POST requests will use the handloer 
> configured at /update/json/docs -->
>   put="/update/json/docs" <!-- PUT requests will use same as POST -->
>   delete="/update"/> <!-- DELETE requests will use /update as well --> 
> {code}
>   
>   



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to