summaryrefslogtreecommitdiffstats
path: root/openstack/common/rpc/serializer.py
diff options
context:
space:
mode:
authorDan Smith <danms@us.ibm.com>2013-05-19 14:13:59 -0700
committerDan Smith <danms@us.ibm.com>2013-05-21 06:40:51 -0700
commit93ee6e3bfb280bfe5b5f6617c5d89c65cc54028d (patch)
tree7dd9d7485b729bf1fa613c3b877912a2be729750 /openstack/common/rpc/serializer.py
parentdf7ea8308363235afba503f8562341bd2e3dce4f (diff)
downloadoslo-93ee6e3bfb280bfe5b5f6617c5d89c65cc54028d.tar.gz
oslo-93ee6e3bfb280bfe5b5f6617c5d89c65cc54028d.tar.xz
oslo-93ee6e3bfb280bfe5b5f6617c5d89c65cc54028d.zip
Add generic serialization support
This adds a generic serialization model that the RpcProxy and RpcDispatcher will use to serialize and deserialize arguments and return values. The base definition is provided, as well as a default NoOpSerializer which performs no special action (retaining the existing behavior). Related to blueprint rpc-object-serialization Change-Id: I0a33baddee3e28dfc47100eb3216b679558b0bdd
Diffstat (limited to 'openstack/common/rpc/serializer.py')
-rw-r--r--openstack/common/rpc/serializer.py52
1 files changed, 52 insertions, 0 deletions
diff --git a/openstack/common/rpc/serializer.py b/openstack/common/rpc/serializer.py
new file mode 100644
index 0000000..0a2c9c4
--- /dev/null
+++ b/openstack/common/rpc/serializer.py
@@ -0,0 +1,52 @@
+# Copyright 2013 IBM Corp.
+#
+# Licensed under the Apache License, Version 2.0 (the "License"); you may
+# not use this file except in compliance with the License. You may obtain
+# a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+# License for the specific language governing permissions and limitations
+# under the License.
+
+"""Provides the definition of an RPC serialization handler"""
+
+import abc
+
+
+class Serializer(object):
+ """Generic (de-)serialization definition base class"""
+ __metaclass__ = abc.ABCMeta
+
+ @abc.abstractmethod
+ def serialize_entity(self, context, entity):
+ """Serialize something to primitive form.
+
+ :param context: Security context
+ :param entity: Entity to be serialized
+ :returns: Serialized form of entity
+ """
+ pass
+
+ @abc.abstractmethod
+ def deserialize_entity(self, context, entity):
+ """Deserialize something from primitive form.
+
+ :param context: Security context
+ :param entity: Primitive to be deserialized
+ :returns: Deserialized form of entity
+ """
+ pass
+
+
+class NoOpSerializer(Serializer):
+ """A serializer that does nothing"""
+
+ def serialize_entity(self, context, entity):
+ return entity
+
+ def deserialize_entity(self, context, entity):
+ return entity