Package com.github.jmkgreen.morphia

Source Code of com.github.jmkgreen.morphia.Morphia

/**
* Copyright (C) 2010 Olafur Gauti Gudmundsson
*
* 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.github.jmkgreen.morphia;

import com.github.jmkgreen.morphia.annotations.Embedded;
import com.github.jmkgreen.morphia.annotations.Entity;
import com.github.jmkgreen.morphia.mapping.DefaultMapper;
import com.github.jmkgreen.morphia.mapping.Mapper;
import com.github.jmkgreen.morphia.mapping.MappingException;
import com.github.jmkgreen.morphia.mapping.cache.EntityCache;
import com.github.jmkgreen.morphia.utils.ReflectionUtils;
import com.mongodb.DBObject;
import com.mongodb.Mongo;
import java.io.IOException;
import java.util.Collections;
import java.util.Set;

/**
* <p>The main project class. Uses a {@link Mapper} to map between annotated POJO entities and MongoDB.</p>
* <p/>
* <p>There are two primary ways to use Morphia:</p>
* <p/>
* <ol>
* <li>Your client can manage the MongoDB connection and queries itself, using
* Morphia only to transform entity instances into MongoDB types and
* back again.</li>
* <li>Your client can provide DAO classes per entity that extends {@link com.github.jmkgreen.morphia.dao.BasicDAO},
* and return instances of these for data access. Used in this way the
* Morphia mapper will be used to automatically map between entity
* and MongoDB. This is the recommended approach.</li>
* </ol>
*
* @author Olafur Gauti Gudmundsson
* @author Scott Hernandez
*/
@SuppressWarnings({"unchecked", "rawtypes"})
public class Morphia {
    private final Mapper mapper;
    private DatastoreFactory datastoreFactory = new DefaultDatastoreFactory();
    private AdvancedDatastoreFactory advancedDatastoreFactory = new DefaultAdvancedDatastoreFactory();

    /**
     * Construct a new instance with an empty set of mappings.
     */
    public Morphia() {
        this(Collections.EMPTY_SET);
    }

    /**
     * Construct a new instance with empty mappings using supplied Mapper.
     *
     * @param myMapper
     */
    public Morphia(Mapper myMapper) {
        this(Collections.EMPTY_SET, myMapper);
    }

    /**
     * Construct a new instance using the DefaultMapper with the supplied classes to map.
     *
     * @param classesToMap
     */
    public Morphia(Set<Class> classesToMap) {
        this.mapper = new DefaultMapper();
        for (Class c : classesToMap) {
            map(c);
        }
    }

    /**
     * Constructor. Uses the supplied mapper and maps the supplied classes.
     *
     * @param classesToMap
     * @param myMapper
     */
    public Morphia(Set<Class> classesToMap, Mapper myMapper) {
        this.mapper = myMapper;
        for (Class c : classesToMap) {
            map(c);
        }
    }

    public synchronized Morphia map(Class... entityClasses) {
        if (entityClasses != null && entityClasses.length > 0)
            for (Class entityClass : entityClasses) {
                if (!mapper.isMapped(entityClass)) {
                    mapper.addMappedClass(entityClass);
                }
            }
        return this;
    }

    public synchronized Morphia mapPackageFromClass(Class clazz) {
        return mapPackage(clazz.getPackage().getName(), false);
    }

    /**
     * Tries to map all classes in the package specified. Fails if one of the classes is not valid for mapping.
     *
     * @param packageName the name of the package to process
     * @return the Morphia instance
     */
    public synchronized Morphia mapPackage(String packageName) {
        return mapPackage(packageName, false);
    }

    /**
     * Tries to map all classes in the package specified.
     *
     * @param packageName          the name of the package to process
     * @param ignoreInvalidClasses specifies whether to ignore classes in the package that cannot be mapped
     * @return the Morphia instance
     */
    public synchronized Morphia mapPackage(String packageName, boolean ignoreInvalidClasses) {
        try {
            for (Class c : ReflectionUtils.getClasses(packageName)) {
                try {
                    Embedded embeddedAnn = ReflectionUtils.getClassEmbeddedAnnotation(c);
                    Entity classEntityAnnotation = ReflectionUtils.getClassEntityAnnotation(c);
                    if (classEntityAnnotation != null || embeddedAnn != null) {
                        map(c);
                    }
                } catch (MappingException ex) {
                    if (!ignoreInvalidClasses) {
                        throw ex;
                    }
                }
            }
            return this;
        } catch (IOException ioex) {
            throw new MappingException("Could not get map classes from package " + packageName, ioex);
        } catch (ClassNotFoundException cnfex) {
            throw new MappingException("Could not get map classes from package " + packageName, cnfex);
        }
    }

