Code Search for Developers
 
 
  

DataSessionContext.java from BIRT at Krugle


Show DataSessionContext.java syntax highlighted

/*
 *************************************************************************
 * Copyright (c) 2006 Actuate Corporation.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 *
 * Contributors:
 *  Actuate Corporation  - initial API and implementation
 *  
 *************************************************************************
 */ 
package org.eclipse.birt.report.data.adapter.api;

import java.util.Map;

import org.eclipse.birt.core.archive.IDocArchiveReader;
import org.eclipse.birt.core.archive.IDocArchiveWriter;
import org.eclipse.birt.core.exception.BirtException;

import org.eclipse.birt.data.engine.api.DataEngineContext;

import org.eclipse.birt.report.data.adapter.i18n.ResourceConstants;
import org.eclipse.birt.report.data.adapter.internal.script.DataAdapterTopLevelScope;
import org.eclipse.birt.report.model.api.ModuleHandle;

import org.mozilla.javascript.Context;
import org.mozilla.javascript.Scriptable;

/**
 * Context information used to initialize a DataRequestSession.
 * The most important attributes of a session context are:
 * <li>Mode: Indicates how the the session makes use of the report document
 * <li>Top Level Scope: the top-level Javascript scope used to evaluate all Javascript expressions. 
 *   The consumer, if capable, should provide a scope which defines all report-level Javascript objects.
 *   If the scope is null, the adaptor will create a new top level scope with some limited implementation
 *   of report level objects.
 * <li>Report Document Streams: reader and writer stream handles to read/write the report document
 * <li>Cache options: whether and how the data session will make use of data set caches
 */
public class DataSessionContext
{
	/** Indicates Generation mode for data requests */
	public final static int MODE_GENERATION = DataEngineContext.MODE_GENERATION;
	/** Indicates Presentation mode for data requests */
	public final static int MODE_PRESENTATION = DataEngineContext.MODE_PRESENTATION;
	/** Indicates Direct Presentation (Generation/Presentation) mode for data requests */
	public final static int MODE_DIRECT_PRESENTATION  = DataEngineContext.DIRECT_PRESENTATION;
	
	/**
	 * AppContext and Data Set cache count setting decide whether cache is used,
	 * which is default value for data engine context.
	 */
	public final static int CACHE_USE_DEFAULT = DataEngineContext.CACHE_USE_DEFAULT;
	/**
	 * Do not use cache, regardless of data set cache setting
	 */
	public final static int CACHE_USE_DISABLE = DataEngineContext.CACHE_USE_DISABLE;
	/**
	 * Always use cached data if available, disregard data set cache setting and
	 * AppContext. cachRowCount parameter decides cache count.
	 */
	public final static int CACHE_USE_ALWAYS = DataEngineContext.CACHE_USE_ALWAYS;

	private boolean hasExternalScope = false;
	private int mode = MODE_DIRECT_PRESENTATION;
	private Scriptable topScope;
	private IDocArchiveReader docReader; 
	private IDocArchiveWriter docWriter;
	private int cacheOption = CACHE_USE_DEFAULT;
	private int cacheCount = 0;
	private ModuleHandle moduleHandle;
	private Map appContext;
	
	/**
	 * Constructs a context in the provided mode. A context created using this
	 * constructor has no associated report design, and no externally defined top
	 * level Javascript scope. The adaptor will provide its own implementation
	 * of the top level scope.
	 * @param mode Data Session mode. Can be MODE_GENERATION, MODE_PRESENTATION 
	 *    or MODE_DIRECT_PRESENTATION
	 */
	public DataSessionContext( int mode )	throws BirtException
	{
		this(mode, null, null);
	}
	
	/**
	 * Constructs a context in the provided mode and associate it with
	 * the provided  report design handle. No externally defined top
	 * level Javascript scope is specified. The adaptor will provide its own implementation
	 * of the top level scope.
	 * @param mode Data Session mode. Can be MODE_GENERATION, MODE_PRESENTATION 
	 *    or MODE_DIRECT_PRESENTATION
	 * @param moduleHandle If not null, this report module is used to look up data set
	 *    and data source definition when executing queries.
	 */
	public DataSessionContext( int mode, ModuleHandle moduleHandle )
		throws BirtException
	{
		this( mode, moduleHandle, null);
	}
	
