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

com.fluidbpm.program.api.util.sql.impl.SQLFormUtil Maven / Gradle / Ivy

/*
 * Koekiebox CONFIDENTIAL
 *
 * [2012] - [2017] Koekiebox (Pty) Ltd
 * All Rights Reserved.
 *
 * NOTICE: All information contained herein is, and remains the property
 * of Koekiebox and its suppliers, if any. The intellectual and
 * technical concepts contained herein are proprietary to Koekiebox
 * and its suppliers and may be covered by South African and Foreign Patents,
 * patents in process, and are protected by trade secret or copyright law.
 * Dissemination of this information or reproduction of this material is strictly
 * forbidden unless prior written permission is obtained from Koekiebox.
 */

package com.fluidbpm.program.api.util.sql.impl;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Map;

import com.fluidbpm.program.api.util.IFormAction;
import com.fluidbpm.program.api.util.cache.CacheUtil;
import com.fluidbpm.program.api.util.sql.ABaseSQLUtil;
import com.fluidbpm.program.api.util.sql.exception.FluidSQLException;
import com.fluidbpm.program.api.util.sql.syntax.ISyntax;
import com.fluidbpm.program.api.util.sql.syntax.SyntaxFactory;
import com.fluidbpm.program.api.vo.field.Field;
import com.fluidbpm.program.api.vo.form.Form;
import com.fluidbpm.program.api.vo.item.FluidItem;
import com.fluidbpm.program.api.vo.user.User;

/**
 * SQL Utility class used for {@code Form} related actions.
 *
 * @author jasonbruwer
 * @since v1.0
 *
 * @see ABaseSQLUtil
 * @see Form
 * @see IFormAction
 */
public class SQLFormUtil extends ABaseSQLUtil implements IFormAction {

	private SQLFormDefinitionUtil formDefUtil = null;
	private SQLFormFieldUtil fieldUtil = null;

	/**
	 * Contains the SQL column indexes for {@code Form}.
	 */
	public static class SQLColumnIndex {
		public static final int _01_FORM_ID = 1;
		public static final int _02_FORM_TYPE = 2;
		public static final int _03_TITLE = 3;
		public static final int _04_CREATED = 4;
		public static final int _05_LAST_UPDATED = 5;
		public static final int _06_CURRENT_USER_ID = 6;

		//additional...
		public static final int _07_FORM_CONTAINER_STATE = 7;
		public static final int _08_FORM_CONTAINER_FLOW_STATE = 8;
	}

	/**
	 * New instance using provided {@code connectionParam}.
	 *
	 * @param connectionParam SQL Connection to use.
	 * @param cacheUtilParam The Cache Util for better performance.
	 */
	public SQLFormUtil(Connection connectionParam, CacheUtil cacheUtilParam) {
		super(connectionParam, cacheUtilParam);

		this.formDefUtil = new SQLFormDefinitionUtil(connectionParam);
		this.fieldUtil = new SQLFormFieldUtil(
				connectionParam, cacheUtilParam, this.formDefUtil);
	}

	/**
	 * New instance using provided {@code connectionParam}.
	 *
	 * @param connectionParam SQL Connection to use.
	 */
	public SQLFormUtil(Connection connectionParam) {
		this(connectionParam, null);
	}

