/* * Copyright 2004-2006 the Seasar Foundation and the Others. * * 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 org.seasar.framework.container; import java.util.Map; /** *

* S2コンテナ上で、 WEBコンテナなどのコンテキストを扱うためのインターフェースです。 *

*

* {@link InstanceDef コンポーネントインスタンス定義}で、 application、 * requestsessionを使う場合、 * {@link S2Container#init()}を行なう前にExternalContextをS2コンテナに設定する必要があります。 *

* * @author higa * @author goto(Javadoc) */ public interface ExternalContext { /** * リクエストコンテキストを返します。 * * @return リクエストコンテキスト * @see InstanceDef#REQUEST_NAME * @see org.seasar.framework.container.deployer.InstanceRequestDef */ Object getRequest(); /** * リクエストコンテキストを設定します。 * * @param request * リクエストコンテキスト * @see InstanceDef#REQUEST_NAME * @see org.seasar.framework.container.deployer.InstanceRequestDef */ void setRequest(Object request); /** * レスポンスコンテキストを返します。 * * @return レスポンスコンテキスト */ Object getResponse(); /** * レスポンスコンテキストを設定します。 * * @param response * レスポンスコンテキスト */ void setResponse(Object response); /** * セッションコンテキストを返します。 * * @return セッションコンテキスト * @see InstanceDef#SESSION_NAME * @see org.seasar.framework.container.deployer.InstanceSessionDef */ Object getSession(); /** * アプリケーションコンテキストを返します。 * * @return アプリケーションコンテキスト * @see InstanceDef#APPLICATION_NAME * @see org.seasar.framework.container.deployer.InstanceApplicationDef */ Object getApplication(); /** * アプリケーションコンテキストを設定します。 * * @param application * アプリケーションコンテキスト * @see InstanceDef#APPLICATION_NAME * @see org.seasar.framework.container.deployer.InstanceApplicationDef */ void setApplication(Object application); /** * アプリケーションコンテキストを{@link java.util.Map}インターフェースで返します。 * * @return アプリケーションコンテキスト * @see InstanceDef#APPLICATION_NAME * @see org.seasar.framework.container.deployer.InstanceApplicationDef */ Map getApplicationMap(); /** * 初期化設定値を{@link java.util.Map}インターフェースで返します。 * * @return 初期化設定値 */ Map getInitParameterMap(); /** * セッションコンテキストを{@link java.util.Map}インターフェースで返します。 * * @return セッションコンテキスト * @see InstanceDef#SESSION_NAME * @see org.seasar.framework.container.deployer.InstanceSessionDef */ Map getSessionMap(); /** * リクエストクッキーを{@link java.util.Map}インターフェースで返します。 * * @return リクエストクッキー */ Map getRequestCookieMap(); /** * キーに対する値を1つ持つリクエストヘッダーを{@link java.util.Map}インターフェースで返します。 * * @return キーに対する値を1つ持つリクエストヘッダー */ Map getRequestHeaderMap(); /** * キーに対する値を複数持つリクエストヘッダーを{@link java.util.Map}インターフェースで返します。 * * @return キーに対する値を複数持つリクエストヘッダー */ Map getRequestHeaderValuesMap(); /** * リクエストコンテキストを{@link java.util.Map}インターフェースで返します。 * * @return リクエストコンテキスト * @see InstanceDef#REQUEST_NAME * @see org.seasar.framework.container.deployer.InstanceRequestDef */ Map getRequestMap(); /** * キーに対する値を1つ持つリクエストパラメータを{@link java.util.Map}インターフェースで返します。 * * @return キーに対する値を1つ持つリクエストパラメータ */ Map getRequestParameterMap(); /** * キーに対する値を複数持つリクエストパラメータを{@link java.util.Map}インターフェースで返します。 * * @return キーに対する値を複数持つリクエストパラメータ */ Map getRequestParameterValuesMap(); }