// Copyright 2012 Citrix Systems, Inc. Licensed under the // Apache License, Version 2.0 (the "License"); you may not use this // file except in compliance with the License. Citrix Systems, Inc. // reserves all rights not expressly granted by 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. // // Automatically generated by addcopyright.py at 04/03/2012 package com.cloud.storage.dao; import java.util.List; import javax.ejb.Local; import org.apache.log4j.Logger; import com.cloud.storage.UploadVO; import com.cloud.storage.Upload.Status; import com.cloud.storage.Upload.Mode; import com.cloud.utils.db.GenericDaoBase; import com.cloud.utils.db.SearchBuilder; import com.cloud.utils.db.SearchCriteria; @Local(value={UploadDao.class}) public class UploadDaoImpl extends GenericDaoBase<UploadVO, Long> implements UploadDao { public static final Logger s_logger = Logger.getLogger(UploadDaoImpl.class.getName()); protected final SearchBuilder<UploadVO> typeUploadStatusSearch; protected final SearchBuilder<UploadVO> typeHostAndUploadStatusSearch; protected final SearchBuilder<UploadVO> typeModeAndStatusSearch; protected static final String UPDATE_UPLOAD_INFO = "UPDATE upload SET upload_state = ?, upload_pct= ?, last_updated = ? " + ", upload_error_str = ?, upload_job_id = ? " + "WHERE host_id = ? and type_id = ? and type = ?"; protected static final String UPLOADS_STATE_DC= "SELECT * FROM upload t, host h where t.host_id = h.id and h.data_center_id=? " + " and t.type_id=? and t.upload_state = ?" ; public UploadDaoImpl() { typeUploadStatusSearch = createSearchBuilder(); typeUploadStatusSearch.and("type_id", typeUploadStatusSearch.entity().getTypeId(), SearchCriteria.Op.EQ); typeUploadStatusSearch.and("upload_state", typeUploadStatusSearch.entity().getUploadState(), SearchCriteria.Op.EQ); typeUploadStatusSearch.and("type", typeUploadStatusSearch.entity().getType(), SearchCriteria.Op.EQ); typeUploadStatusSearch.done(); typeHostAndUploadStatusSearch = createSearchBuilder(); typeHostAndUploadStatusSearch.and("host_id", typeHostAndUploadStatusSearch.entity().getHostId(), SearchCriteria.Op.EQ); typeHostAndUploadStatusSearch.and("upload_state", typeHostAndUploadStatusSearch.entity().getUploadState(), SearchCriteria.Op.EQ); typeHostAndUploadStatusSearch.done(); typeModeAndStatusSearch = createSearchBuilder(); typeModeAndStatusSearch.and("mode", typeModeAndStatusSearch.entity().getMode(), SearchCriteria.Op.EQ); typeModeAndStatusSearch.and("upload_state", typeModeAndStatusSearch.entity().getUploadState(), SearchCriteria.Op.EQ); typeModeAndStatusSearch.done(); } @Override public List<UploadVO> listByTypeUploadStatus(long typeId, UploadVO.Type type, UploadVO.Status uploadState) { SearchCriteria<UploadVO> sc = typeUploadStatusSearch.create(); sc.setParameters("type_id", typeId); sc.setParameters("type", type); sc.setParameters("upload_state", uploadState.toString()); return listBy(sc); } @Override public List<UploadVO> listByHostAndUploadStatus(long sserverId, Status uploadState){ SearchCriteria<UploadVO> sc = typeHostAndUploadStatusSearch.create(); sc.setParameters("host_id", sserverId); sc.setParameters("upload_state", uploadState.toString()); return listBy(sc); } @Override public List<UploadVO> listByModeAndStatus(Mode mode, Status uploadState){ SearchCriteria<UploadVO> sc = typeModeAndStatusSearch.create(); sc.setParameters("mode", mode.toString()); sc.setParameters("upload_state", uploadState.toString()); return listBy(sc); } }