Update documentation for account_quota middleware

Change-Id: I3dc7930ee2a1eb26b1f60e83fce2bc1bea0a8b0f
This commit is contained in:
Christian Schwede 2013-04-03 10:29:50 +02:00
parent ba5a0b0fe1
commit e5cd78d902
2 changed files with 41 additions and 24 deletions

View File

@ -194,6 +194,13 @@ Container Quotas
:members: :members:
:show-inheritance: :show-inheritance:
Account Quotas
==============
.. automodule:: swift.common.middleware.account_quotas
:members:
:show-inheritance:
.. _slo-doc: .. _slo-doc:
Static Large Objects Static Large Objects
@ -209,10 +216,3 @@ List Endpoints
.. automodule:: swift.common.middleware.list_endpoints .. automodule:: swift.common.middleware.list_endpoints
:members: :members:
:show-inheritance: :show-inheritance:
Account Quotas
================
.. automodule:: swift.common.middleware.account_quotas
:members:
:show-inheritance:

View File

@ -13,7 +13,38 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
""" Account quota middleware for Openstack Swift Proxy """ """
``account_quotas`` is a middleware which blocks write requests (PUT, POST) if a
given account quota (in bytes) is exceeded while DELETE requests are still
allowed.
``account_quotas`` uses the ``x-account-meta-quota-bytes`` metadata entry to
store the quota. Write requests to this metadata entry are only permitted for
resellers. There is no quota limit if ``x-account-meta-quota-bytes`` is not
set.
The ``account_quotas`` middleware should be added to the pipeline in your
``/etc/swift/proxy-server.conf`` file just after any auth middleware.
For example::
[pipeline:main]
pipeline = catch_errors cache tempauth account_quotas proxy-server
[filter:account_quotas]
use = egg:swift#account_quotas
To set the quota on an account::
swift -A http://127.0.0.1:8080/auth/v1.0 -U account:reseller -K secret \
post -m quota-bytes:10000
Remove the quota::
swift -A http://127.0.0.1:8080/auth/v1.0 -U account:reseller -K secret \
post -m quota-bytes:
"""
from swift.common.swob import HTTPForbidden, HTTPRequestEntityTooLarge, \ from swift.common.swob import HTTPForbidden, HTTPRequestEntityTooLarge, \
HTTPBadRequest, wsgify HTTPBadRequest, wsgify
@ -22,25 +53,11 @@ from swift.proxy.controllers.base import get_account_info
class AccountQuotaMiddleware(object): class AccountQuotaMiddleware(object):
""" """ Account quota middleware
account_quotas is a middleware which blocks write requests (PUT, POST) if a
given quota (in bytes) is exceeded while DELETE requests are still allowed.
account_quotas uses the x-account-meta-quota-bytes metadata to store the See above for a full description.
quota. Write requests to this metadata setting are only allowed for
resellers. There is no quota limit if x-account-meta-quota-bytes is not
set.
The following shows an example proxy-server.conf:
[pipeline:main]
pipeline = catch_errors cache tempauth account-quotas proxy-server
[filter:account-quotas]
use = egg:swift#account_quotas
""" """
def __init__(self, app, *args, **kwargs): def __init__(self, app, *args, **kwargs):
self.app = app self.app = app