summaryrefslogtreecommitdiffstats
path: root/gluster/swift/obj
diff options
context:
space:
mode:
authorPeter Portante <peter.portante@redhat.com>2013-05-24 11:35:59 -0400
committerLuis Pabon <lpabon@redhat.com>2013-06-04 11:27:02 -0700
commit3435c59ba3a679867adffa84719b8648c9fbf601 (patch)
treeb13dcacc4a2b6eb6fe013b9fe88cb30cbead21af /gluster/swift/obj
parent40c313378e5fffb846f1fd143573a687e2774b28 (diff)
Forward port PDQ 3489: turn off cont & act updates
This is a simple sub-classing of the proper update methods to just no-op their behavior. Change-Id: Ib1ae5234d372cbce572da34cfe702235b78f2310 Signed-off-by: Peter Portante <peter.portante@redhat.com> Reviewed-on: http://review.gluster.org/5088 Reviewed-by: Luis Pabon <lpabon@redhat.com> Tested-by: Luis Pabon <lpabon@redhat.com>
Diffstat (limited to 'gluster/swift/obj')
-rw-r--r--gluster/swift/obj/server.py30
1 files changed, 29 insertions, 1 deletions
diff --git a/gluster/swift/obj/server.py b/gluster/swift/obj/server.py
index 1223036..084346a 100644
--- a/gluster/swift/obj/server.py
+++ b/gluster/swift/obj/server.py
@@ -27,8 +27,36 @@ from gluster.swift.common.DiskFile import Gluster_DiskFile
server.DiskFile = Gluster_DiskFile
+class ObjectController(server.ObjectController):
+ """
+ Subclass of the object server's ObjectController which replaces the
+ container_update method with one that is a no-op (information is simply
+ stored on disk and already updated by virtue of performing the file system
+ operations directly).
+ """
+
+ def container_update(self, op, account, container, obj, request,
+ headers_out, objdevice):
+ """
+ Update the container when objects are updated.
+
+ For Gluster, this is just a no-op, since a container is just the
+ directory holding all the objects (sub-directory hierarchy of files).
+
+ :param op: operation performed (ex: 'PUT', or 'DELETE')
+ :param account: account name for the object
+ :param container: container name for the object
+ :param obj: object name
+ :param request: the original request object driving the update
+ :param headers_out: dictionary of headers to send in the container
+ request(s)
+ :param objdevice: device name that the object is in
+ """
+ return
+
+
def app_factory(global_conf, **local_conf):
"""paste.deploy app factory for creating WSGI object server apps"""
conf = global_conf.copy()
conf.update(local_conf)
- return server.ObjectController(conf)
+ return ObjectController(conf)