You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

139 lines
5.2 KiB

#!/usr/bin/python
# -- Content-Encoding: UTF-8 --
"""
The configuration module.
:copyright: Copyright 2018, Thomas Calmant
:license: Apache License 2.0
:version: 0.3.2
..
Copyright 2018 Thomas Calmant
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.
"""
import sys
# ------------------------------------------------------------------------------
# Module version
__version_info__ = (0, 3, 2)
__version__ = ".".join(str(x) for x in __version_info__)
# Documentation strings format
__docformat__ = "restructuredtext en"
# ------------------------------------------------------------------------------
class LocalClasses(dict):
"""
Associates local classes with their names (used in the jsonclass module)
"""
def add(self, cls, name=None):
"""
Stores a local class
:param cls: A class
:param name: Custom name used in the __jsonclass__ attribute
"""
self[name or cls.__name__] = cls
# ------------------------------------------------------------------------------
class Config(object):
"""
This is pretty much used exclusively for the 'jsonclass'
functionality... set use_jsonclass to False to turn it off.
You can change serialize_method and ignore_attribute, or use
the local_classes.add(class) to include "local" classes.
"""
def __init__(self, version=2.0, content_type="application/json-rpc",
user_agent=None, use_jsonclass=True,
serialize_method='_serialize',
ignore_attribute='_ignore',
serialize_handlers=None):
"""
Sets up a configuration of JSONRPClib
:param version: JSON-RPC specification version
:param content_type: HTTP content type header value
:param user_agent: The HTTP request user agent
:param use_jsonclass: Allow bean marshalling
:param serialize_method: A string that references the method on a
custom class object which is responsible for
returning a tuple of the arguments and a dict
of attributes.
:param ignore_attribute: A string that references the attribute on a
custom class object which holds strings and/or
references of the attributes the class
translator should ignore.
:param serialize_handlers: A dictionary of dump handler functions by
type for additional type support and for
overriding dump of built-in types in utils
"""
# JSON-RPC specification
self.version = version
# Change to False to keep __jsonclass__ entries raw.
self.use_jsonclass = use_jsonclass
# it SHOULD be 'application/json-rpc'
# but MAY be 'application/json' or 'application/jsonrequest'
self.content_type = content_type
# Default user agent
if user_agent is None:
user_agent = 'jsonrpclib/{0} (Python {1})'.format(
__version__,
'.'.join(str(ver) for ver in sys.version_info[0:3]))
self.user_agent = user_agent
# The list of classes to use for jsonclass translation.
self.classes = LocalClasses()
# The serialize_method should be a string that references the
# method on a custom class object which is responsible for
# returning a tuple of the constructor arguments and a dict of
# attributes.
self.serialize_method = serialize_method
# The ignore attribute should be a string that references the
# attribute on a custom class object which holds strings and / or
# references of the attributes the class translator should ignore.
self.ignore_attribute = ignore_attribute
# The list of serialize handler functions for jsonclass dump.
# Used for handling additional types and overriding built-in types.
# Functions are expected to have the same parameters as jsonclass dump
# (possibility to call standard jsonclass dump function within).
self.serialize_handlers = serialize_handlers or {}
def copy(self):
"""
Returns a shallow copy of this configuration bean
:return: A shallow copy of this configuration
"""
new_config = Config(self.version, self.content_type, self.user_agent,
self.use_jsonclass, self.serialize_method,
self.ignore_attribute, None)
new_config.classes = self.classes.copy()
new_config.serialize_handlers = self.serialize_handlers.copy()
return new_config
# Default configuration
DEFAULT = Config()