All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.mongodb.TaggableReadPreference Maven / Gradle / Ivy

Go to download

The MongoDB Java Driver uber-artifact, containing mongodb-driver, mongodb-driver-core, and bson

There is a newer version: 3.1.0
Show newest version
/*
 * Copyright (c) 2008-2014 MongoDB, Inc.
 *
 * 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.
 */

package com.mongodb;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

/**
 * Abstract class for all preference which can be combined with tags
 */
public abstract class TaggableReadPreference extends ReadPreference {
    TaggableReadPreference() {
        tagSetList = Collections.emptyList();
    }

    TaggableReadPreference(List tagSetList) {
        this.tagSetList = Collections.unmodifiableList(new ArrayList(tagSetList));
    }

    @Override
    public boolean isSlaveOk() {
        return true;
    }

    @Deprecated
    @Override
    public DBObject toDBObject() {
        DBObject readPrefObject = new BasicDBObject("mode", getName());

        if (!tagSetList.isEmpty()) {
            List tagSetDocumentList = new ArrayList();
            for (TagSet tagSet : tagSetList) {
                DBObject tagSetDocument = new BasicDBObject();
                for (Tag tag : tagSet) {
                    tagSetDocument.put(tag.getName(), tag.getValue());
                }
                tagSetDocumentList.add(tagSetDocument);
            }
            readPrefObject.put("tags", tagSetDocumentList);
        }

        return readPrefObject;
    }

    /**
     * Gets the list of tag sets as a list of {@code TagSet} instances.
     *
     * @return the list of tag sets
     * @since 2.13
     */
    public List getTagSetList() {
        return tagSetList;
    }

    /**
     * Gets the list of tag sets as a list of DBObject, one for each tag set
     *
     * @return the list of tag sets
     * @see TaggableReadPreference#getTagSetList()
     * @deprecated use the {@code getTagSetList} method instead
     */
    @Deprecated
    public List getTagSets() {
        List tags = new ArrayList();
        for (TagSet curTags: tagSetList) {
            BasicDBObject tagsDocument = new BasicDBObject();
            for (Tag curTag : curTags) {
                tagsDocument.put(curTag.getName(), curTag.getValue());
            }
            tags.add(tagsDocument);
        }
        return tags;
    }

    @Override
    public String toString() {
        return getName() + printTags();
    }

    @Override
    public boolean equals(final Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;

        TaggableReadPreference that = (TaggableReadPreference) o;

        if (!tagSetList.equals(that.tagSetList)) return false;

        return true;
    }

    @Override
    public int hashCode() {
        int result = tagSetList.hashCode();
        result = 31 * result + getName().hashCode();
        return result;
    }

    @Override
    List choose(final ClusterDescription clusterDescription) {
        if (tagSetList.isEmpty()) {
            return getServers(clusterDescription);
        }
        for (TagSet tags : tagSetList) {
            List taggedServers = getServersForTags(clusterDescription, tags);
            if (!taggedServers.isEmpty()) {
                return taggedServers;
            }
        }
        return Collections.emptyList();
    }

    abstract List getServers(final ClusterDescription clusterDescription);

    abstract List getServersForTags(final ClusterDescription clusterDescription, final TagSet tags);

    String printTags() {
        return tagSetList.isEmpty() ? "" :  " : " + tagSetList;
    }

    final List tagSetList;

    /**
     * Read from secondary
     */
    static class SecondaryReadPreference extends TaggableReadPreference {
        SecondaryReadPreference() {
        }

        SecondaryReadPreference(List tagsList) {
            super(tagsList);
        }

        @Override
        public String getName() {
            return "secondary";
        }

        @Override
        List getServers(final ClusterDescription clusterDescription) {
            return clusterDescription.getSecondaries();
        }

        @Override
        List getServersForTags(final ClusterDescription clusterDescription, final TagSet tags) {
            return clusterDescription.getSecondaries(tags);
        }
    }

    /**
     * Read from secondary if available, otherwise from primary, irrespective of tags.
     */
    static class SecondaryPreferredReadPreference extends SecondaryReadPreference {
        SecondaryPreferredReadPreference() {
        }

        SecondaryPreferredReadPreference(List tagsList) {
            super(tagsList);
        }

        @Override
        public String getName() {
            return "secondaryPreferred";
        }

        @Override
        List choose(final ClusterDescription clusterDescription) {
            final List servers = super.choose(clusterDescription);
            return (!servers.isEmpty()) ? servers : clusterDescription.getPrimaries();
        }
    }

    /**
     * Read from nearest node respective of tags.
     */
    static class NearestReadPreference extends TaggableReadPreference {
        NearestReadPreference() {
        }

        NearestReadPreference(List tagsList) {
            super(tagsList);
        }

        @Override
        public String getName() {
            return "nearest";
        }

        @Override
        List getServers(final ClusterDescription clusterDescription) {
            return clusterDescription.getAnyPrimaryOrSecondary();
        }

        @Override
        List getServersForTags(final ClusterDescription clusterDescription, final TagSet tags) {
            return clusterDescription.getAnyPrimaryOrSecondary(tags);
        }
    }

    /**
     * Read from primary if available, otherwise a secondary.
     */
    static class PrimaryPreferredReadPreference extends SecondaryReadPreference {
        PrimaryPreferredReadPreference() {}

        PrimaryPreferredReadPreference(List tagsList) {
            super(tagsList);
        }

        @Override
        public String getName() {
            return "primaryPreferred";
        }

        @Override
        List choose(final ClusterDescription clusterDescription) {
            List servers = clusterDescription.getPrimaries();
            return (!servers.isEmpty()) ? servers : super.choose(clusterDescription);
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy