org.alfresco.repo.domain.activities.ibatis.ActivityPostDAOImpl.java Source code

Java tutorial

Introduction

Here is the source code for org.alfresco.repo.domain.activities.ibatis.ActivityPostDAOImpl.java

Source

/*
 * #%L
 * Alfresco Repository
 * %%
 * Copyright (C) 2005 - 2016 Alfresco Software Limited
 * %%
 * This file is part of the Alfresco software. 
 * If the software was purchased under a paid Alfresco license, the terms of 
 * the paid license agreement will prevail.  Otherwise, the software is 
 * provided under the following open source license terms:
 * 
 * Alfresco is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 * 
 * Alfresco 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 Lesser General Public License for more details.
 * 
 * You should have received a copy of the GNU Lesser General Public License
 * along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
 * #L%
 */
package org.alfresco.repo.domain.activities.ibatis;

import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;

import org.alfresco.repo.domain.activities.ActivityPostDAO;
import org.alfresco.repo.domain.activities.ActivityPostEntity;
import org.apache.ibatis.session.RowBounds;

/**
 * @author janv
 * @since 3.0
 */
public class ActivityPostDAOImpl extends ActivitiesDAOImpl implements ActivityPostDAO {
    @SuppressWarnings("unchecked")
    public List<ActivityPostEntity> selectPosts(ActivityPostEntity activityPost, int maxItems) throws SQLException {
        int rowLimit = maxItems < 0 ? RowBounds.NO_ROW_LIMIT : maxItems;
        RowBounds rowBounds = new RowBounds(RowBounds.NO_ROW_OFFSET, rowLimit);

        if ((activityPost.getJobTaskNode() != -1) && (activityPost.getMinId() != -1)
                && (activityPost.getMaxId() != -1) && (activityPost.getStatus() != null)) {
            return template.selectList("alfresco.activities.select_activity_posts_by_params", activityPost,
                    rowBounds);
        } else if (activityPost.getStatus() != null) {
            return template.selectList("alfresco.activities.select_activity_posts_by_status", activityPost,
                    rowBounds);
        } else {
            return new ArrayList<ActivityPostEntity>(0);
        }
    }

    public Long getMaxActivitySeq() throws SQLException {
        return template.selectOne("alfresco.activities.select_activity_post_max_seq");
    }

    public Long getMinActivitySeq() throws SQLException {
        return template.selectOne("alfresco.activities.select_activity_post_min_seq");
    }

    public Integer getMaxNodeHash() throws SQLException {
        return template.selectOne("alfresco.activities.select_activity_post_max_jobtasknode");
    }

    public int updatePost(long id, String siteNetwork, String activityData, ActivityPostEntity.STATUS status)
            throws SQLException {
        ActivityPostEntity post = new ActivityPostEntity();
        post.setId(id);
        post.setSiteNetwork(siteNetwork);
        post.setActivityData(activityData);
        post.setStatus(status.toString());
        post.setLastModified(new Date());

        return template.update("alfresco.activities.update_activity_post_data", post);
    }

    public int updatePostStatus(long id, ActivityPostEntity.STATUS status) throws SQLException {
        ActivityPostEntity post = new ActivityPostEntity();
        post.setId(id);
        post.setStatus(status.toString());
        post.setLastModified(new Date());

        return template.update("alfresco.activities.update_activity_post_status", post);
    }

    public int deletePosts(Date keepDate, ActivityPostEntity.STATUS status) throws SQLException {
        ActivityPostEntity params = new ActivityPostEntity();
        params.setPostDate(keepDate);
        params.setStatus(status.toString());

        return template.delete("alfresco.activities.delete_activity_posts_older_than_date", params);
    }

    public long insertPost(ActivityPostEntity activityPost) throws SQLException {
        template.insert("alfresco.activities.insert.insert_activity_post", activityPost);
        Long id = activityPost.getId();
        return (id != null ? id : -1);
    }
}