All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.obj.nc.repositories.MessageRepository Maven / Gradle / Ivy

/*
 *   Copyright (C) 2021 the original author or authors.
 *
 *   This file is part of Notiflow
 *
 *   This program 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.
 *
 *   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 Lesser General Public License for more details.
 *
 *   You should have received a copy of the GNU Lesser General Public License
 *   along with this program.  If not, see .
 */

package com.obj.nc.repositories;

import com.obj.nc.domain.dto.MessageTableViewDto;
import com.obj.nc.domain.message.MessagePersistentState;
import com.obj.nc.domain.refIntegrity.EntityExistenceChecker;
import org.springframework.data.jdbc.repository.query.Query;
import org.springframework.data.repository.PagingAndSortingRepository;
import org.springframework.data.repository.query.Param;

import java.time.Instant;
import java.util.List;
import java.util.UUID;

public interface MessageRepository extends PagingAndSortingRepository, EntityExistenceChecker {
	
	List findByIdIn(List intentIds);
    
    @Query(
            value = "select " +
                    "	msg.*, array(select endpoint_id from nc_message_2_endpoint_rel m2e where m2e.message_id = msg.id) as endpoint_ids " +
                    "from " +
                    "	nc_message msg " +
                    "where " +
                    "	msg.time_created between (:createdFrom) and (:createdTo) " +
                    "and " +
                    "	(:eventId)::uuid is null or (:eventId)::uuid = any ( msg.previous_event_ids ) " +
                    "offset :offset rows fetch next :pageSize rows only",
            rowMapperClass = MessageTableViewDto.MessageTableViewDtoRowMapper.class)
    List findAllMessages(@Param("createdFrom") Instant createdFrom,
                                              @Param("createdTo") Instant createdTo,
                                              @Param("eventId") UUID eventId,
                                              @Param("offset") long offset,
                                              @Param("pageSize") int pageSize);
    
    @Query(
            value = "select " +
                    "	count(msg.id) " +
                    "from " +
                    "	nc_message msg " +
                    "where " +
                    "	msg.time_created between (:createdFrom) and (:createdTo) " +
                    "and " +
                    "	(:eventId)::uuid is null or (:eventId)::uuid = any ( msg.previous_event_ids ) ")
    long countAllMessages(@Param("createdFrom") Instant createdFrom,
                          @Param("createdTo") Instant createdTo,
                          @Param("eventId") UUID eventId);
    
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy