blob: 2883589c157e319e71ac00bde2fc3312f0a51b28 [file] [log] [blame]
/*
* Copyright (c) 2002, 2018 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0, which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the
* Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
* version 2 with the GNU Classpath Exception, which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
*/
package com.sun.s1peqe.connector.cci;
import java.math.BigDecimal;
import java.util.*;
import jakarta.ejb.*;
import jakarta.resource.cci.*;
import jakarta.resource.ResourceException;
import javax.naming.*;
import com.sun.connector.cciblackbox.*;
public class CoffeeBean implements SessionBean {
private SessionContext sc;
private String user;
private String password;
private ConnectionFactory cf;
public void ejbCreate() throws CreateException {
}
public void setSessionContext(SessionContext sc) {
try {
this.sc = sc;
Context ic = new InitialContext();
user = (String) ic.lookup("java:comp/env/user");
password = (String) ic.lookup("java:comp/env/password");
cf = (jakarta.resource.cci.ConnectionFactory) ic.lookup("java:comp/env/eis/CCIEIS");
} catch (NamingException ex) {
ex.printStackTrace();
}
}
public int getCoffeeCount() {
int count = -1;
try {
Connection con = getCCIConnection();
Interaction ix = con.createInteraction();
CciInteractionSpec iSpec = new CciInteractionSpec();
iSpec.setSchema(user);
iSpec.setCatalog(null);
iSpec.setFunctionName("COUNTCOFFEE");
RecordFactory rf = cf.getRecordFactory();
IndexedRecord iRec = rf.createIndexedRecord("InputRecord");
Record oRec = ix.execute(iSpec, iRec);
Iterator iterator = ((IndexedRecord)oRec).iterator();
while(iterator.hasNext()) {
Object obj = iterator.next();
if(obj instanceof Integer) {
count = ((Integer)obj).intValue();
}
else if(obj instanceof BigDecimal) {
count = ((BigDecimal)obj).intValue();
}
}
closeCCIConnection(con);
}catch(ResourceException ex) {
ex.printStackTrace();
}
return count;
}
public void insertCoffee(String name, int qty) {
try {
Connection con = getCCIConnection();
Interaction ix = con.createInteraction();
CciInteractionSpec iSpec = new CciInteractionSpec();
iSpec.setFunctionName("INSERTCOFFEE");
iSpec.setSchema(user);
iSpec.setCatalog(null);
RecordFactory rf = cf.getRecordFactory();
IndexedRecord iRec = rf.createIndexedRecord("InputRecord");
boolean flag = iRec.add(name);
flag = iRec.add(new Integer(qty));
ix.execute(iSpec, iRec);
closeCCIConnection(con);
}catch(ResourceException ex) {
ex.printStackTrace();
}
}
private Connection getCCIConnection() {
Connection con = null;
System.out.println("<========== IN get cci Connection ===========>");
try {
ConnectionSpec spec = new CciConnectionSpec("DBUSER", "DBPASSWORD");
System.out.println("<========== Created ISpec ===========>");
System.out.println("CF value : " + cf);
con = cf.getConnection(spec);
} catch (ResourceException ex) {
ex.printStackTrace();
}
return con;
}
private void closeCCIConnection(Connection con) {
try {
con.close();
} catch (ResourceException ex) {
ex.printStackTrace();
}
}
public void ejbRemove() {}
public void ejbActivate() {}
public void ejbPassivate() {}
}