| Index: third_party/gsutil/boto/sdb/db/manager/__init__.py
|
| diff --git a/third_party/gsutil/boto/sdb/db/manager/__init__.py b/third_party/gsutil/boto/sdb/db/manager/__init__.py
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..69fc16f7128dd91b476c52adff9c7347f6ecfea0
|
| --- /dev/null
|
| +++ b/third_party/gsutil/boto/sdb/db/manager/__init__.py
|
| @@ -0,0 +1,85 @@
|
| +# Copyright (c) 2006,2007,2008 Mitch Garnaat http://garnaat.org/
|
| +#
|
| +# Permission is hereby granted, free of charge, to any person obtaining a
|
| +# copy of this software and associated documentation files (the
|
| +# "Software"), to deal in the Software without restriction, including
|
| +# without limitation the rights to use, copy, modify, merge, publish, dis-
|
| +# tribute, sublicense, and/or sell copies of the Software, and to permit
|
| +# persons to whom the Software is furnished to do so, subject to the fol-
|
| +# lowing conditions:
|
| +#
|
| +# The above copyright notice and this permission notice shall be included
|
| +# in all copies or substantial portions of the Software.
|
| +#
|
| +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
| +# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL-
|
| +# ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
|
| +# SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
| +# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
| +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
| +# IN THE SOFTWARE.
|
| +import boto
|
| +
|
| +
|
| +def get_manager(cls):
|
| + """
|
| + Returns the appropriate Manager class for a given Model class. It
|
| + does this by looking in the boto config for a section like this::
|
| +
|
| + [DB]
|
| + db_type = SimpleDB
|
| + db_user = <aws access key id>
|
| + db_passwd = <aws secret access key>
|
| + db_name = my_domain
|
| + [DB_TestBasic]
|
| + db_type = SimpleDB
|
| + db_user = <another aws access key id>
|
| + db_passwd = <another aws secret access key>
|
| + db_name = basic_domain
|
| + db_port = 1111
|
| +
|
| + The values in the DB section are "generic values" that will be used
|
| + if nothing more specific is found. You can also create a section for
|
| + a specific Model class that gives the db info for that class.
|
| + In the example above, TestBasic is a Model subclass.
|
| + """
|
| + db_user = boto.config.get('DB', 'db_user', None)
|
| + db_passwd = boto.config.get('DB', 'db_passwd', None)
|
| + db_type = boto.config.get('DB', 'db_type', 'SimpleDB')
|
| + db_name = boto.config.get('DB', 'db_name', None)
|
| + db_table = boto.config.get('DB', 'db_table', None)
|
| + db_host = boto.config.get('DB', 'db_host', "sdb.amazonaws.com")
|
| + db_port = boto.config.getint('DB', 'db_port', 443)
|
| + enable_ssl = boto.config.getbool('DB', 'enable_ssl', True)
|
| + sql_dir = boto.config.get('DB', 'sql_dir', None)
|
| + debug = boto.config.getint('DB', 'debug', 0)
|
| + # first see if there is a fully qualified section name in the Boto config
|
| + module_name = cls.__module__.replace('.', '_')
|
| + db_section = 'DB_' + module_name + '_' + cls.__name__
|
| + if not boto.config.has_section(db_section):
|
| + db_section = 'DB_' + cls.__name__
|
| + if boto.config.has_section(db_section):
|
| + db_user = boto.config.get(db_section, 'db_user', db_user)
|
| + db_passwd = boto.config.get(db_section, 'db_passwd', db_passwd)
|
| + db_type = boto.config.get(db_section, 'db_type', db_type)
|
| + db_name = boto.config.get(db_section, 'db_name', db_name)
|
| + db_table = boto.config.get(db_section, 'db_table', db_table)
|
| + db_host = boto.config.get(db_section, 'db_host', db_host)
|
| + db_port = boto.config.getint(db_section, 'db_port', db_port)
|
| + enable_ssl = boto.config.getint(db_section, 'enable_ssl', enable_ssl)
|
| + debug = boto.config.getint(db_section, 'debug', debug)
|
| + elif hasattr(cls, "_db_name") and cls._db_name is not None:
|
| + # More specific then the generic DB config is any _db_name class property
|
| + db_name = cls._db_name
|
| + elif hasattr(cls.__bases__[0], "_manager"):
|
| + return cls.__bases__[0]._manager
|
| + if db_type == 'SimpleDB':
|
| + from sdbmanager import SDBManager
|
| + return SDBManager(cls, db_name, db_user, db_passwd,
|
| + db_host, db_port, db_table, sql_dir, enable_ssl)
|
| + elif db_type == 'XML':
|
| + from xmlmanager import XMLManager
|
| + return XMLManager(cls, db_name, db_user, db_passwd,
|
| + db_host, db_port, db_table, sql_dir, enable_ssl)
|
| + else:
|
| + raise ValueError('Unknown db_type: %s' % db_type)
|
|
|