FileDocCategorySizeDatePackage
ProfileBeanEJB3.javaAPI DocExample2611Thu Dec 15 21:07:06 GMT 2005com.oreilly.jent.ejb.stateful

ProfileBeanEJB3.java

package com.oreilly.jent.ejb.stateful;

/**
 * In general, you may use the code in this book in your programs and 
 * documentation. You do not need to contact us for permission unless 
 * you're reproducing a significant portion of the code. For example, 
 * writing a program that uses several chunks of code from this book does 
 * not require permission. Selling or distributing a CD-ROM of examples 
 * from O'Reilly books does require permission. Answering a question by 
 * citing this book and quoting example code does not require permission. 
 * Incorporating a significant amount of example code from this book into 
 * your product's documentation does require permission.
 * 
 * We appreciate, but do not require, attribution. An attribution usually 
 * includes the title, author, publisher, and ISBN. For example: 
 * 
 *   "Java Enterprise in a Nutshell, Third Edition, 
 *    by Jim Farley and William Crawford 
 *    with Prakash Malani, John G. Norman, and Justin Gehtland. 
 *    Copyright 2006 O'Reilly Media, Inc., 0-596-10142-2."
 *  
 *  If you feel your use of code examples falls outside fair use or the 
 *  permission given above, feel free to contact us at 
 *  permissions@oreilly.com.
 */

import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Properties;

import javax.ejb.SessionBean;
import javax.ejb.SessionContext;

import com.oreilly.jent.ejb.NoSuchPersonException;

// A stateful session Profile, which provides profile information
// for a named person.

// Indicate this is a stateful session bean
@Stateful(name="ProfileEJB3")
// Request a remote client interface for this bean
@Remote
// Specify deployed resources this bean depends on
@Resource(name="ProfileDB",
          resourceType="javax.sql.DataSource",
          jndiName="jdbc/ProfileDB")
// Note: No need to extend the SessionBean interface
public class ProfileBeanEJB3 {
    // Name of the person owning the profile
    private String mName = "";
    // Entries in the profile (name/value pairs)
    private Properties mEntries = new Properties();
    
    // No activate, passivate methods - we don't need them, 
    // no need to write them.
    
    // Tag this as a business method, so it appears in the generated
    // client interface(s)
    @BusinessMethod
    // Also tag this as a web method, so it will be callable from
    // the SOAP interface.  Note that this annotation is actually
    // defined in the new JAX-RPC 2.0 spec, not in the EJB 3.0 spec.
    @WebMethod
    public String getName() {
        return mName;
    }
}