package railo.commons.sql;
import java.lang.reflect.Method;
import java.sql.Blob;
import java.sql.Connection;
import railo.commons.lang.ClassUtil;
import railo.runtime.op.Caster;
public class OracleBlob {
private static Integer duration;
private static Integer mode;
private static Method createTemporary;
private static Method open;
private static Method setBytes;
public static Blob createBlob(Connection conn,byte[] barr,Blob defaultValue) {
try{
Class clazz = ClassUtil.loadClass("oracle.sql.BLOB");
// BLOB.DURATION_SESSION
if(duration==null) duration = Caster.toInteger(clazz.getField("DURATION_SESSION").getInt(null));
// BLOB.MODE_READWRITE
if(mode==null) mode = Caster.toInteger(clazz.getField("MODE_READWRITE").getInt(null));
//BLOB blob = BLOB.createTemporary(conn, false, BLOB.DURATION_SESSION);
if(createTemporary==null || createTemporary.getDeclaringClass()!=clazz)
createTemporary = clazz.getMethod("createTemporary", new Class[]{Connection.class,boolean.class,int.class});
Object blob = createTemporary.invoke(null, new Object[]{conn,Boolean.FALSE,duration});
//blob.open(BLOB.MODE_READWRITE);
if(open==null || open.getDeclaringClass()!=clazz)
open = clazz.getMethod("open", new Class[]{int.class});
open.invoke(blob, new Object[]{mode});
//blob.setBytes(1,barr);
if(setBytes==null || setBytes.getDeclaringClass()!=clazz)
setBytes = clazz.getMethod("setBytes", new Class[]{long.class,byte[].class});
setBytes.invoke(blob, new Object[]{Long.valueOf(1),barr});
return (Blob) blob;
}
catch(Throwable t){
//print.printST(t);
}
return defaultValue;
}
}