KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > jboss > test > mdb > bean > BMPBean


1 /*
2   * JBoss, Home of Professional Open Source
3   * Copyright 2005, JBoss Inc., and individual contributors as indicated
4   * by the @authors tag. See the copyright.txt in the distribution for a
5   * full listing of individual contributors.
6   *
7   * This is free software; you can redistribute it and/or modify it
8   * under the terms of the GNU Lesser General Public License as
9   * published by the Free Software Foundation; either version 2.1 of
10   * the License, or (at your option) any later version.
11   *
12   * This software is distributed in the hope that it will be useful,
13   * but WITHOUT ANY WARRANTY; without even the implied warranty of
14   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15   * Lesser General Public License for more details.
16   *
17   * You should have received a copy of the GNU Lesser General Public
18   * License along with this software; if not, write to the Free
19   * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
20   * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
21   */

22 package org.jboss.test.mdb.bean;
23
24 import javax.ejb.MessageDrivenBean JavaDoc;
25 import javax.ejb.MessageDrivenContext JavaDoc;
26 import javax.ejb.EJBException JavaDoc;
27
28 import javax.jms.MessageListener JavaDoc;
29 import javax.jms.Message JavaDoc;
30 import javax.naming.InitialContext JavaDoc;
31 import javax.transaction.Status JavaDoc;
32 import javax.transaction.Transaction JavaDoc;
33 import javax.transaction.TransactionManager JavaDoc;
34 import javax.transaction.xa.XAResource JavaDoc;
35
36 /**
37  * MessageBeanImpl.java
38  *
39  *
40  * Created: Sat Nov 25 18:07:50 2000
41  *
42  * @author
43  * @version
44  */

45
46 public class BMPBean implements MessageDrivenBean JavaDoc, MessageListener JavaDoc{
47    org.jboss.logging.Logger log = org.jboss.logging.Logger.getLogger(getClass());
48    
49     private MessageDrivenContext JavaDoc ctx = null;
50     public BMPBean() {
51     
52     }
53     public void setMessageDrivenContext(MessageDrivenContext JavaDoc ctx)
54     throws EJBException JavaDoc {
55     this.ctx = ctx;
56     }
57     
58     public void ejbCreate() {}
59
60     public void ejbRemove() {ctx=null;}
61
62     public void onMessage(Message JavaDoc message) {
63
64         log.debug("DEBUG: BMPBean got message" + message.toString() );
65         try {
66           TransactionManager JavaDoc tm = (TransactionManager JavaDoc)new InitialContext JavaDoc().lookup("java:/TransactionManager");
67           Transaction JavaDoc threadTx = tm.suspend();
68             log.debug("DEBUG Tx="+threadTx);
69
70     log.debug("Sleeping for 10 seconds");
71       try { Thread.currentThread().sleep(1000*10);
72       } catch ( InterruptedException JavaDoc e ) {}
73     log.debug("Sleep done");
74
75             if( threadTx != null )
76                 tm.resume(threadTx);
77         } catch (Exception JavaDoc e) {
78           log.debug("BMPBean Error:"+e);
79         }
80     }
81 }
82
83
84
Popular Tags