    /**
     * Check whether a specific class is mapped by this instance.
     *
     * @param entityClass the class we want to check
     * @return true if the class is mapped, else false
     */
    public boolean isMapped(Class entityClass) {
        return mapper.isMapped(entityClass);
    }

    /**
     * Map from a DBObject, creating a new EntityCache.
     *
     * @param entityClass
     * @param dbObject
     * @return The typed instance
     */
    public <T> T fromDBObject(Class<T> entityClass, DBObject dbObject) {
        return fromDBObject(entityClass, dbObject, mapper.createEntityCache());
    }

    /**
     * Map from a DBObject using an existing EntityCache.
     * <p/>
     * If the entityClass does not an interface and is not already mapped,
     * a MappingException will be thrown.
     *
     * @param entityClass
     * @param dbObject
     * @param cache
     * @return The typed instance
     * @throws MappingException
     * @see Mapper#fromDBObject(Class, com.mongodb.DBObject, com.github.jmkgreen.morphia.mapping.cache.EntityCache)
     */
    public <T> T fromDBObject(Class<T> entityClass, DBObject dbObject, EntityCache cache) {
        if (!entityClass.isInterface() && !mapper.isMapped(entityClass)) {
            throw new MappingException("Trying to map to an unmapped class: " + entityClass.getName());
        }
        try {
            return (T) mapper.fromDBObject(entityClass, dbObject, cache);
        } catch (Exception e) {
            throw new MappingException("Could not map entity from DBObject", e);
        }
    }

    /**
     * Proxy to Mapper.toDBObject(Object)
     *
     * @param entity To be converted
     * @return New DBObject
     * @see Mapper#toDBObject(Object)
     */
    public DBObject toDBObject(Object entity) {
        try {
            return mapper.toDBObject(entity);
        } catch (Exception e) {
            throw new MappingException("Could not map entity to DBObject", e);
        }
    }

    public Mapper getMapper() {
        return this.mapper;
    }

    /**
     * It is best to use a Mongo singleton instance here
     */
    public Datastore createDatastore(Mongo mon, String dbName, String user, char[] pw) {
        return datastoreFactory.create(this, mon, dbName, user, pw);
    }

    /**
     * It is best to use a Mongo singleton instance here
     */
    public Datastore createDatastore(Mongo mongo, String dbName) {
        return createDatastore(mongo, dbName, null, null);
    }

    public AdvancedDatastore createAdvancedDatastore(Mongo mon, String dbName) {
        return createAdvancedDatastore(mon,  dbName,  null, null);
    }
    /**
     * Create a new {@link AdvancedDatastore} instance via an {@link AdvancedDatastoreFactory}.
     *
     * @since 1.2.4
     * @param mon
     * @param dbName
     * @param user
     * @param pw
     * @return
     */
    public AdvancedDatastore createAdvancedDatastore(Mongo mon, String dbName, String user, char[] pw) {
        return advancedDatastoreFactory.create(this, mon,  dbName,  user,  pw);
    }

    /**
     * Override the default datastore factory.
     *
     * @since 1.2.4
     * @param datastoreFactory
     */
    public void setDatastoreFactory(DatastoreFactory datastoreFactory) {
        this.datastoreFactory = datastoreFactory;
    }

    /**
     * Override the default advanced datastore factory.
     *
     * @since 1.2.4
     * @param advancedDatastoreFactory
     */
    public void setAdvancedDatastoreFactory(AdvancedDatastoreFactory advancedDatastoreFactory) {
        this.advancedDatastoreFactory = advancedDatastoreFactory;
    }
}
TOP

Related Classes of com.github.jmkgreen.morphia.Morphia

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.