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 package connectivity.tools;
25*b1cdbd2cSJim Jagielski 
26*b1cdbd2cSJim Jagielski import com.sun.star.beans.XPropertySet;
27*b1cdbd2cSJim Jagielski import com.sun.star.container.XNameAccess;
28*b1cdbd2cSJim Jagielski import com.sun.star.sdbc.ColumnValue;
29*b1cdbd2cSJim Jagielski import com.sun.star.sdbcx.XColumnsSupplier;
30*b1cdbd2cSJim Jagielski import com.sun.star.sdbcx.XDataDescriptorFactory;
31*b1cdbd2cSJim Jagielski import com.sun.star.sdbcx.XTablesSupplier;
32*b1cdbd2cSJim Jagielski import com.sun.star.uno.UnoRuntime;
33*b1cdbd2cSJim Jagielski import connectivity.tools.sdb.Connection;
34*b1cdbd2cSJim Jagielski 
35*b1cdbd2cSJim Jagielski /** is a very simply descriptor of a HSQL table, to be used with a HsqlDatabase.createTable method
36*b1cdbd2cSJim Jagielski  */
37*b1cdbd2cSJim Jagielski public class HsqlTableDescriptor
38*b1cdbd2cSJim Jagielski {
39*b1cdbd2cSJim Jagielski     private String                  m_name;
40*b1cdbd2cSJim Jagielski     private HsqlColumnDescriptor[]  m_columns;
41*b1cdbd2cSJim Jagielski 
42*b1cdbd2cSJim Jagielski     /** Creates a new instance of HsqlTableDescriptor */
HsqlTableDescriptor( String _name, HsqlColumnDescriptor[] _columns )43*b1cdbd2cSJim Jagielski     public HsqlTableDescriptor( String _name, HsqlColumnDescriptor[] _columns )
44*b1cdbd2cSJim Jagielski     {
45*b1cdbd2cSJim Jagielski         m_name = _name;
46*b1cdbd2cSJim Jagielski         m_columns = _columns;
47*b1cdbd2cSJim Jagielski     }
48*b1cdbd2cSJim Jagielski 
49*b1cdbd2cSJim Jagielski     /** returns the name of the table
50*b1cdbd2cSJim Jagielski      */
getName()51*b1cdbd2cSJim Jagielski     public String getName()
52*b1cdbd2cSJim Jagielski     {
53*b1cdbd2cSJim Jagielski         return m_name;
54*b1cdbd2cSJim Jagielski     }
55*b1cdbd2cSJim Jagielski 
56*b1cdbd2cSJim Jagielski     /** returns the set of column descriptors for the table
57*b1cdbd2cSJim Jagielski      */
getColumns()58*b1cdbd2cSJim Jagielski     public HsqlColumnDescriptor[] getColumns()
59*b1cdbd2cSJim Jagielski     {
60*b1cdbd2cSJim Jagielski         return m_columns;
61*b1cdbd2cSJim Jagielski     }
62*b1cdbd2cSJim Jagielski 
createSdbcxDescriptor( Connection _forConnection )63*b1cdbd2cSJim Jagielski     public XPropertySet createSdbcxDescriptor( Connection _forConnection )
64*b1cdbd2cSJim Jagielski     {
65*b1cdbd2cSJim Jagielski         XTablesSupplier suppTables = UnoRuntime.queryInterface( XTablesSupplier.class, _forConnection.getXConnection() );
66*b1cdbd2cSJim Jagielski         XDataDescriptorFactory tableDescFac = UnoRuntime.queryInterface( XDataDescriptorFactory.class, suppTables.getTables() );
67*b1cdbd2cSJim Jagielski         XPropertySet tableDesc = tableDescFac.createDataDescriptor();
68*b1cdbd2cSJim Jagielski 
69*b1cdbd2cSJim Jagielski         try
70*b1cdbd2cSJim Jagielski         {
71*b1cdbd2cSJim Jagielski             tableDesc.setPropertyValue( "Name", getName() );
72*b1cdbd2cSJim Jagielski         }
73*b1cdbd2cSJim Jagielski         catch ( Exception e ) { e.printStackTrace( System.err ); }
74*b1cdbd2cSJim Jagielski 
75*b1cdbd2cSJim Jagielski         XColumnsSupplier suppDescCols = UnoRuntime.queryInterface( XColumnsSupplier.class, tableDesc );
76*b1cdbd2cSJim Jagielski 
77*b1cdbd2cSJim Jagielski         XNameAccess descColumns = suppDescCols.getColumns();
78*b1cdbd2cSJim Jagielski         XDataDescriptorFactory columnDescFac = UnoRuntime.queryInterface( XDataDescriptorFactory.class, descColumns );
79*b1cdbd2cSJim Jagielski 
80*b1cdbd2cSJim Jagielski         HsqlColumnDescriptor[] myColumns = getColumns();
81*b1cdbd2cSJim Jagielski         for ( int i = 0; i < myColumns.length; ++i )
82*b1cdbd2cSJim Jagielski         {
83*b1cdbd2cSJim Jagielski             XPropertySet columnDesc = columnDescFac.createDataDescriptor();
84*b1cdbd2cSJim Jagielski             try
85*b1cdbd2cSJim Jagielski             {
86*b1cdbd2cSJim Jagielski                 columnDesc.setPropertyValue( "Name", myColumns[i].getName() );
87*b1cdbd2cSJim Jagielski                 columnDesc.setPropertyValue( "IsNullable", new Integer( myColumns[i].isRequired() ? ColumnValue.NO_NULLS : ColumnValue.NULLABLE) );
88*b1cdbd2cSJim Jagielski                 columnDesc.setPropertyValue( "TypeName", myColumns[i].getTypeName() );
89*b1cdbd2cSJim Jagielski                 if ( myColumns[i].isPrimaryKey() || myColumns[i].isForeignKey() )
90*b1cdbd2cSJim Jagielski                     // not yet implemented
91*b1cdbd2cSJim Jagielski                     throw new java.lang.UnsupportedOperationException("creating a primary or foreign key via SDBCX not yet implemented" );
92*b1cdbd2cSJim Jagielski             }
93*b1cdbd2cSJim Jagielski             catch( com.sun.star.uno.Exception e ) { e.printStackTrace( System.err ); }
94*b1cdbd2cSJim Jagielski         }
95*b1cdbd2cSJim Jagielski 
96*b1cdbd2cSJim Jagielski         return tableDesc;
97*b1cdbd2cSJim Jagielski     }
98*b1cdbd2cSJim Jagielski }
99