1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski import java.io.*;
25*b1cdbd2cSJim Jagielski 
26*b1cdbd2cSJim Jagielski import com.sun.star.comp.helper.RegistryServiceFactory;
27*b1cdbd2cSJim Jagielski import com.sun.star.comp.servicemanager.ServiceManager;
28*b1cdbd2cSJim Jagielski import com.sun.star.lang.XMultiComponentFactory;
29*b1cdbd2cSJim Jagielski import com.sun.star.lang.XServiceInfo;
30*b1cdbd2cSJim Jagielski import com.sun.star.lang.XComponent;
31*b1cdbd2cSJim Jagielski import com.sun.star.bridge.XUnoUrlResolver;
32*b1cdbd2cSJim Jagielski import com.sun.star.uno.UnoRuntime;
33*b1cdbd2cSJim Jagielski import com.sun.star.uno.XComponentContext;
34*b1cdbd2cSJim Jagielski import com.sun.star.beans.XPropertySet;
35*b1cdbd2cSJim Jagielski import com.sun.star.container.XNameAccess;
36*b1cdbd2cSJim Jagielski import com.sun.star.sdbc.*;
37*b1cdbd2cSJim Jagielski import com.sun.star.sdbcx.Privilege;
38*b1cdbd2cSJim Jagielski import com.sun.star.sdb.CommandType;
39*b1cdbd2cSJim Jagielski import com.sun.star.sdb.XRowSetApproveBroadcaster;
40*b1cdbd2cSJim Jagielski 
41*b1cdbd2cSJim Jagielski public class RowSet
42*b1cdbd2cSJim Jagielski {
43*b1cdbd2cSJim Jagielski     private static XComponentContext xContext = null;
44*b1cdbd2cSJim Jagielski     private static XMultiComponentFactory xMCF = null;
main(String argv[])45*b1cdbd2cSJim Jagielski 	public static void main(String argv[]) throws java.lang.Exception
46*b1cdbd2cSJim Jagielski 	{
47*b1cdbd2cSJim Jagielski         try {
48*b1cdbd2cSJim Jagielski             // get the remote office component context
49*b1cdbd2cSJim Jagielski             xContext = com.sun.star.comp.helper.Bootstrap.bootstrap();
50*b1cdbd2cSJim Jagielski             System.out.println("Connected to a running office ...");
51*b1cdbd2cSJim Jagielski             xMCF = xContext.getServiceManager();
52*b1cdbd2cSJim Jagielski         }
53*b1cdbd2cSJim Jagielski         catch( Exception e) {
54*b1cdbd2cSJim Jagielski             System.err.println("ERROR: can't get a component context from a running office ...");
55*b1cdbd2cSJim Jagielski             e.printStackTrace(System.out);
56*b1cdbd2cSJim Jagielski             System.exit(1);
57*b1cdbd2cSJim Jagielski         }
58*b1cdbd2cSJim Jagielski 
59*b1cdbd2cSJim Jagielski         try{
60*b1cdbd2cSJim Jagielski 			showRowSetEvents();
61*b1cdbd2cSJim Jagielski 			showRowSetRowCount();
62*b1cdbd2cSJim Jagielski 			showRowSetPrivileges();
63*b1cdbd2cSJim Jagielski 			useRowSet();
64*b1cdbd2cSJim Jagielski 		}
65*b1cdbd2cSJim Jagielski 		catch(com.sun.star.uno.Exception e)
66*b1cdbd2cSJim Jagielski 		{
67*b1cdbd2cSJim Jagielski 			System.err.println(e);
68*b1cdbd2cSJim Jagielski 			e.printStackTrace();
69*b1cdbd2cSJim Jagielski 		}
70*b1cdbd2cSJim Jagielski 		System.exit(0);
71*b1cdbd2cSJim Jagielski 	}
72*b1cdbd2cSJim Jagielski 
printDataSources()73*b1cdbd2cSJim Jagielski 	public static void printDataSources() throws com.sun.star.uno.Exception
74*b1cdbd2cSJim Jagielski 	{
75*b1cdbd2cSJim Jagielski 		// create a DatabaseContext and print all DataSource names
76*b1cdbd2cSJim Jagielski 		XNameAccess xNameAccess = (XNameAccess)UnoRuntime.queryInterface(
77*b1cdbd2cSJim Jagielski             XNameAccess.class,
78*b1cdbd2cSJim Jagielski             xMCF.createInstanceWithContext("com.sun.star.sdb.DatabaseContext",
79*b1cdbd2cSJim Jagielski                                            xContext));
80*b1cdbd2cSJim Jagielski 		String aNames [] = xNameAccess.getElementNames();
81*b1cdbd2cSJim Jagielski 		for(int i=0;i<aNames.length;++i)
82*b1cdbd2cSJim Jagielski 			System.out.println(aNames[i]);
83*b1cdbd2cSJim Jagielski 	}
84*b1cdbd2cSJim Jagielski 
useRowSet()85*b1cdbd2cSJim Jagielski 	public static void useRowSet() throws com.sun.star.uno.Exception
86*b1cdbd2cSJim Jagielski 	{
87*b1cdbd2cSJim Jagielski 		// first we create our RowSet object
88*b1cdbd2cSJim Jagielski 		XRowSet xRowRes = (XRowSet)UnoRuntime.queryInterface(
89*b1cdbd2cSJim Jagielski             XRowSet.class,
90*b1cdbd2cSJim Jagielski             xMCF.createInstanceWithContext("com.sun.star.sdb.RowSet", xContext));
91*b1cdbd2cSJim Jagielski 
92*b1cdbd2cSJim Jagielski 		System.out.println("RowSet created!");
93*b1cdbd2cSJim Jagielski 		// set the properties needed to connect to a database
94*b1cdbd2cSJim Jagielski 		XPropertySet xProp = (XPropertySet)UnoRuntime.queryInterface(XPropertySet.class,xRowRes);
95*b1cdbd2cSJim Jagielski 		xProp.setPropertyValue("DataSourceName","Bibliography");
96*b1cdbd2cSJim Jagielski 		xProp.setPropertyValue("Command","biblio");
97*b1cdbd2cSJim Jagielski 		xProp.setPropertyValue("CommandType",new Integer(com.sun.star.sdb.CommandType.TABLE));
98*b1cdbd2cSJim Jagielski 
99*b1cdbd2cSJim Jagielski 		xRowRes.execute();
100*b1cdbd2cSJim Jagielski 		System.out.println("RowSet executed!");
101*b1cdbd2cSJim Jagielski 
102*b1cdbd2cSJim Jagielski 
103*b1cdbd2cSJim Jagielski 		XComponent xComp = (XComponent)UnoRuntime.queryInterface(XComponent.class,xRowRes);
104*b1cdbd2cSJim Jagielski 		xComp.dispose();
105*b1cdbd2cSJim Jagielski 		System.out.println("RowSet destroyed!");
106*b1cdbd2cSJim Jagielski 	}
107*b1cdbd2cSJim Jagielski 
showRowSetPrivileges()108*b1cdbd2cSJim Jagielski 	public static void showRowSetPrivileges() throws com.sun.star.uno.Exception
109*b1cdbd2cSJim Jagielski 	{
110*b1cdbd2cSJim Jagielski 		// first we create our RowSet object
111*b1cdbd2cSJim Jagielski 		XRowSet xRowRes = (XRowSet)UnoRuntime.queryInterface(
112*b1cdbd2cSJim Jagielski             XRowSet.class,
113*b1cdbd2cSJim Jagielski             xMCF.createInstanceWithContext("com.sun.star.sdb.RowSet", xContext));
114*b1cdbd2cSJim Jagielski 
115*b1cdbd2cSJim Jagielski 		System.out.println("RowSet created!");
116*b1cdbd2cSJim Jagielski 		// set the properties needed to connect to a database
117*b1cdbd2cSJim Jagielski 		XPropertySet xProp = (XPropertySet)UnoRuntime.queryInterface(XPropertySet.class,xRowRes);
118*b1cdbd2cSJim Jagielski 		xProp.setPropertyValue("DataSourceName","Bibliography");
119*b1cdbd2cSJim Jagielski 		xProp.setPropertyValue("Command","biblio");
120*b1cdbd2cSJim Jagielski 		xProp.setPropertyValue("CommandType",new Integer(com.sun.star.sdb.CommandType.TABLE));
121*b1cdbd2cSJim Jagielski 
122*b1cdbd2cSJim Jagielski 		xRowRes.execute();
123*b1cdbd2cSJim Jagielski 		System.out.println("RowSet executed!");
124*b1cdbd2cSJim Jagielski 
125*b1cdbd2cSJim Jagielski 		Integer aPriv = (Integer)xProp.getPropertyValue("Privileges");
126*b1cdbd2cSJim Jagielski 		int nPriv  = aPriv.intValue();
127*b1cdbd2cSJim Jagielski 		if( (nPriv & Privilege.SELECT) == Privilege.SELECT)
128*b1cdbd2cSJim Jagielski 			System.out.println("SELECT");
129*b1cdbd2cSJim Jagielski 		if( (nPriv & Privilege.INSERT) == Privilege.INSERT)
130*b1cdbd2cSJim Jagielski 			System.out.println("INSERT");
131*b1cdbd2cSJim Jagielski 		if( (nPriv & Privilege.UPDATE) == Privilege.UPDATE)
132*b1cdbd2cSJim Jagielski 			System.out.println("UPDATE");
133*b1cdbd2cSJim Jagielski 		if( (nPriv & Privilege.DELETE) == Privilege.DELETE)
134*b1cdbd2cSJim Jagielski 			System.out.println("DELETE");
135*b1cdbd2cSJim Jagielski 
136*b1cdbd2cSJim Jagielski 		// now destroy the RowSet
137*b1cdbd2cSJim Jagielski 		XComponent xComp = (XComponent)UnoRuntime.queryInterface(XComponent.class,xRowRes);
138*b1cdbd2cSJim Jagielski 		xComp.dispose();
139*b1cdbd2cSJim Jagielski 		System.out.println("RowSet destroyed!");
140*b1cdbd2cSJim Jagielski 	}
141*b1cdbd2cSJim Jagielski 
showRowSetRowCount()142*b1cdbd2cSJim Jagielski 	public static void showRowSetRowCount() throws com.sun.star.uno.Exception
143*b1cdbd2cSJim Jagielski 	{
144*b1cdbd2cSJim Jagielski 		// first we create our RowSet object
145*b1cdbd2cSJim Jagielski 		XRowSet xRowRes = (XRowSet)UnoRuntime.queryInterface(
146*b1cdbd2cSJim Jagielski             XRowSet.class,
147*b1cdbd2cSJim Jagielski             xMCF.createInstanceWithContext("com.sun.star.sdb.RowSet", xContext));
148*b1cdbd2cSJim Jagielski 
149*b1cdbd2cSJim Jagielski 		System.out.println("RowSet created!");
150*b1cdbd2cSJim Jagielski 		// set the properties needed to connect to a database
151*b1cdbd2cSJim Jagielski 		XPropertySet xProp = (XPropertySet)UnoRuntime.queryInterface(XPropertySet.class,xRowRes);
152*b1cdbd2cSJim Jagielski 		xProp.setPropertyValue("DataSourceName","Bibliography");
153*b1cdbd2cSJim Jagielski 		xProp.setPropertyValue("Command","biblio");
154*b1cdbd2cSJim Jagielski 		xProp.setPropertyValue("CommandType",new Integer(com.sun.star.sdb.CommandType.TABLE));
155*b1cdbd2cSJim Jagielski 
156*b1cdbd2cSJim Jagielski 		xRowRes.execute();
157*b1cdbd2cSJim Jagielski 		System.out.println("RowSet executed!");
158*b1cdbd2cSJim Jagielski 
159*b1cdbd2cSJim Jagielski 		// now look if the RowCount is already final
160*b1cdbd2cSJim Jagielski 		System.out.println("The RowCount is final: " + xProp.getPropertyValue("IsRowCountFinal"));
161*b1cdbd2cSJim Jagielski 
162*b1cdbd2cSJim Jagielski 		XResultSet xRes = (XResultSet)UnoRuntime.queryInterface(XResultSet.class,xRowRes);
163*b1cdbd2cSJim Jagielski 		xRes.last();
164*b1cdbd2cSJim Jagielski 
165*b1cdbd2cSJim Jagielski 		System.out.println("The RowCount is final: " + xProp.getPropertyValue("IsRowCountFinal"));
166*b1cdbd2cSJim Jagielski 		System.out.println("There are " + xProp.getPropertyValue("RowCount") + " rows!");
167*b1cdbd2cSJim Jagielski 
168*b1cdbd2cSJim Jagielski 		// now destroy the RowSet
169*b1cdbd2cSJim Jagielski 		XComponent xComp = (XComponent)UnoRuntime.queryInterface(XComponent.class,xRowRes);
170*b1cdbd2cSJim Jagielski 		xComp.dispose();
171*b1cdbd2cSJim Jagielski 		System.out.println("RowSet destroyed!");
172*b1cdbd2cSJim Jagielski 	}
173*b1cdbd2cSJim Jagielski 
showRowSetEvents()174*b1cdbd2cSJim Jagielski 	public static void showRowSetEvents() throws com.sun.star.uno.Exception
175*b1cdbd2cSJim Jagielski 	{
176*b1cdbd2cSJim Jagielski 		// first we create our RowSet object
177*b1cdbd2cSJim Jagielski 		XRowSet xRowRes = (XRowSet)UnoRuntime.queryInterface(
178*b1cdbd2cSJim Jagielski             XRowSet.class,
179*b1cdbd2cSJim Jagielski             xMCF.createInstanceWithContext("com.sun.star.sdb.RowSet", xContext));
180*b1cdbd2cSJim Jagielski 
181*b1cdbd2cSJim Jagielski 		System.out.println("RowSet created!");
182*b1cdbd2cSJim Jagielski 		// add our Listener
183*b1cdbd2cSJim Jagielski 		System.out.println("Append our Listener!");
184*b1cdbd2cSJim Jagielski 		RowSetEventListener pRow = new RowSetEventListener();
185*b1cdbd2cSJim Jagielski 		XRowSetApproveBroadcaster xApBroad = (XRowSetApproveBroadcaster)UnoRuntime.queryInterface(XRowSetApproveBroadcaster.class,xRowRes);
186*b1cdbd2cSJim Jagielski 		xApBroad.addRowSetApproveListener(pRow);
187*b1cdbd2cSJim Jagielski 		xRowRes.addRowSetListener(pRow);
188*b1cdbd2cSJim Jagielski 
189*b1cdbd2cSJim Jagielski 		// set the properties needed to connect to a database
190*b1cdbd2cSJim Jagielski 		XPropertySet xProp = (XPropertySet)UnoRuntime.queryInterface(XPropertySet.class,xRowRes);
191*b1cdbd2cSJim Jagielski 		xProp.setPropertyValue("DataSourceName","Bibliography");
192*b1cdbd2cSJim Jagielski 		xProp.setPropertyValue("Command","biblio");
193*b1cdbd2cSJim Jagielski 		xProp.setPropertyValue("CommandType",new Integer(com.sun.star.sdb.CommandType.TABLE));
194*b1cdbd2cSJim Jagielski 
195*b1cdbd2cSJim Jagielski 		xRowRes.execute();
196*b1cdbd2cSJim Jagielski 		System.out.println("RowSet executed!");
197*b1cdbd2cSJim Jagielski 
198*b1cdbd2cSJim Jagielski 		// do some movements to check if we got all notifications
199*b1cdbd2cSJim Jagielski 		XResultSet xRes = (XResultSet)UnoRuntime.queryInterface(XResultSet.class,xRowRes);
200*b1cdbd2cSJim Jagielski 		System.out.println("beforeFirst");
201*b1cdbd2cSJim Jagielski 		xRes.beforeFirst();
202*b1cdbd2cSJim Jagielski 		// this should lead to no notifications because
203*b1cdbd2cSJim Jagielski 		// we should stand before the first row at the beginning
204*b1cdbd2cSJim Jagielski 		System.out.println("We stand before the first row: " + xRes.isBeforeFirst());
205*b1cdbd2cSJim Jagielski 
206*b1cdbd2cSJim Jagielski 		System.out.println("next");
207*b1cdbd2cSJim Jagielski 		xRes.next();
208*b1cdbd2cSJim Jagielski 		System.out.println("next");
209*b1cdbd2cSJim Jagielski 		xRes.next();
210*b1cdbd2cSJim Jagielski 		System.out.println("last");
211*b1cdbd2cSJim Jagielski 		xRes.last();
212*b1cdbd2cSJim Jagielski 		System.out.println("next");
213*b1cdbd2cSJim Jagielski 		xRes.next();
214*b1cdbd2cSJim Jagielski 		System.out.println("We stand after the last row: " + xRes.isAfterLast());
215*b1cdbd2cSJim Jagielski 		System.out.println("first");
216*b1cdbd2cSJim Jagielski 		xRes.first();
217*b1cdbd2cSJim Jagielski 		System.out.println("previous");
218*b1cdbd2cSJim Jagielski 		xRes.previous();
219*b1cdbd2cSJim Jagielski 		System.out.println("We stand before the first row: " + xRes.isBeforeFirst());
220*b1cdbd2cSJim Jagielski 		System.out.println("afterLast");
221*b1cdbd2cSJim Jagielski 		xRes.afterLast();
222*b1cdbd2cSJim Jagielski 		System.out.println("We stand after the last row: " + xRes.isAfterLast());
223*b1cdbd2cSJim Jagielski 
224*b1cdbd2cSJim Jagielski 		// now destroy the RowSet
225*b1cdbd2cSJim Jagielski 		XComponent xComp = (XComponent)UnoRuntime.queryInterface(XComponent.class,xRowRes);
226*b1cdbd2cSJim Jagielski 		xComp.dispose();
227*b1cdbd2cSJim Jagielski 		System.out.println("RowSet destroyed!");
228*b1cdbd2cSJim Jagielski 	}
229*b1cdbd2cSJim Jagielski }
230*b1cdbd2cSJim Jagielski 
231