mirror of https://github.com/apache/cloudstack.git
128 lines
5.4 KiB
Java
128 lines
5.4 KiB
Java
// 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.Date;
|
|
import java.util.List;
|
|
|
|
import javax.ejb.Local;
|
|
|
|
import com.cloud.storage.Snapshot;
|
|
import com.cloud.storage.SnapshotScheduleVO;
|
|
import com.cloud.utils.db.GenericDaoBase;
|
|
import com.cloud.utils.db.SearchBuilder;
|
|
import com.cloud.utils.db.SearchCriteria;
|
|
|
|
|
|
@Local (value={SnapshotScheduleDao.class})
|
|
public class SnapshotScheduleDaoImpl extends GenericDaoBase<SnapshotScheduleVO, Long> implements SnapshotScheduleDao {
|
|
protected final SearchBuilder<SnapshotScheduleVO> executableSchedulesSearch;
|
|
protected final SearchBuilder<SnapshotScheduleVO> coincidingSchedulesSearch;
|
|
private final SearchBuilder<SnapshotScheduleVO> VolumeIdSearch;
|
|
private final SearchBuilder<SnapshotScheduleVO> VolumeIdPolicyIdSearch;
|
|
|
|
|
|
protected SnapshotScheduleDaoImpl() {
|
|
|
|
executableSchedulesSearch = createSearchBuilder();
|
|
executableSchedulesSearch.and("scheduledTimestamp", executableSchedulesSearch.entity().getScheduledTimestamp(), SearchCriteria.Op.LT);
|
|
executableSchedulesSearch.and("asyncJobId", executableSchedulesSearch.entity().getAsyncJobId(), SearchCriteria.Op.NULL);
|
|
executableSchedulesSearch.done();
|
|
|
|
coincidingSchedulesSearch = createSearchBuilder();
|
|
coincidingSchedulesSearch.and("volumeId", coincidingSchedulesSearch.entity().getVolumeId(), SearchCriteria.Op.EQ);
|
|
coincidingSchedulesSearch.and("scheduledTimestamp", coincidingSchedulesSearch.entity().getScheduledTimestamp(), SearchCriteria.Op.LT);
|
|
coincidingSchedulesSearch.and("asyncJobId", coincidingSchedulesSearch.entity().getAsyncJobId(), SearchCriteria.Op.NULL);
|
|
coincidingSchedulesSearch.done();
|
|
|
|
VolumeIdSearch = createSearchBuilder();
|
|
VolumeIdSearch.and("volumeId", VolumeIdSearch.entity().getVolumeId(), SearchCriteria.Op.EQ);
|
|
VolumeIdSearch.done();
|
|
|
|
VolumeIdPolicyIdSearch = createSearchBuilder();
|
|
VolumeIdPolicyIdSearch.and("volumeId", VolumeIdPolicyIdSearch.entity().getVolumeId(), SearchCriteria.Op.EQ);
|
|
VolumeIdPolicyIdSearch.and("policyId", VolumeIdPolicyIdSearch.entity().getPolicyId(), SearchCriteria.Op.EQ);
|
|
VolumeIdPolicyIdSearch.done();
|
|
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
@Override
|
|
public List<SnapshotScheduleVO> getCoincidingSnapshotSchedules(long volumeId, Date date) {
|
|
SearchCriteria<SnapshotScheduleVO> sc = coincidingSchedulesSearch.create();
|
|
sc.setParameters("volumeId", volumeId);
|
|
sc.setParameters("scheduledTimestamp", date);
|
|
// Don't return manual snapshots. They will be executed through another code path.
|
|
sc.addAnd("policyId", SearchCriteria.Op.NEQ, 1L);
|
|
return listBy(sc);
|
|
}
|
|
|
|
|
|
@Override
|
|
public SnapshotScheduleVO findOneByVolume(long volumeId) {
|
|
SearchCriteria<SnapshotScheduleVO> sc = VolumeIdSearch.create();
|
|
sc.setParameters("volumeId", volumeId);
|
|
return findOneBy(sc);
|
|
}
|
|
|
|
|
|
@Override
|
|
public SnapshotScheduleVO findOneByVolumePolicy(long volumeId, long policyId) {
|
|
SearchCriteria<SnapshotScheduleVO> sc = VolumeIdPolicyIdSearch.create();
|
|
sc.setParameters("volumeId", volumeId);
|
|
sc.setParameters("policyId", policyId);
|
|
return findOneBy(sc);
|
|
}
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
@Override
|
|
public List<SnapshotScheduleVO> getSchedulesToExecute(Date currentTimestamp) {
|
|
SearchCriteria<SnapshotScheduleVO> sc = executableSchedulesSearch.create();
|
|
sc.setParameters("scheduledTimestamp", currentTimestamp);
|
|
return listBy(sc);
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
@Override
|
|
public SnapshotScheduleVO getCurrentSchedule(Long volumeId, Long policyId, boolean executing) {
|
|
assert volumeId != null;
|
|
SearchCriteria<SnapshotScheduleVO> sc = createSearchCriteria();
|
|
SearchCriteria.Op op = executing ? SearchCriteria.Op.NNULL : SearchCriteria.Op.NULL;
|
|
sc.addAnd("volumeId", SearchCriteria.Op.EQ, volumeId);
|
|
if (policyId != null) {
|
|
sc.addAnd("policyId", SearchCriteria.Op.EQ, policyId);
|
|
if (policyId != Snapshot.MANUAL_POLICY_ID) {
|
|
// manual policies aren't scheduled by the snapshot poller, so don't look for the jobId here
|
|
sc.addAnd("asyncJobId", op);
|
|
}
|
|
} else {
|
|
sc.addAnd("asyncJobId", op);
|
|
}
|
|
|
|
List<SnapshotScheduleVO> snapshotSchedules = listBy(sc);
|
|
// This will return only one schedule because of a DB uniqueness constraint.
|
|
assert (snapshotSchedules.size() <= 1);
|
|
if (snapshotSchedules.isEmpty()) {
|
|
return null;
|
|
}
|
|
else {
|
|
return snapshotSchedules.get(0);
|
|
}
|
|
}
|
|
|
|
} |