	/**
	 * Creates a DataEngine context in the provided mode, using the provided top level scope.
	 * Also sets the handle of the report design being executed. 
	 * @param mode Data Session mode. Can be MODE_GENERATION, MODE_PRESENTATION 
	 *    or MODE_DIRECT_PRESENTATION
	 * @param moduleHandle If not null, this report module is used to look up data set
	 *    and data source definition when executing queries.
	 * @param topScope A top-level scope for evaluating all Javascript code and expressions 
	 *    when executing queries. If a scope is provided, all report-level scripting objects
	 *    (such as "params") must be available in the scope.
	 */
	public DataSessionContext( int mode, ModuleHandle moduleHandle, Scriptable topScope )
		throws BirtException
	{
		if ( !( mode == MODE_GENERATION || mode == MODE_PRESENTATION || mode == MODE_DIRECT_PRESENTATION ) )
			throw new AdapterException( ResourceConstants.ADAPTER_INVALID_MODE,
					new Integer( mode ) );
		
		this.mode = mode;
		this.topScope = topScope;
		this.hasExternalScope = topScope != null;
		this.moduleHandle = moduleHandle;
	}
	
	
	/**
	 * Sets the report doc reader. A reader is required in presentation mode
	 */
	public void setDocumentReader( IDocArchiveReader reader)
	{
		this.docReader = reader;
	}
	
	/**
	 * Sets the report doc writer. A writer is required in generation mode
	 */
	public void setDocumentWriter( IDocArchiveWriter writer)
	{
		this.docWriter = writer;
	}
	
	/**
	 * Sets the cache option.
	 * This function only available for
	 * MODE_DIRECT_PRESENTATION mode. In other cases, exception will be thrown.
	 * 
	 */
	public void setCacheOption( int option, int cacheCount )
			throws BirtException
	{
		if ( !( option == CACHE_USE_DEFAULT || option == CACHE_USE_DISABLE || option == CACHE_USE_ALWAYS ) )
			throw new AdapterException( ResourceConstants.INVALID_CAHCE_OPTION,
					new Integer( option ) );
		
		this.cacheOption = option;
		this.cacheCount = cacheCount;
	}
	
	/**
	 * Gets a DataEngineContext for use to initialize data engine
	 */
	public DataEngineContext getDataEngineContext() throws BirtException
	{
		DataEngineContext context = DataEngineContext.newInstance(
				mode, getTopScope(), docReader, docWriter);
		context.setCacheOption( cacheOption, cacheCount);
		return context;
	}

	/**
	 * Whether a user-provided top scope is used. If return value is false, the adaptor
	 * has provided its own implementation of a top level scope
	 */
	public boolean hasExternalScope()
	{
		return hasExternalScope;
	}
	
	/**
	 * Gets a top level scope for evaluating javascript expressions. This scope can be
	 * either user provided, or one created by this adaptor
	 */
	public Scriptable getTopScope()
	{
		if ( topScope == null )
		{
			// No scope provided by user; create one
			Context cx = Context.enter( );
			topScope = new DataAdapterTopLevelScope( cx, moduleHandle );
			Context.exit( );
		}
		return topScope;
	}
	
	/**
	 * Gets the report design module associated with the session
	 */
	public ModuleHandle getModuleHandle()
	{
		return moduleHandle;
	}
	
	/**
	 * Sets the application context to be passed to data engine and data drivers
	 * @param context - task contexts in a map. The map contains name(String) - value pairs
	 */
	public void setAppContext(Map context)
	{
		this.appContext = context;
	}
	
	/**
	 * Gets the application context map for this request.
	 * @returns Context as name(string) -> value map. Null if no application context has been set 
	 */
	public Map getAppContext()
	{
		return this.appContext;
	}
}




See more files for this project here

BIRT

BIRT is an open source, Eclipse-based reporting system that integrates with your application to produce compelling reports for both web and PDF.

Project homepage: http://www.eclipse.org/birt/phoenix/
Programming language(s): Java,XML
License: gpl2

  AdapterException.java
  DataRequestSession.java
  DataSessionContext.java
  IDataAdapterFactory.java
  IModelAdapter.java
  IRequestInfo.java