emory-libraries/eulexistdb

View on GitHub
eulexistdb/manager.py

Summary

Maintainability
A
0 mins
Test Coverage
# file eulexistdb/manager.py
#
#   Copyright 2010,2011 Emory University Libraries
#
#   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.

from django.conf import settings
from eulexistdb.db import ExistDB
from eulexistdb.query import QuerySet

class Manager(object):

    """
    Connect an :class:`~eulexistdb.models.XmlModel` to an
    :class:`~eulexistdb.db.ExistDB` for easy querying.

    Typically each :class:`~eulexistdb.models.XmlModel` will
    have one or more ``Manager`` members. Like Django ``Manager`` objects
    these offer a convenient way to access model-based queries. Like Django
    ``Manager`` objects, developers can `derive a child class`_ and override
    :meth:`get_query_set` to modify the default ``QuerySet``. Unlike Django,
    this implementation does not currently provide a default ``Manager`` for
    every ``XmlModel``.

    Developers should consult :class:`eulexistdb.query.QuerySet` for a
    complete list of its methods. ``Manager`` directly exposes these
    methods, forwarding them to the ``QuerySet`` returned by its own
    :meth:`get_query_set`.

    .. _derive a child class: http://docs.djangoproject.com/en/1.1/topics/db/managers/#modifying-initial-manager-querysets
    """

    def __init__(self, xpath):
        self.xpath = xpath

        # NOTE: model needs to be patched in to a real XmlModel class after
        # the fact. currently this is handled by XmlModelType metaclass
        # logic.
        self.model = None

    def get_query_set(self):
        """
        Get the default :class:`eulexistdb.db.QuerySet` returned
        by this ``Manager``. Typically this returns a ``QuerySet`` based on
        the ``Manager``'s `xpath`, evaluated in the
        ``settings.EXISTDB_ROOT_COLLECTION`` on a default
        :class:`eulexistdb.db.ExistDB`.

        This is a convenient point for developers to customize an object's
        managers. Deriving a child class from Manager and overriding or
        extending this method is a handy way to create custom queries
        accessible from an :class:`~eulexistdb.models.XmlModel`.
        """

        if hasattr(settings, 'EXISTDB_FULLTEXT_OPTIONS'):
            fulltext_opts = settings.EXISTDB_FULLTEXT_OPTIONS
        else:
            fulltext_opts = {}


        return QuerySet(model=self.model, xpath=self.xpath, using=ExistDB(),
                        collection=settings.EXISTDB_ROOT_COLLECTION,
                        fulltext_options=fulltext_opts)

    #######################
    # PROXIES TO QUERYSET #
    #######################

    def count(self):
        return self.get_query_set().count()

    def filter(self, *args, **kwargs):
        return self.get_query_set().filter(*args, **kwargs)

    def or_filter(self, *args, **kwargs):
        return self.get_query_set().or_filter(*args, **kwargs)

    def order_by(self, *args, **kwargs):
        return self.get_query_set().order_by(*args, **kwargs)

    def only(self, *args, **kwargs):
        return self.get_query_set().only(*args, **kwargs)

    def also(self, *args, **kwargs):
        return self.get_query_set().also(*args, **kwargs)

    def distinct(self):
        return self.get_query_set().distinct()

    def all(self):
        return self.get_query_set().all()

    def get(self, *args, **kwargs):
        return self.get_query_set().get(*args, **kwargs)