You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@openwebbeans.apache.org by st...@apache.org on 2010/07/03 15:06:41 UTC

svn commit: r960216 - /openwebbeans/trunk/readme/README_1_0_0-alpha-1.txt

Author: struberg
Date: Sat Jul  3 13:06:41 2010
New Revision: 960216

URL: http://svn.apache.org/viewvc?rev=960216&view=rev
Log:
1.0.0-alpha-1 release preparation

Added:
    openwebbeans/trunk/readme/README_1_0_0-alpha-1.txt

Added: openwebbeans/trunk/readme/README_1_0_0-alpha-1.txt
URL: http://svn.apache.org/viewvc/openwebbeans/trunk/readme/README_1_0_0-alpha-1.txt?rev=960216&view=auto
==============================================================================
--- openwebbeans/trunk/readme/README_1_0_0-alpha-1.txt (added)
+++ openwebbeans/trunk/readme/README_1_0_0-alpha-1.txt Sat Jul  3 13:06:41 2010
@@ -0,0 +1,619 @@
+-------------------------------
+Apache OpenWebBeans 1.0.0-alpha-1
+-------------------------------
+Welcome! Thanks for downloading and using OpenWebBeans. 
+This document is a "Getting Started Guide" for OpenWebBeans.
+
+This document is based on the 1.0.0-alpha-1 release of the OpenWebBeans.
+
+NOTE : Final release version of OpenWebBeans will be 1.0.0.
+
+--------------------------------
+What is Apache  OpenWebBeans?
+--------------------------------
+OpenWebBeans is an ASL 2.0-licensed implementation of the JSR-299, Contexts and Dependency Injection for the Java EE platform.
+
+Project's web page can be found at: 
+"http://openwebbeans.apache.org"
+
+--------------------------------
+OpenWebBeans 1.0.0-alpha-1 Release Features
+--------------------------------
+
+- 1.0.0-alpha-1 release supports the following features
+-----------------------------------
+* Managed Beans Support
+* Session Beans Support (via Embeddable OpenEJB container in Tomcat)
+* Producer Method Support
+* Producer Field Support
+* Java EE Resource Injection Support
+* JMS OpenWebBeans Support(OWB Specific)
+* Inheritance, Stereotype Inheritances
+* Specialization Support
+* Event Support
+* Decorator and Interceptor Support
+* Lookup and Dependency Injection Support
+* Java EE Plugin Support (via ServetContextListener interface)
+* Portable Integration Support
+* Passivation Capability of Beans
+* @Alternative support
+* OSGi environment support with an own plugable bundle ClassPath scanner
+* vastly improved Interceptor performance
+* improved Serialization handling
+* improved CreationalContext handling
+* revised internal logging
+* upgrade to JPA-2 and JSF-2 support
+* support for direct CDI usage in tomcat-6 and tomcat-7 environments
+
+
+
+- 1.0.0-alpha-1 release does not supports the following features
+--------------------------------------------
+* Does not fully integrate with Geronimo 
+ (You have to configure your application to use OWB functionality, 
+  e.g configure web.xml, adding interceptor to EJBs etc.)
+
+-------------------------------------------
+Release Notes - OpenWebBeans - Version 1.0.0-alpha-1
+-------------------------------------------
+Bug
+
+    * [OWB-216] - Update pom.xml svn links
+    * [OWB-231] - exception using abstract decorators
+    * [OWB-245] - Using parameterized type varaibles fails for Producer Method injection
+    * [OWB-259] - Implement spec 11.5.5. ProcessModule event
+    * [OWB-289] - Owb return 2 beans for Indirect specialized producer beans
+    * [OWB-302] - InjectionPoint injections (both method and field based) in Decorators result in null
+    * [OWB-312] - Add dopriv's to allow OWB to function with java 2 security enabled
+    * [OWB-317] - creationalContext in InvocationContextImpl is always null
+    * [OWB-318] - multiple methods with same EJB @interceptors(foo.class) in same bean class get multiple interceptor instances
+    * [OWB-327] - annotating an Interceptor with @ApplictionScoped leads to OutOfMemory
+    * [OWB-329] - Interceptor instances get created each time the interceptor gets called
+    * [OWB-332] - Destroy Depdent Of Producer Method Beans when Invocation Completes
+    * [OWB-333] - InjectionTarget and Producer Handling
+    * [OWB-334] - cid is missing when using redirect for a jsf 2.0 application
+    * [OWB-336] - injected BeanManager must be Serializable
+    * [OWB-337] - events must not get broadcasted to beans which have no active Context
+    * [OWB-339] - Injecting Non-Contextual Beans Causes NPE in WebBeansUtil
+    * [OWB-340] - BeanManagerImpl.createInjectionTarget() Throws Exception When No Constructor Found
+    * [OWB-341] - CreationalContext#incompleteInstance should get cleaned after create()
+    * [OWB-342] - InterceptorHandler crashes with NullPointerException after deserialisation
+    * [OWB-343] - upgrade JPA spec from 1.0-PFD2 to 1.0 final revision
+    * [OWB-345] - Remove duplicate dependencies
+    * [OWB-351] - OWB picks up @SessionScoped contextual instances from expired sessions
+    * [OWB-352] - Thread Safety Problem in our InterceptorHandlers, aka proxies
+    * [OWB-353] - NPE in removeDependents@CreationalContextImpl
+    * [OWB-354] - WebContextService may throw NPE in tiered classloading environmemt
+    * [OWB-357] - WebbeansFinder should index first on ClassLoader, not singleton type
+    * [OWB-359] - ownerCreationalContext sometimes causes NPE in InterceptorDataImpl.createNewInstance()
+    * [OWB-361] - underlying EJB method not actually in our interceptors stack
+    * [OWB-362] - InvocationTargetException when invoking Stateless SessionBean
+    * [OWB-363] - Intermittent bug with ApplicationScope disposers not being called
+    * [OWB-366] - ContextNotActiveException fired from AppScope/NormalScopedBeanInterceptorHandler when a proxied object finalized
+    * [OWB-368] - The 299 spec (that I have) uses receive=IF_EXISTS but OWB uses notifyObserver=IF_EXISTS.
+    * [OWB-369] - Static ContextsService in ContextFactory causes wrong webContextService used for multiple applications
+    * [OWB-370] - Intransient Conversation context get rdestroyed randomly by destroyWithRespectToTimout
+    * [OWB-371] - no lifecycle interceptors for non-contextual EJB
+    * [OWB-372] - creational context not cleaned up for non-contextual EJB interceptions
+    * [OWB-373] - build crashes with missing artifact error
+    * [OWB-374] - migrate jsf2sample from sun to MyFaces
+    * [OWB-376] - [patch] Guess example broken with Jetty plugin 6.x due to EL 2.2
+    * [OWB-377] - revise logging
+    * [OWB-378] - ejb at bottom of decorator stack doesn't handle changed method
+    * [OWB-380] - NormalScopedBeanInterceptorHandler throws NPE when handling 3rd party Contexts
+    * [OWB-381] - NPE thrown from AbstractInjectable if dependent producer returns null
+    * [OWB-382] - injecting a @Dependent bean into a passivatation scoped bean causes a NonSerializableException
+    * [OWB-387] - DependentContext Interceptor Double Call for PostConstruct
+    * [OWB-390] - fix broken links in our 'site'
+    * [OWB-396] - fix poms to work with maven 3
+    * [OWB-398] - DelegateHandler cached too agressively
+    * [OWB-399] - Proxy objects could not be correctly deserialized by using javassist 3.11. we need to update to 3.12
+    * [OWB-400] - starting OWB as part of an EAR in geronimo causes a exception due to missing 'bundle' protocol
+
+Improvement
+
+    * [OWB-116] - Update Business Method Definition
+    * [OWB-118] - Supports Decorators for Other Delegate Injections
+    * [OWB-136] - fix 'broken' license headers in our java files
+    * [OWB-170] - Address findbug issues in webbeans-impl
+    * [OWB-183] - Improve webbeans-doc module to get a documentation more user friendly
+    * [OWB-214] - get rid of javax.transaction.Transaction dependency in webbeans-impl
+    * [OWB-237] - NoSuchElementException when WebBeansConfigurationListener is absent
+    * [OWB-275] - remove unused imports and cleanup code
+    * [OWB-286] - java.lang.NoClassDefFoundError: javax/validation/Validator
+    * [OWB-313] - create caching strategies for resolving Bean<T> for BeanManager and EL invocations
+    * [OWB-314] - cache resolved instances in NormalScopedBeanMethodHandlers of @ApplicationScoped beans
+    * [OWB-315] - cache resolved instances in NormalScopedBeanMethodHandlers of @SessionScoped beans
+    * [OWB-319] - Strange logging when writing non-Serializable SessionScoped bean
+    * [OWB-320] - Remove Java EE Dependencies from WebBeans Core
+    * [OWB-322] - Create new EJB project and separate common EJB classes from OpenEJB plugin
+    * [OWB-325] - Relocate SPI Classes to SPI Module. Change JSR299, JSR330 as optional pom dependency.
+    * [OWB-326] - improve producer tests
+    * [OWB-328] - improve logger performance
+    * [OWB-330] - reduce BeanManagerImpl#getManager() calls inside the same functions
+    * [OWB-331] - Cache Interceptor & Decorator Stack oon Interceptor Handler
+    * [OWB-346] - Make EJB samples running
+    * [OWB-347] - Using InjectableBeanManager in TCK
+    * [OWB-349] - ignore exception during type hierarchy scan
+    * [OWB-350] - Support Interceptor for non-contextual EJBs
+    * [OWB-355] - OpenEjbBean should look for @Remove methods
+    * [OWB-356] - EjbPlugin only looks for DeployementInfo once, so new deployed application won't be discovered
+    * [OWB-358] - provide property to skip injection in @PostConstruct of OpenWebBeansEjbInterceptor
+    * [OWB-360] - Add BeanManager to a ServletContext attribute
+    * [OWB-364] - Reduce the amount of info level logging
+    * [OWB-365] - make injection optional in OWBEJBInterceptor
+    * [OWB-375] - Performance: OWB logging performs operations when logging disabled.
+    * [OWB-379] - upgrade to final atinject-spec artifact
+    * [OWB-386] - upgarde CDI TCK to 1.0.2.CR1
+    * [OWB-389] - atinject-tck upgrade to final 1.0 release
+    * [OWB-397] - Add helper method and some debug to WebBeansFinder
+
+New Feature
+
+    * [OWB-316] - Implement a generic TestContainer for CDI implementations
+    * [OWB-323] - Provide methods to pass classloader into ServiceLoader and WebBeansFinder for use in tiered classloader situations
+    * [OWB-324] - Add Tomcat Plugin
+    * [OWB-348] - Adding Interceptor and Decorator Support for EJB Beans
+    * [OWB-395] - OpenWebBeans Tomcat 7 Support
+
+TCK Challenge
+
+    * [OWB-388] - Pass TCK 1.0.2 CR1 Web Profile
+
+Task
+
+    * [OWB-6] - Scope passivation
+    * [OWB-14] - Update WebBeans Lifecycle for Servlet Beans
+    * [OWB-46] - Injection into non-contextual objects
+    * [OWB-204] - Update Samples for JSF2 Usage
+    * [OWB-220] - Update site.xml links and bread crumbs to point to non-incubator.
+    * [OWB-310] - Drop dom4j and use jre builtin xml parsers for processing beans.xml
+    * [OWB-391] - create a owb-build-tools project to maintain project specific checkstyle rules, etc.
+
+Test
+
+    * [OWB-56] - Integrate the official JSR-299 TCK test suite
+    * [OWB-222] - Update website download link, and fix relative URL translation
+    * [OWB-367] - Add a unit test for IF_EXISTS
+
+
+----------------------------------------------
+Required Platform
+----------------------------------------------
+Java Version : Java SE >= 6.0
+Java EE Must : Java EE >= 5.0
+
+---------------------------------------------
+How to Configure OpenWebBeans
+---------------------------------------------
+
+This section explains a content of the distribution bundle, OWB plugins and its
+dependent libraries. 
+
+---------------------------------------------
+1.0.0-alpha-1 Distribution Content
+---------------------------------------------
+There are several jars in the OpenWebBeans 1.0.0-alpha-1 distribution;
+
+ - openwebbeans-impl-1.0.0-alpha-1.jar     --> Includes Core Dependency Injection Service.
+ - openwebbeans-ejb-1.0.0-alpha-1.jar      --> EJB Plugin(Supports EJBs in OpenEJB embedded in Tomcat).
+ - openwebbeans-openejb-1.0.0-alpha-1.jar  --> OpenEJB specific Plugin SPI implementations as extension to openwebbeans-ejb
+ - openwebbeans-jms-1.0.0-alpha-1.jar      --> JMS Plugin(Supports injection of JMS related artifacts,i.e, ConnectionFactory, Session, Connection etc.)
+ - openwebbeans-jsf-1.0.0-alpha-1.jar      --> JSF-2.0 Plugin(JSF Conversation Scoped Support).
+ - openwebbeans-jsf12-1.0.0-alpha-1.jar    --> JSF-1.2 Plugin(JSF Conversation Scoped Support).
+ - openwebbeans-resource-1.0.0-alpha-1.jar --> Java EE Resource Injection for Web Projects (Includes @PersistenceContext,@PersistenceUnit
+                                          and @Resource injection into the Managed Beans. @Resource injections use java:/comp/env of the
+                                          Web application component. @PersistenceContext is based on extended EntityManager.
+ - openwebbeans-spi-1.0.0-alpha-1.jar      --> OpenWebBeans Server Provider Interfaces. They are implemented by runtime environments that would
+                                          like to use OpenWebBeans as a JSR-299 implementation.
+ - samples                            --> Includes source code of the samples. Samples are mavenized project  therefore you can easily build and run
+                                          them from your environment that has maven runtime.
+ - openwebbeans-osgi-1.0.0-alpha-1.jar     --> ClassPath ScannerService SPI implementation for OSGI environments like Apache Geronimo-3
+ - openwebbeans-web-1.0.0-alpha-1.jar      --> Basic Servlet integration
+ - openwebbeans-tomcat6-1.0.0-alpha-1.jar  --> Support for deeper integration into Apache Tomcat-6
+ - openwebbeans-tomcat7-1.0.0-alpha-1.jar  --> Support for deeper integration into Apache Tomcat-7
+
+
+
+
+------------------------------------------
+How OWB Plugins Work
+------------------------------------------
+
+OpenWebBeans has been developing in a plugin way. The Core dependency injection service
+is provided with openwebbeans-impl. If you need further service functionality, 
+you have to add respective plugin jars into the application classpath. OpenWebBeans 
+uses the Java SE 6.0 java.util.ServiceLoader mechanism to pickup those plugins at runtime.
+
+Current Plugins:
+---------------------
+Look at "1.0.0-alpha-1 Distribution Content" above.
+
+------------------------------------------
+Dependent Libraries
+------------------------------------------
+
+Third Party jars:
+-----------------
+They are necessary at runtime in the Core Implementation.
+
+log4j: Version 1.2.14 
+dom4j: Version 1.6.1
+javassist : Version 3.12.0.GA
+scannotation : Version 1.0.2 (if not running in an OSGi environment like Apache Geronimo-3)
+
+Java EE APIs jars(Container Provider Libraries) :
+-------------------------------------------------
+Generally full Java EE servers provides these jars. But web containers like Tomcat or Jetty
+does not contain some of them, such as JPA, JSF, Validation API etc. So, if you do not want to bundle
+these libraries within your application classpath, you have to put these libraries into your
+server common classpath if it does not contain.
+
+jcdi-api (JSR-299 Specification API)
+atinject-api (JSR-330 Specification API)
+servlet-2.5 or servlet 3.0 (Servlet Specification API)
+ejb-3.1 (EJB Specification API)
+el-2.2 (Expression Langauge Specification API)
+jsf-2.0 (Java Server Faces API)
+jsr-250 (Annotation API)
+interceptor-1.1 (Interceptor API)
+jta-1.1 (Java Transaction API)
+jsp.2.1 or jsp-2.2 (Java Server Pages API)
+jpa-2.0 (Java Persistence API)
+jaxws-2.1 or jaxws-2.2 (Java Web Service API)
+jms-1.1 or jms-1.2 (Java Messaging Service API)
+validation (Validation Specification)
+
+Dependencies of OpenWebBeans Maven Modules&Plugins
+--------------------------------------------------
+
+openwebbeans-impl : 
+------------------
+Third party        : log4j, dom4j, javassist, scannotation, openwebbeans-spi
+Container Provided : jcdi-api, at-inject, servlet, el, jsr-250, interceptor, jta, jsp, validation
+
+openwebbeans-ejb:
+-----------------
+Third party        : openwebbeans-impl and its dependencies
+Container Provided : OpenWebBeans EJB plugin is based on OpenEJB in Tomcat. Therefore, if you install OpenEJB
+                     within Tomcat correctly, there is no need to add any additional libraries. Look at the
+                     OpenEJB in Tomcat configuration section.
+
+openwebbeans-jms:
+-----------------
+Third party        : openwebbeans-impl and its dependencies
+Container Provided : jms
+
+openwebbeans-jsf:
+-----------------
+Third party        : openwebbeans-impl and its dependencies
+Container Provided : jsf
+
+NOTE : We are trying to decrease dependent libraries of the our core, i.e, openwebbeans-impl. 
+At 1.0.0, dependent third party libraries will be decreased. We have a plan to create profile
+plugins, therefore each profile plugin provides its own dependent libraries. For example, in 
+fully Java EE Profile Plugin, Transaction API is supported but this will not be the case
+for Java Web Profile Plugin or Java SE Profile Plugin. Stay Tune!
+
+Currently, as you have seen above, openwebbeans-impl depends on some Java EE/Runtime
+provided libraries (servlet, jsp, el etc). In the future, with OpenWebBeans profiling support,
+openwebbeans-impl will not depend on any Java EE APIs. Those APIs will be provided
+by OpenWebBeans profiles/plugins that openwebbeans-impl will be used. Therefore,
+you will able to use OpenWebBeans in your own runtime environment easily by writing
+your own plugins and contributing it to OpenWebBeans :)
+        
+------------------------------------------
+Library Configuration
+------------------------------------------
+To run openwebbeans applications in the Java EE based application server, 
+you could add JSR-299 API and JSR-330 API into the server common classpath, and
+implementation, plugins and dependent jars into your "WEB-INF/lib" directory 
+of the Java EE Web Application.
+
+In this release, we can not support the OpenWebBeans as an integrated
+functionality of the Java EE Application Servers. So, you have to manage the
+configuration of the OpenWebBeans within your application's "web.xml" file. A sample "web.xml"
+file can be found in the "config" directory. To use EJB functionality, you also have to
+add OWB specific interceptor into your EJB beans. Look at the EJB section of this readme 
+for further details.
+
+---------------------------------------------
+OpenWebBeans Properties File
+---------------------------------------------
+OpenWebBeans uses a default configuration file to configure some of its
+properties. Default configuration file is embedded into the OWB implementation
+jar file. Instead of opening this jar file and changing configuration properties, simply add
+"openwebbeans.properties" file into a "META-INF/openwebbeans" folder of your application
+classpath. This will override the default configuration.
+
+Belows are default configuration properties of the OpenWebBeans that is embedded into openwebbeans-impl jar file.
+
+Each plugin or developer can provide its own SPI implementation class and its own configuration values. If you woud like
+to use those implementation classes or configuration values, you have to override default configuration file as explained
+in the above paragraph, i.e, putting "openwebbeans.properties" file into "META-INF/openwebbeans" folder of your application.
+
+For example : You add "META-INF/openwebbeans/openwebbeans.properties" in your application classpath. And you add the following
+key-value pair to use. And this service implementation is provided by your plugin, for example OpenWebBeans OpenEJB plugin.
+
+Override default value of ResourceInjectionService
+-------------------------------------------------
+org.apache.webbeans.spi.ResourceInjectionService=org.apache.webbeans.ejb.resource.OpenEjbResourceInjectionService
+
+OpenWebBeans uses the "OpenEjbResourceInjectionService" class to inject resources into the managed bean instances. 
+
+Configuration Names and Their Default Values :
+
+- "org.apache.webbeans.spi.ContainerLifecycle"
+   Description : Implementation of org.apache.webbeans.spi.ContainerLifecycle. All magic starts from here.
+   Values      : org.apache.webbeans.lifecycle.DefaultLifecycle, OR CUSTOM
+   Default     : org.apache.webbeans.lifecycle.DefaultLifecycle
+
+- "org.apache.webbeans.spi.JNDIService"
+   Description  : Configures JNDI provider implementation.
+   Values       : org.apache.webbeans.spi.se.DefaultJndiService OR CUSTOM
+   Default      : org.apache.webbeans.spi.se.DefaultJndiService
+
+- "org.apache.webbeans.spi.conversation.ConversationService"
+   Description  : Implementation of conversation.
+   Values       : org.apache.webbeans.spi.conversation.jsf.DefaultConversationService OR CUSTOM
+   Default      : org.apache.webbeans.spi.conversation.jsf.DefaultConversationService
+
+- "org.apache.webbeans.spi.ScannerService"
+   Description  : Default implementation of org.apache.webbeans.spi.ScannerService. It is used for scanning application deployment
+                  for finding bean classes and configuration files.
+   Values       : org.apache.webbeans.spi.ee.deployer.DefaultScannerService OR CUSTOM
+   Default      : org.apache.webbeans.spi.ee.deployer.DefaultScannerService
+
+- "org.apache.webbeans.spi.SecurityService"
+   Description   : Implementation of org.apache.webbeans.spi.SecurityService. It is used for getting current "Principal".
+   Values        : org.apache.webbeans.spi.se.DefaultSecurityService or CUSTOM
+   Default       : org.apache.webbeans.spi.se.DefaultSecurityService
+
+- "org.apache.webbeans.spi.ValidatorService"
+   Description   : Implementation of org.apache.webbeans.spi.ValidatorService. It is used for getting "ValidatorFactory" and "Validator".
+   Values        : org.apache.webbeans.spi.se.DefaultValidatorService or CUSTOM
+   Default       : org.apache.webbeans.spi.se.DefaultValidatorService
+
+- "org.apache.webbeans.spi.TransactionService"
+   Description   : Implementation of org.apache.webbeans.spi.TransactionService. It is used for getting "TransactionManager" and "Transaction".
+   Values        : org.apache.webbeans.spi.se.DefaultTransactionService or CUSTOM
+   Default       : org.apache.webbeans.spi.se.DefaultTransactionService
+
+- "org.apache.webbeans.spi.ResourceInjectionService" 
+   Description   : Implementation of org.apache.webbeans.spi.ResourceInjectionService. It is used for injection Java EE enviroment resource into the
+                   Managed Bean instances.
+   Values        : org.apache.webbeans.se.DefaultResourceInjectionService or CUSTOM
+   Default       : org.apache.webbeans.se.DefaultResourceInjectionService
+
+- "org.apache.webbeans.spi.JNDIService.jmsConnectionFactoryJndi"
+   Description   : Configures JMS ConnectionFactory object jndi name
+   Values        : Server specific JNDI name
+   Default       : ConnectionFactory
+
+- "org.apache.webbeans.conversation.Conversation.periodicDelay"
+   Description   : Conversation removing thread periodic delay
+   Values        : Configured in millisecond
+   Default       : 150000 ms
+
+- "org.apache.webbeans.spi.deployer.useEjbMetaDataDiscoveryService"
+   Description   : Use EJB functionality or not. If use OpenEJB configures to true
+   Values        : false, true
+   Default       : false
+
+---------------------------------------------
+EJB Support via Embeddable OpenEJB Container in Tomcat 6.X
+---------------------------------------------
+
+Configuration Steps:
+--------------------------------------------
+1* Download Tomcat 6.X version
+2* Configure OpenEJB. Look at URL http://openejb.apache.org/tomcat.html for installation.
+3* Copy JSR-330 API to Tomcat /lib folder.
+4* Copy JSR-299 API to Tomcat /lib folder
+5* Put all dependent libraries of the OpenWebBeans OpenEJB Plugin
+   - openwebbeans-ejb
+   - openwebbeans-impl and its dependencies
+
+You could look at ejb-sample.war for "WEB-INF/lib" libraries to develop custom application.
+You can also look at a source of the project.
+
+To use EJB functionality, you will use OpenEJB collapse-ear support. In this configuration,
+your EJB beans live within your "war" bundle.
+
+How to Develop EJB Applications
+---------------------------------------------
+1* Add "META-INF/openwebbeans.properties" into your application classpath.
+2* Add "org.apache.webbeans.spi.deployer.useEjbMetaDataDiscoveryService=true" to use EJB functionality.
+   So OWB container looks for EJBs.
+3* Add "org.apache.webbeans.resource.spi.ResourceService=org.apache.webbeans.ejb.resource.OpenEjbResourceInjectionService to
+use OpenEJB Resource injections.
+4* Add "openwebbeans-ejb", plugin into your web application classpath. 
+5* If you want to use other plugins, add respective plugins into your application classpath. For example, if you wish to use
+JSF framework, you add "openwebbeans-jsf" plugin.
+6* Add OWB related interceptor into your EJB Beans. This is called "org.apache.webbeans.ejb.interceptor.OpenWebBeansEjbInterceptor"
+This is needed for OWB injections.
+7* Update your application's "web.xml" to add OWB specific configuration.
+
+---------------------------------------------
+How to Run Samples
+---------------------------------------------
+
+In this release, there are several sample applications located in the "/samples" directory 
+of the distribution. You can run those samples via simple maven command.
+
+1) "Guess Application" : Simple usage of the OWB + JSF. 
+It can be run in the jetty web container via maven jetty plugin from source. 
+Look at "Compile and Run Samples via Jetty&Tomcat Plugin" section.
+
+2) "Hotel Reservation Application" : Show usage of JSF + JPA + OWB  
+It can be run in the jetty web container via maven jetty plugin from source. 
+Look at "Compile and Run Samples via Jetty&Tomcat Plugin" section.
+
+3) "EJB Sample Application" : Shows the usage of EJBs with embeddable OpenEJB in Tomcat. Firstly
+configure OpenEJB with Tomcat as explained above.
+Look at "Compile and Run Samples via Jetty&Tomcat Plugin" section.
+
+4) "EJB Telephone Application" : Shows the usage of OpenEJB resource injection service.
+Look at "Compile and Run Samples via Jetty&Tomcat Plugin" section.
+
+5) "JMS Injection Sample" : Show JMS injections. JMS injection currently uses
+   ConnectionFactory as JMS connection factory jndi name. You can change this
+   via configuration file. Look above explanation for how to configure JMS jndi. Also,
+   JMS injection requires to use of a JMS provider. Generally Java EE servers contains
+   default JMS provider. It can be run on JBoss and Geronimo. It uses Queue with jndi_name = "queue/A". 
+   So you have to create a queue destination in your JMS provider with name "queue/A" to run example. 
+   If you want to change queue jndi name, then look at source and change it from "WEB-INF/beans.xml" file.
+
+6) "Conversation Sample" : Shows usage of JSF conversations.
+It can be run in the jetty web container via maven jetty plugin from source.
+Look at "Compile and Run Samples via Jetty&Tomcat Plugin" section.
+
+7) "JSF2 Sample" : Shows usage of JSF2 Ajax.
+It can be run in the jetty web container via maven jetty plugin from source.
+Look at "Compile and Run Samples via Jetty&Tomcat Plugin" section. It requires
+to use JSF2 runtime.
+
+
+8) "Standalone Sample" : Shows usage of OpenWebBeans in Stadnalone Swing Application.
+Look at "OpenWebBeans in Java SE" section.
+
+Configuring and Running the Applications:
+--------------------------------------------
+See section Compile and Run Samples via Jetty&Tomcat Plugin.
+
+--------------------------------------------
+Maven Install and Package From the Source
+--------------------------------------------
+
+Maven Version : Apache Maven 2.2.1 or later
+
+Firstly you have to download the "source" version of the OpenWebBeans project that
+contains the all source codes of the OpenWebBeans.
+
+To install the Maven artifacts of the project from the source, Maven must be installed
+in your runtime. After Maven installation, just run the following command in the top level
+directory that contains the main "pom.xml" : 
+
+> mvn clean install
+
+This command will install all the Maven artifacts into your local Maven repository.
+
+If you wish to package all artifacts of the project, just run the following command
+in in the top level directory that contains the main "pom.xml" : 
+
+> mvn clean package
+
+This command will package the project artifacts from the source and put these artifacts into the each modules
+respective "target" directory.
+
+-------------------------------------------
+Compile and Run Samples via Tomcat&Jetty Plugin
+-------------------------------------------
+This section shows how to run samples in Jetty or OpenEJB Embedded Tomcat.
+
+------------------------------------------
+Samples Run within Jetty Plugin
+------------------------------------------
+You can compile and run "guess","jsf2","conversation-sample" and "reservation "samples via maven Jetty plugin.
+Go to the source bundle "samples/" directory. In the "guess/" or "reservation/" directory, run
+the following maven commands. It will start up maven Jetty container. It bundles all of the
+required jars into the WEB-INF/lib folder. You are not required to add any jar to the classpath.
+
+Samples : Guess and Reservation
+------------------------------
+Go to the source folder of projects and run
+
+> mvn clean install -Pjetty
+> mvn jetty:run -Pjetty
+
+Guess URL               : http://localhost:8080/guess
+Reservation URL         : http://localhost:8080/reservation
+
+Samples : Conversation Sample and JSF2
+-------------------------------------
+Go to the source folder of projects and run
+
+>mvn clean install
+>mvn jetty:run
+
+Conversation Sample URL : http://localhost:8080/conversation-sample
+JSF2 Sample URL         : http://localhost:8080/jsf2sample
+
+------------------------------------------
+Samples Run within Tomcat Plugin
+------------------------------------------
+OpenEJB samples are run with Maven Tomcat Plugin.
+
+Tomcat Plugin uses http://localhost:8080/manager application to deploy war file
+into your embeddable EJB Tomcat container. There must be an tomcat-users.xml
+file in the "conf" directory of the server that contains manager role and username.
+
+>Start Tomcat server if not started
+>mvn tomcat:deploy
+
+Ejb Sample URL    : http://localhost:8080/ejb-sample
+Ejb Telephone URL : http://localhost:8080/ejb-telephone
+
+Example tomcat-users.xml file
+------------------------------------------
+<tomcat-users>
+<role rolename="manager"/>
+<user username="admin" password="" roles="manager"/>
+</tomcat-users>
+
+-----------------------------------------
+Deploy JMS Sample
+-----------------------------------------
+Simple drops jms-sample.war file into your application deploy location.
+
+JMS Sample Example URL        : Hit the url http://localhost:8080/jms-sample/sender.jsf for sending JMS messages
+                                Hit the url http://localhost:8080/jms-sample/receiver.jsf for receiving JMS messages
+
+-----------------------------------------
+OpenWebBeans in Java SE
+----------------------------------------
+OpenWebBeans can perfeclty use in Java SE environment like Java Swing
+applications. Standalone Samples is provided to show how to use OpenWebBeans
+in Java SE.
+
+Go to the source directory of the standalone sample:
+>mvn clean package;
+>cd target;
+>jar -xvf standalone-sample.jar
+>java -jar standalone-sample-1.0.0-SNAPSHOT.jar
+>Enjoy :)
+
+-----------------------------------------------
+OpenWebBeans User and Development Mailing Lists
+-----------------------------------------------
+Please mail to the user mailing list about any questions or advice
+about the OpenWebBeans.
+
+User Mailing List : [users@openwebbeans.apache.org]
+
+You can also join the discussions happening in the dev list
+
+Dev Mailing List  : [dev@openwebbeans.apache.org]
+
+-------------------------------------------
+OpenWebBeans JIRA Page
+-------------------------------------------
+Please logs bugs into the "https://issues.apache.org/jira/browse/OWB".
+
+------------------------------------------
+OpenWebBeans Wiki and Blog Page
+-----------------------------------------
+Wiki: http://cwiki.apache.org/OWB/
+Introduction to OpenWebBeans : http://cwiki.apache.org/OWB/introduction-to-openwebbeans.html
+Blog : http://blogs.apache.org/owb
+
+-----------------------------------------
+OpenWebBeans Web Page
+----------------------------------------
+You can reach the OpenWebBeans web page at
+http://openwebbeans.apache.org
+---------------------------------------
+
+Your OpenWebBeans Team
+
+Enjoy!