Branch data Line data Source code
1 : : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 : : /*
3 : : * This file is part of the LibreOffice project.
4 : : *
5 : : * This Source Code Form is subject to the terms of the Mozilla Public
6 : : * License, v. 2.0. If a copy of the MPL was not distributed with this
7 : : * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8 : : *
9 : : * This file incorporates work covered by the following license notice:
10 : : *
11 : : * Licensed to the Apache Software Foundation (ASF) under one or more
12 : : * contributor license agreements. See the NOTICE file distributed
13 : : * with this work for additional information regarding copyright
14 : : * ownership. The ASF licenses this file to you under the Apache
15 : : * License, Version 2.0 (the "License"); you may not use this file
16 : : * except in compliance with the License. You may obtain a copy of
17 : : * the License at http://www.apache.org/licenses/LICENSE-2.0 .
18 : : */
19 : :
20 : : #include "mysql/YCatalog.hxx"
21 : : #include "mysql/YUsers.hxx"
22 : : #include "mysql/YTables.hxx"
23 : : #include "mysql/YViews.hxx"
24 : : #include <com/sun/star/sdbc/XRow.hpp>
25 : : #include <com/sun/star/sdbc/XResultSet.hpp>
26 : : #include <comphelper/types.hxx>
27 : :
28 : :
29 : : // -------------------------------------------------------------------------
30 : : using namespace connectivity;
31 : : using namespace connectivity::mysql;
32 : : using namespace connectivity::sdbcx;
33 : : using namespace ::com::sun::star::uno;
34 : : using namespace ::com::sun::star::beans;
35 : : using namespace ::com::sun::star::sdbcx;
36 : : using namespace ::com::sun::star::sdbc;
37 : : using namespace ::com::sun::star::container;
38 : : using namespace ::com::sun::star::lang;
39 : : // -------------------------------------------------------------------------
40 : 0 : OMySQLCatalog::OMySQLCatalog(const Reference< XConnection >& _xConnection) : OCatalog(_xConnection)
41 : 0 : ,m_xConnection(_xConnection)
42 : : {
43 : 0 : }
44 : : // -----------------------------------------------------------------------------
45 : 0 : void OMySQLCatalog::refreshObjects(const Sequence< ::rtl::OUString >& _sKindOfObject,TStringVector& _rNames)
46 : : {
47 : 0 : Reference< XResultSet > xResult = m_xMetaData->getTables(Any(),
48 : : ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("%")),
49 : : ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("%")),
50 : 0 : _sKindOfObject);
51 : 0 : fillNames(xResult,_rNames);
52 : 0 : }
53 : : // -------------------------------------------------------------------------
54 : 0 : void OMySQLCatalog::refreshTables()
55 : : {
56 : 0 : TStringVector aVector;
57 : 0 : static const ::rtl::OUString s_sTableTypeView(RTL_CONSTASCII_USTRINGPARAM("VIEW"));
58 : 0 : static const ::rtl::OUString s_sTableTypeTable(RTL_CONSTASCII_USTRINGPARAM("TABLE"));
59 : 0 : static const ::rtl::OUString s_sAll(RTL_CONSTASCII_USTRINGPARAM("%"));
60 : :
61 : 0 : Sequence< ::rtl::OUString > sTableTypes(3);
62 : 0 : sTableTypes[0] = s_sTableTypeView;
63 : 0 : sTableTypes[1] = s_sTableTypeTable;
64 : 0 : sTableTypes[2] = s_sAll; // just to be sure to include anything else ....
65 : :
66 : 0 : refreshObjects(sTableTypes,aVector);
67 : :
68 : 0 : if ( m_pTables )
69 : 0 : m_pTables->reFill(aVector);
70 : : else
71 : 0 : m_pTables = new OTables(m_xMetaData,*this,m_aMutex,aVector);
72 : 0 : }
73 : : // -------------------------------------------------------------------------
74 : 0 : void OMySQLCatalog::refreshViews()
75 : : {
76 : 0 : Sequence< ::rtl::OUString > aTypes(1);
77 : 0 : aTypes[0] = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("VIEW"));
78 : :
79 : : // let's simply assume the server is new enough to support views. Current drivers
80 : : // as of this writing might not return the proper information in getTableTypes, so
81 : : // don't rely on it.
82 : : // during #73245# / 2007-10-26 / frank.schoenheit@sun.com
83 : 0 : bool bSupportsViews = sal_True;
84 : :
85 : 0 : TStringVector aVector;
86 : 0 : if ( bSupportsViews )
87 : 0 : refreshObjects(aTypes,aVector);
88 : :
89 : 0 : if ( m_pViews )
90 : 0 : m_pViews->reFill(aVector);
91 : : else
92 : 0 : m_pViews = new OViews(m_xMetaData,*this,m_aMutex,aVector);
93 : 0 : }
94 : : // -------------------------------------------------------------------------
95 : 0 : void OMySQLCatalog::refreshGroups()
96 : : {
97 : 0 : }
98 : : // -------------------------------------------------------------------------
99 : 0 : void OMySQLCatalog::refreshUsers()
100 : : {
101 : 0 : TStringVector aVector;
102 : 0 : Reference< XStatement > xStmt = m_xConnection->createStatement( );
103 : 0 : Reference< XResultSet > xResult = xStmt->executeQuery(::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("select User from mysql.user group by User")));
104 : 0 : if ( xResult.is() )
105 : : {
106 : 0 : Reference< XRow > xRow(xResult,UNO_QUERY);
107 : 0 : TString2IntMap aMap;
108 : 0 : while( xResult->next() )
109 : 0 : aVector.push_back(xRow->getString(1));
110 : 0 : ::comphelper::disposeComponent(xResult);
111 : : }
112 : 0 : ::comphelper::disposeComponent(xStmt);
113 : :
114 : 0 : if(m_pUsers)
115 : 0 : m_pUsers->reFill(aVector);
116 : : else
117 : 0 : m_pUsers = new OUsers(*this,m_aMutex,aVector,m_xConnection,this);
118 : 0 : }
119 : : // -----------------------------------------------------------------------------
120 : 0 : Any SAL_CALL OMySQLCatalog::queryInterface( const Type & rType ) throw(RuntimeException)
121 : : {
122 : 0 : if ( rType == ::getCppuType((const Reference<XGroupsSupplier>*)0) )
123 : 0 : return Any();
124 : :
125 : :
126 : 0 : return OCatalog::queryInterface(rType);
127 : : }
128 : : // -----------------------------------------------------------------------------
129 : 0 : Sequence< Type > SAL_CALL OMySQLCatalog::getTypes( ) throw(RuntimeException)
130 : : {
131 : 0 : Sequence< Type > aTypes = OCatalog::getTypes();
132 : 0 : ::std::vector<Type> aOwnTypes;
133 : 0 : aOwnTypes.reserve(aTypes.getLength());
134 : 0 : const Type* pBegin = aTypes.getConstArray();
135 : 0 : const Type* pEnd = pBegin + aTypes.getLength();
136 : 0 : for(;pBegin != pEnd;++pBegin)
137 : : {
138 : 0 : if ( !(*pBegin == ::getCppuType((const Reference<XGroupsSupplier>*)0)))
139 : : {
140 : 0 : aOwnTypes.push_back(*pBegin);
141 : : }
142 : : }
143 : 0 : const Type* pTypes = aOwnTypes.empty() ? 0 : &aOwnTypes[0];
144 : 0 : return Sequence< Type >(pTypes, aOwnTypes.size());
145 : : }
146 : : // -----------------------------------------------------------------------------
147 : :
148 : :
149 : : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|