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 // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_connectivity.hxx"
26*b1cdbd2cSJim Jagielski #include "adabas/BCatalog.hxx"
27*b1cdbd2cSJim Jagielski #include "adabas/BConnection.hxx"
28*b1cdbd2cSJim Jagielski #include "adabas/BGroups.hxx"
29*b1cdbd2cSJim Jagielski #include "adabas/BUsers.hxx"
30*b1cdbd2cSJim Jagielski #include "adabas/BTables.hxx"
31*b1cdbd2cSJim Jagielski #include "adabas/BViews.hxx"
32*b1cdbd2cSJim Jagielski #include <com/sun/star/sdbc/XRow.hpp>
33*b1cdbd2cSJim Jagielski #include <com/sun/star/sdbc/XResultSet.hpp>
34*b1cdbd2cSJim Jagielski #include <comphelper/types.hxx>
35*b1cdbd2cSJim Jagielski 
36*b1cdbd2cSJim Jagielski 
37*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
38*b1cdbd2cSJim Jagielski using namespace connectivity;
39*b1cdbd2cSJim Jagielski using namespace connectivity::adabas;
40*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::uno;
41*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::beans;
42*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::sdbcx;
43*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::sdbc;
44*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::container;
45*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::lang;
46*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------------
OAdabasCatalog(SQLHANDLE _aConnectionHdl,OAdabasConnection * _pCon)47*b1cdbd2cSJim Jagielski OAdabasCatalog::OAdabasCatalog(SQLHANDLE _aConnectionHdl, OAdabasConnection* _pCon) : connectivity::sdbcx::OCatalog(_pCon)
48*b1cdbd2cSJim Jagielski 				,m_pConnection(_pCon)
49*b1cdbd2cSJim Jagielski 				,m_aConnectionHdl(_aConnectionHdl)
50*b1cdbd2cSJim Jagielski {
51*b1cdbd2cSJim Jagielski }
52*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------------
buildName(const Reference<XRow> & _xRow)53*b1cdbd2cSJim Jagielski ::rtl::OUString OAdabasCatalog::buildName(const Reference< XRow >& _xRow)
54*b1cdbd2cSJim Jagielski {
55*b1cdbd2cSJim Jagielski 	::rtl::OUString sName;
56*b1cdbd2cSJim Jagielski 	sName = _xRow->getString(2);
57*b1cdbd2cSJim Jagielski     if ( sName.getLength() )
58*b1cdbd2cSJim Jagielski         sName += OAdabasCatalog::getDot();
59*b1cdbd2cSJim Jagielski 	sName += _xRow->getString(3);
60*b1cdbd2cSJim Jagielski 
61*b1cdbd2cSJim Jagielski 
62*b1cdbd2cSJim Jagielski 	return sName;
63*b1cdbd2cSJim Jagielski }
64*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------------
fillVector(const::rtl::OUString & _sQuery,TStringVector & _rVector)65*b1cdbd2cSJim Jagielski void OAdabasCatalog::fillVector(const ::rtl::OUString& _sQuery,TStringVector& _rVector)
66*b1cdbd2cSJim Jagielski {
67*b1cdbd2cSJim Jagielski     Reference< XStatement > xStmt = m_pConnection->createStatement(  );
68*b1cdbd2cSJim Jagielski     OSL_ENSURE(xStmt.is(),"OAdabasCatalog::fillVector: Could not create a statement!");
69*b1cdbd2cSJim Jagielski 	Reference< XResultSet > xResult = xStmt->executeQuery(_sQuery);
70*b1cdbd2cSJim Jagielski 
71*b1cdbd2cSJim Jagielski 	fillNames(xResult,_rVector);
72*b1cdbd2cSJim Jagielski 	::comphelper::disposeComponent(xStmt);
73*b1cdbd2cSJim Jagielski 
74*b1cdbd2cSJim Jagielski }
75*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
refreshTables()76*b1cdbd2cSJim Jagielski void OAdabasCatalog::refreshTables()
77*b1cdbd2cSJim Jagielski {
78*b1cdbd2cSJim Jagielski 	TStringVector aVector;
79*b1cdbd2cSJim Jagielski 	{
80*b1cdbd2cSJim Jagielski 		Sequence< ::rtl::OUString > aTypes(1);
81*b1cdbd2cSJim Jagielski 		aTypes[0] = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("%"));
82*b1cdbd2cSJim Jagielski 		Reference< XResultSet > xResult = m_xMetaData->getTables(Any(),
83*b1cdbd2cSJim Jagielski 																::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("%")),
84*b1cdbd2cSJim Jagielski 																::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("%")),
85*b1cdbd2cSJim Jagielski 																aTypes);
86*b1cdbd2cSJim Jagielski 		fillNames(xResult,aVector);
87*b1cdbd2cSJim Jagielski 	}
88*b1cdbd2cSJim Jagielski 
89*b1cdbd2cSJim Jagielski 	if(m_pTables)
90*b1cdbd2cSJim Jagielski 		m_pTables->reFill(aVector);
91*b1cdbd2cSJim Jagielski 	else
92*b1cdbd2cSJim Jagielski 		m_pTables = new OTables(m_xMetaData,*this,m_aMutex,aVector);
93*b1cdbd2cSJim Jagielski }
94*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
refreshViews()95*b1cdbd2cSJim Jagielski void OAdabasCatalog::refreshViews()
96*b1cdbd2cSJim Jagielski {
97*b1cdbd2cSJim Jagielski 	TStringVector aVector;
98*b1cdbd2cSJim Jagielski     static const ::rtl::OUString s_sView(RTL_CONSTASCII_USTRINGPARAM("SELECT DISTINCT NULL,DOMAIN.VIEWDEFS.OWNER, DOMAIN.VIEWDEFS.VIEWNAME FROM DOMAIN.VIEWDEFS"));
99*b1cdbd2cSJim Jagielski 	fillVector(s_sView,aVector);
100*b1cdbd2cSJim Jagielski 
101*b1cdbd2cSJim Jagielski 	if(m_pViews)
102*b1cdbd2cSJim Jagielski 		m_pViews->reFill(aVector);
103*b1cdbd2cSJim Jagielski 	else
104*b1cdbd2cSJim Jagielski 		m_pViews = new OViews(m_xMetaData,*this,m_aMutex,aVector);
105*b1cdbd2cSJim Jagielski }
106*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
refreshGroups()107*b1cdbd2cSJim Jagielski void OAdabasCatalog::refreshGroups()
108*b1cdbd2cSJim Jagielski {
109*b1cdbd2cSJim Jagielski 	TStringVector aVector;
110*b1cdbd2cSJim Jagielski     static const ::rtl::OUString s_sGroup(RTL_CONSTASCII_USTRINGPARAM("SELECT DISTINCT NULL,NULL,GROUPNAME FROM DOMAIN.USERS WHERE GROUPNAME IS NOT NULL AND GROUPNAME <> ' '"));
111*b1cdbd2cSJim Jagielski     fillVector(s_sGroup,aVector);
112*b1cdbd2cSJim Jagielski 	if(m_pGroups)
113*b1cdbd2cSJim Jagielski 		m_pGroups->reFill(aVector);
114*b1cdbd2cSJim Jagielski 	else
115*b1cdbd2cSJim Jagielski 		m_pGroups = new OGroups(*this,m_aMutex,aVector,m_pConnection,this);
116*b1cdbd2cSJim Jagielski }
117*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
refreshUsers()118*b1cdbd2cSJim Jagielski void OAdabasCatalog::refreshUsers()
119*b1cdbd2cSJim Jagielski {
120*b1cdbd2cSJim Jagielski 	TStringVector aVector;
121*b1cdbd2cSJim Jagielski     static const ::rtl::OUString s_sUsers(RTL_CONSTASCII_USTRINGPARAM("SELECT DISTINCT NULL,NULL,USERNAME FROM DOMAIN.USERS WHERE USERNAME IS NOT NULL AND USERNAME <> ' ' AND USERNAME <> 'CONTROL'"));
122*b1cdbd2cSJim Jagielski     fillVector(s_sUsers,aVector);
123*b1cdbd2cSJim Jagielski 
124*b1cdbd2cSJim Jagielski 	if(m_pUsers)
125*b1cdbd2cSJim Jagielski 		m_pUsers->reFill(aVector);
126*b1cdbd2cSJim Jagielski 	else
127*b1cdbd2cSJim Jagielski 		m_pUsers = new OUsers(*this,m_aMutex,aVector,m_pConnection,this);
128*b1cdbd2cSJim Jagielski }
129*b1cdbd2cSJim Jagielski // -------------------------------------------------------------------------
getDot()130*b1cdbd2cSJim Jagielski const ::rtl::OUString& OAdabasCatalog::getDot()
131*b1cdbd2cSJim Jagielski {
132*b1cdbd2cSJim Jagielski 	static const ::rtl::OUString sDot(RTL_CONSTASCII_USTRINGPARAM("."));
133*b1cdbd2cSJim Jagielski 	return sDot;
134*b1cdbd2cSJim Jagielski }
135*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------------
correctColumnProperties(sal_Int32,sal_Int32 & _rnType,::rtl::OUString & _rsTypeName)136*b1cdbd2cSJim Jagielski void OAdabasCatalog::correctColumnProperties(sal_Int32 /*_nPrec*/, sal_Int32& _rnType,::rtl::OUString& _rsTypeName)
137*b1cdbd2cSJim Jagielski {
138*b1cdbd2cSJim Jagielski 	switch(_rnType)
139*b1cdbd2cSJim Jagielski 	{
140*b1cdbd2cSJim Jagielski 	case DataType::DECIMAL:
141*b1cdbd2cSJim Jagielski 		{
142*b1cdbd2cSJim Jagielski             static const ::rtl::OUString sDecimal(RTL_CONSTASCII_USTRINGPARAM("DECIMAL"));
143*b1cdbd2cSJim Jagielski 			if(_rnType == DataType::DECIMAL && _rsTypeName == sDecimal)
144*b1cdbd2cSJim Jagielski 				_rnType = DataType::NUMERIC;
145*b1cdbd2cSJim Jagielski 		}
146*b1cdbd2cSJim Jagielski 		break;
147*b1cdbd2cSJim Jagielski 	case DataType::FLOAT:
148*b1cdbd2cSJim Jagielski 		//	if(_nPrec >= 16)
149*b1cdbd2cSJim Jagielski 		{
150*b1cdbd2cSJim Jagielski 			static const ::rtl::OUString sDouble(RTL_CONSTASCII_USTRINGPARAM("DOUBLE PRECISION"));
151*b1cdbd2cSJim Jagielski 			_rsTypeName = sDouble;
152*b1cdbd2cSJim Jagielski 			_rnType = DataType::DOUBLE;
153*b1cdbd2cSJim Jagielski 		}
154*b1cdbd2cSJim Jagielski //		else if(_nPrec > 15)
155*b1cdbd2cSJim Jagielski //		{
156*b1cdbd2cSJim Jagielski //			static const ::rtl::OUString sReal = ::rtl::OUString::createFromAscii("REAL");
157*b1cdbd2cSJim Jagielski //			_rsTypeName = sReal;
158*b1cdbd2cSJim Jagielski //			_rnType = DataType::REAL;
159*b1cdbd2cSJim Jagielski //		}
160*b1cdbd2cSJim Jagielski 		break;
161*b1cdbd2cSJim Jagielski 	}
162*b1cdbd2cSJim Jagielski }
163*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------------
164*b1cdbd2cSJim Jagielski 
165