OpenStack Object Storage (Swift) before 2.3.0, when allow_version is configured, allows remote authenticated users to delete the latest version of an object by leveraging listing access to the x-versions-location container.
{
"binaries": [
{
"binary_version": "1.13.1-0ubuntu1.2",
"binary_name": "python-swift"
},
{
"binary_version": "1.13.1-0ubuntu1.2",
"binary_name": "swift"
},
{
"binary_version": "1.13.1-0ubuntu1.2",
"binary_name": "swift-account"
},
{
"binary_version": "1.13.1-0ubuntu1.2",
"binary_name": "swift-container"
},
{
"binary_version": "1.13.1-0ubuntu1.2",
"binary_name": "swift-object"
},
{
"binary_version": "1.13.1-0ubuntu1.2",
"binary_name": "swift-object-expirer"
},
{
"binary_version": "1.13.1-0ubuntu1.2",
"binary_name": "swift-proxy"
}
],
"availability": "No subscription required"
}