/*
* Copyright (c) 2010 Lockheed Martin Corporation
*
* 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 org.eurekastreams.server.persistence.mappers.db;
import java.util.List;
import org.apache.commons.logging.Log;
import org.eurekastreams.commons.logging.LogFactory;
import org.eurekastreams.server.domain.PersonStream;
import org.eurekastreams.server.persistence.mappers.BaseArgDomainMapper;
import org.eurekastreams.server.persistence.mappers.requests.DeleteAndReorderStreamsRequest;
/**
* Mapper to delete a person's person_stream entry and collapse index of remaining entries.
*
*/
public class DeleteAndReorderStreamsDbMapper extends BaseArgDomainMapper<DeleteAndReorderStreamsRequest, Boolean>
{
/**
* Local logger instance.
*/
private final Log log = LogFactory.make();
@SuppressWarnings("unchecked")
@Override
public Boolean execute(final DeleteAndReorderStreamsRequest inRequest)
{
Long userId = inRequest.getPersonId();
Long streamId = inRequest.getStreamId();
// Delete Entry
getEntityManager().createQuery(
"DELETE FROM PersonStream WHERE pk.personId = :personId AND pk.streamId = :streamId").setParameter(
"personId", userId).setParameter("streamId", streamId).executeUpdate();
// Get remaining person streams for user
List<PersonStream> streams = getEntityManager().createQuery(
"FROM PersonStream WHERE pk.personId = :personId ORDER BY streamIndex")
.setParameter("personId", userId).getResultList();
// there's a constraint on the indexed column, so temporarily make all indexes available by going negative
getEntityManager().createQuery(
"UPDATE PersonStream SET streamIndex = -1 - streamIndex WHERE pk.personId = :personId").setParameter(
"personId", userId).executeUpdate();
// set the new order
for (int streamIndex = 0; streamIndex < streams.size(); streamIndex++)
{
PersonStream ps = streams.get(streamIndex);
log.info("Setting stream index to " + streamIndex + " for stream id #" + ps.getStreamId() + " for person #"
+ userId);
// have to update in real time, rather than wait for flush - the constraints make this tough
getEntityManager().createQuery(
"UPDATE PersonStream SET streamIndex = :streamIndex "
+ "WHERE pk.personId = :personId AND streamId = :streamId").setParameter("streamIndex",
streamIndex).setParameter("personId", ps.getPersonId()).setParameter("streamId", ps.getStreamId())
.executeUpdate();
}
return true;
}
}