	/**
	 * Retrieves the Table field records as {@code List
}. * * @param electronicFormIdParam The Form Identifier. * @param includeFieldDataParam Whether to populate the return {@code List} fields. * @return {@code List} records. */ public List getFormTableForms( Long electronicFormIdParam, boolean includeFieldDataParam ) { List returnVal = new ArrayList(); if (electronicFormIdParam == null) { return returnVal; } Map definitionAndTitle = this.formDefUtil.getFormDefinitionIdAndTitle(); PreparedStatement preparedStatement = null; ResultSet resultSet = null; try { ISyntax syntax = SyntaxFactory.getInstance().getSyntaxFor( this.getSQLTypeFromConnection(), ISyntax.ProcedureMapping.Form.GetFormContainersTableFieldFormContainers); preparedStatement = this.getConnection().prepareStatement( syntax.getPreparedStatement()); preparedStatement.setLong(1, electronicFormIdParam); resultSet = preparedStatement.executeQuery(); //Iterate each of the form containers... while (resultSet.next()) { returnVal.add(this.mapFormContainerTo( definitionAndTitle, resultSet)); } //When field data must also be included... if (includeFieldDataParam) { for (Form form : returnVal) { List formFields = this.fieldUtil.getFormFields( form.getId(), false, false); form.setFormFields(formFields); } } } catch (SQLException sqlError) { throw new FluidSQLException(sqlError); } finally { this.closeStatement(preparedStatement,resultSet); } return returnVal; } /** * Gets the descendants for the {@code electronicFormIdsParam} Forms. * * @param electronicFormIdsParam Identifiers for the Forms to retrieve. * @param includeFieldDataParam Whether to populate the return {@code List} fields. * @param includeTableFieldsParam Whether to populate the return {@code List} table fields. * @param includeTableFieldFormRecordInfoParam Does table record form data need to be included. * * @return {@code List} descendants. * * @see Form */ @Override public List getFormDescendants( List electronicFormIdsParam, boolean includeFieldDataParam, boolean includeTableFieldsParam, boolean includeTableFieldFormRecordInfoParam) { if (electronicFormIdsParam == null || electronicFormIdsParam.isEmpty()) { return null; } List returnVal = new ArrayList(); for (Long electronicFormId : electronicFormIdsParam) { List forTheCycle = this.getFormDescendants( electronicFormId, includeFieldDataParam, includeTableFieldsParam, includeTableFieldFormRecordInfoParam); if (forTheCycle == null) { continue; } returnVal.addAll(forTheCycle); } return returnVal; } /** * Gets the descendants for the {@code electronicFormIdParam} Form. * * @param electronicFormIdParam Identifier for the Form. * @param includeFieldDataParam Whether to populate the return {@code List} fields. * @param includeTableFieldsParam Whether to populate the return {@code List} table fields. * @param includeTableFieldFormRecordInfoParam Does table record form data need to be included. * * @return {@code List} descendants. * * @see Form */ public List getFormDescendants( Long electronicFormIdParam, boolean includeFieldDataParam, boolean includeTableFieldsParam, boolean includeTableFieldFormRecordInfoParam ) { List returnVal = new ArrayList(); if (electronicFormIdParam == null) { return returnVal; } Map definitionAndTitle = this.formDefUtil.getFormDefinitionIdAndTitle(); PreparedStatement preparedStatement = null; ResultSet resultSet = null; try { ISyntax syntax = SyntaxFactory.getInstance().getSyntaxFor( this.getSQLTypeFromConnection(), ISyntax.ProcedureMapping.Form.GetFormContainersChildFormContainers); preparedStatement = this.getConnection().prepareStatement( syntax.getPreparedStatement()); preparedStatement.setLong(1,electronicFormIdParam); resultSet = preparedStatement.executeQuery(); //Iterate each of the form containers... while (resultSet.next()) { Form mappedForm = this.mapFormContainerTo( definitionAndTitle, resultSet); if (mappedForm == null) { continue; } //Ancestor... mappedForm.setAncestorId(electronicFormIdParam); returnVal.add(mappedForm); } //When field data must also be included... if (includeFieldDataParam) { for (Form form : returnVal) { List formFields = this.fieldUtil.getFormFields( form.getId(), includeTableFieldsParam, includeTableFieldFormRecordInfoParam); form.setFormFields(formFields); } } } catch (SQLException sqlError) { throw new FluidSQLException(sqlError); } finally { this.closeStatement(preparedStatement,resultSet); } return returnVal; } /** * Gets the descendants for the {@code electronicFormIdParam} Form with the * FormContainer and FormContainerFlow state. * * @param electronicFormIdParam Identifier for the Form. * @param includeFieldDataParam Whether to populate the return {@code List} fields. * @param includeTableFieldsParam Whether to populate the return {@code List} table fields. * @return {@code List} descendants. * * @see Form */ @Deprecated public List getFormDescendantsWithStates( Long electronicFormIdParam, boolean includeFieldDataParam, boolean includeTableFieldsParam ) { List returnVal = new ArrayList(); if (electronicFormIdParam == null) { return returnVal; } Map definitionAndTitle = this.formDefUtil.getFormDefinitionIdAndTitle(); PreparedStatement preparedStatement = null; ResultSet resultSet = null; try { ISyntax syntax = SyntaxFactory.getInstance().getSyntaxFor( this.getSQLTypeFromConnection(), ISyntax.ProcedureMapping.Form.GetFormContainersChildFormContainersWithStates); preparedStatement = this.getConnection().prepareStatement( syntax.getPreparedStatement()); preparedStatement.setLong(1, electronicFormIdParam); resultSet = preparedStatement.executeQuery(); //Iterate each of the form containers... while (resultSet.next()) { Form mappedForm = this.mapFormContainerTo( definitionAndTitle, resultSet); if (mappedForm == null) { continue; } //Map the states... this.mapFormContainerStatesTo(mappedForm, resultSet); //Ancestor... mappedForm.setAncestorId(electronicFormIdParam); returnVal.add(mappedForm); } //When field data must also be included... if (includeFieldDataParam) { for (Form form : returnVal) { List formFields = this.fieldUtil.getFormFields( form.getId(), includeTableFieldsParam, false); form.setFormFields(formFields); } } } catch (SQLException sqlError) { throw new FluidSQLException(sqlError); } finally { this.closeStatement(preparedStatement,resultSet); } return returnVal; } /** * Gets the ancestor for the {@code electronicFormIdParam} Form. * * @param electronicFormIdParam Identifier for the Form. * @param includeFieldDataParam Whether to populate the return {@code Form} fields. * @param includeTableFieldsParam Whether to populate the return {@code Form} table fields. * @return {@code Form} descendants. * * @see Form */ public Form getFormAncestor( Long electronicFormIdParam, boolean includeFieldDataParam, boolean includeTableFieldsParam ) { if (electronicFormIdParam == null) { return null; } Form returnVal = null; Map definitionAndTitle = this.formDefUtil.getFormDefinitionIdAndTitle(); PreparedStatement preparedStatement = null; ResultSet resultSet = null; try { ISyntax syntax = SyntaxFactory.getInstance().getSyntaxFor( this.getSQLTypeFromConnection(), ISyntax.ProcedureMapping.Form.GetFormContainersParentFormContainer); preparedStatement = this.getConnection().prepareStatement( syntax.getPreparedStatement()); preparedStatement.setLong(1,electronicFormIdParam); resultSet = preparedStatement.executeQuery(); //Iterate each of the form containers... if (resultSet.next()) { returnVal = this.mapFormContainerTo( definitionAndTitle, resultSet); } //When field data must also be included... if (includeFieldDataParam && returnVal != null) { returnVal.setFormFields( this.fieldUtil.getFormFields( returnVal.getId(), includeTableFieldsParam, false)); } return returnVal; } catch (SQLException sqlError) { throw new FluidSQLException(sqlError); } finally { this.closeStatement(preparedStatement,resultSet); } } /** * Maps the Form to the provided Definition-Id and Title. * * @param definitionAndTitleParam Form Definition Id and Title mapping. * @param resultSetParam Result Set used to populate {@code Form} with. * * @return Form * * @throws SQLException If no mapping exists for Form Type. * * @see ResultSet */ private Form mapFormContainerTo( Map definitionAndTitleParam, ResultSet resultSetParam ) throws SQLException { Long formId = resultSetParam.getLong(SQLColumnIndex._01_FORM_ID); String formType = definitionAndTitleParam.get( resultSetParam.getLong(SQLColumnIndex._02_FORM_TYPE)); String title = resultSetParam.getString(SQLColumnIndex._03_TITLE); Date created = resultSetParam.getDate(SQLColumnIndex._04_CREATED); Date lastUpdated = resultSetParam.getDate(SQLColumnIndex._05_LAST_UPDATED); Long currentUserId = resultSetParam.getLong(SQLColumnIndex._06_CURRENT_USER_ID); if (formType == null) { throw new SQLException("No mapping found for Form Type '"+ resultSetParam.getLong(SQLColumnIndex._02_FORM_TYPE)+"'."); } Form toAdd = new Form(formType); toAdd.setId(formId); toAdd.setTitle(title); //Created... if (created != null) { toAdd.setDateCreated(new Date(created.getTime())); } //Last Updated... if (lastUpdated != null) { toAdd.setDateLastUpdated(new Date(lastUpdated.getTime())); } //Current User... if (currentUserId != null && currentUserId.longValue() > 0) { User currentUser = new User(); currentUser.setId(currentUserId); toAdd.setCurrentUser(currentUser); } return toAdd; } /** * Maps the Form states with the {@code resultSetParam}. * * @param resultSetParam Result Set used to populate {@code Form} with. * * @return Form * * @throws SQLException If no mapping exists for Form Type. * * @see ResultSet */ private void mapFormContainerStatesTo( Form previousMappedForm, ResultSet resultSetParam ) throws SQLException { if (previousMappedForm == null) { return; } //Form Container State... Long formContainerState = resultSetParam.getLong( SQLColumnIndex._07_FORM_CONTAINER_STATE); long formContStateId = (formContainerState == null) ? 0: formContainerState.longValue(); if (formContStateId > 0) { if (formContStateId == 1) { previousMappedForm.setState(Form.State.OPEN); } else if (formContStateId == 2) { previousMappedForm.setState(Form.State.LOCKED); } } Long formContainerFlowState = resultSetParam.getLong( SQLColumnIndex._08_FORM_CONTAINER_FLOW_STATE); long formContFlowStateId = (formContainerFlowState == null) ? 0: formContainerFlowState.longValue(); if (formContFlowStateId > 0) { if (formContFlowStateId == 1) { previousMappedForm.setFlowState( FluidItem.FlowState.NotInFlow.name()); } else if (formContFlowStateId == 2) { previousMappedForm.setFlowState( FluidItem.FlowState.WorkInProgress.name()); } else if (formContFlowStateId == 3) { previousMappedForm.setFlowState( FluidItem.FlowState.UserSend.name()); } else if (formContFlowStateId == 4) { previousMappedForm.setFlowState( FluidItem.FlowState.UserSendWorkInProgress.name()); } else if (formContFlowStateId == 5) { previousMappedForm.setFlowState(FluidItem.FlowState.Archive.name()); } } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy