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

com.stardog.ext.spring.batch.SnarlItemReader Maven / Gradle / Ivy

/*
* Copyright (c) the original authors
*
* 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 com.stardog.ext.spring.batch;

import java.util.List;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.batch.item.ItemReader;
import org.springframework.batch.item.NonTransientResourceException;
import org.springframework.batch.item.ParseException;
import org.springframework.batch.item.UnexpectedInputException;
import org.springframework.beans.factory.DisposableBean;
import org.springframework.beans.factory.InitializingBean;

import com.stardog.ext.spring.DataSource;
import com.stardog.ext.spring.RowMapper;
import com.stardog.ext.spring.SnarlTemplate;

/**
 * Implementation of a Spring Batch ItemReader that supports the SNARL API
 * 
 * @author Al Baker
 * @author Clark & Parsia 
 * 
 * @param 
 *
 */
public class SnarlItemReader implements ItemReader, InitializingBean, DisposableBean {

	final Logger log = LoggerFactory.getLogger(SnarlItemReader.class);
	
	private SnarlTemplate snarlTemplate;
	
	private DataSource dataSource;
	
	private List results;
	
	private String query;
	
	private RowMapper rowMapper;
	
	
	/* 
	 * Some explanation on this method: in Spring Batch, ItemReader is stateful for the life of
	 * a Batch run, and will be called repeatedly until exhausted and returns null.  There is
	 * an 'ItemStream' interface that provides an open, close, and update method for managing a 
	 * cursor based approach for reading.  However, this includes an execution context since Spring
	 * Batch manages execution state for things like retries and restarts.
	 * 
	 * For the initial implementation - will keep a simple implementation with Stardog where the 
	 * result set is read out and then read out one at a time by Spring Batch.  Therefore, any Spring
	 * Batch retries, or persisting job state to disk, will include the results sets instead of a cursor.
	 * 
	 * The rationale for this is to keep the batch system simple as Stardog moves to 1.0 and keeping 
	 * Stardog connections (ie the cursor) around in Spring Batch will be a post 1.0 refactoring.
	 * 
	 * (non-Javadoc)
	 * @see org.springframework.batch.item.ItemReader#read()
	 */
	@Override
	public T read() throws Exception, UnexpectedInputException, ParseException,
			NonTransientResourceException {
		
		if (results == null) {
			results = snarlTemplate.query(query, rowMapper);
			log.debug("SnarlItemReader finished loading query data");
		}
		
		if (results.size() > 0) { 
			return results.remove(0);
		} else {
			return null;
		}
	}

	@Override
	public void afterPropertiesSet() throws Exception {
		snarlTemplate = new SnarlTemplate();
		snarlTemplate.setDataSource(dataSource);
	}

	@Override
	public void destroy() throws Exception {
		snarlTemplate.setDataSource(null);
		snarlTemplate = null;
	}

	/**
	 * @return the dataSource
	 */
	public DataSource getDataSource() {
		return dataSource;
	}

	/**
	 * @param dataSource the dataSource to set
	 */
	public void setDataSource(DataSource dataSource) {
		this.dataSource = dataSource;
	}

	/**
	 * @return the query
	 */
	public String getQuery() {
		return query;
	}

	/**
	 * @param query the query to set
	 */
	public void setQuery(String query) {
		this.query = query;
	}

	/**
	 * @return the rowMapper
	 */
	public RowMapper getRowMapper() {
		return rowMapper;
	}

	/**
	 * @param rowMapper the rowMapper to set
	 */
	public void setRowMapper(RowMapper rowMapper) {
		this.rowMapper = rowMapper;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy