<div dir="ltr">Kevin, thanks for the info! I agree with you. RFC is the authority. use payload in the DELETE isn't good way.</div><div class="gmail_extra"><br><div class="gmail_quote">2014-12-09 7:58 GMT+08:00 Kevin L. Mitchell <span dir="ltr"><<a href="mailto:kevin.mitchell@rackspace.com" target="_blank">kevin.mitchell@rackspace.com</a>></span>:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">On Tue, 2014-12-09 at 07:38 +0800, Alex Xu wrote:<br>
> Not sure all, nova is limited<br>
> at <a href="https://github.com/openstack/nova/blob/master/nova/api/openstack/wsgi.py#L79" target="_blank">https://github.com/openstack/nova/blob/master/nova/api/openstack/wsgi.py#L79</a><br>
> That under our control.<br>
<br>
</span>It is, but the client frameworks aren't, and some of them prohibit<br>
sending a body with a DELETE request.  Further, RFC7231 has this to say<br>
about DELETE request bodies:<br>
<br>
        A payload within a DELETE request message has no defined semantics;<br>
        sending a payload body on a DELETE request might cause some existing<br>
        implementations to reject the request.<br>
<br>
(§4.3.5)<br>
<br>
I think we have to conclude that, if we need a request body, we cannot<br>
use the DELETE method.  We can modify the operation, such as setting a<br>
"force" flag, with a query parameter on the URI, but a request body<br>
should be considered out of bounds with respect to DELETE.<br>
<div class="HOEnZb"><div class="h5"><br>
> Maybe not just ask question for delete, also for other method.<br>
><br>
> 2014-12-09 1:11 GMT+08:00 Kevin L. Mitchell <<a href="mailto:kevin.mitchell@rackspace.com">kevin.mitchell@rackspace.com</a>>:<br>
>         On Mon, 2014-12-08 at 14:07 +0800, Eli Qiao wrote:<br>
>         > I wonder if we can use body in delete, currently , there isn't any<br>
>         > case used in v2/v3 api.<br>
><br>
>         No, many frameworks raise an error if you try to include a body with a<br>
>         DELETE request.<br>
>         --<br>
>         Kevin L. Mitchell <<a href="mailto:kevin.mitchell@rackspace.com">kevin.mitchell@rackspace.com</a>><br>
>         Rackspace<br>
<br>
--<br>
Kevin L. Mitchell <<a href="mailto:kevin.mitchell@rackspace.com">kevin.mitchell@rackspace.com</a>><br>
Rackspace<br>
<br>
<br>
_______________________________________________<br>
OpenStack-dev mailing list<br>
<a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
</div></div></blockquote></div><br></div>