/** * Copyright (C) 2010 Cloud.com, Inc. All rights reserved. * * This software is licensed under the GNU General Public License v3 or later. * * It is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or any later version. * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . * */ package com.cloud.dao; import java.io.Serializable; import java.util.List; import com.cloud.utils.db.GenericSearchBuilder; import com.cloud.utils.db.SearchBuilder; import com.cloud.utils.db.SearchCriteria; /** * Generic Entity Manager to retrieve database objects. * */ public interface EntityManager { /** * Finds an entity by its id. * @param class of the entity you're trying to find. * @param class of the id that the entity uses. * @param entityType Type of the entity. * @param id id value * @return T if found; null if not. */ public T findById(Class entityType, K id); /** * Finds an entity by external id which is always String * @param entity class * @param entityType type of entity you're looking for. * @param xid external id * @return T if found, null if not. */ public T findByXid(Class entityType, String xid); /** * Lists all entities. Use this method at your own risk. * @param entity class * @param entityType type of entity you're looking for. * @return List */ public List list(Class entityType); /** * Persists the entity. * @param entity class * @param t entity * @return persisted entity. Only use this after persisting. */ public T persist(T t); public SearchBuilder createSearchBuilder(Class entityType); public GenericSearchBuilder createGenericSearchBuilder(Class entityType, Class resultType); public List search(Class entityType, SearchCriteria sc); public void remove(Class entityType, K id); }