summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--dbaccess/source/ui/dlg/UserAdmin.cxx128
1 files changed, 59 insertions, 69 deletions
diff --git a/dbaccess/source/ui/dlg/UserAdmin.cxx b/dbaccess/source/ui/dlg/UserAdmin.cxx
index fa8c57e88e41..45518471dd0c 100644
--- a/dbaccess/source/ui/dlg/UserAdmin.cxx
+++ b/dbaccess/source/ui/dlg/UserAdmin.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: UserAdmin.cxx,v $
*
- * $Revision: 1.11 $
+ * $Revision: 1.12 $
*
- * last change: $Author: hr $ $Date: 2003-03-19 17:52:19 $
+ * last change: $Author: hr $ $Date: 2004-08-02 15:41:45 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -222,7 +222,6 @@ OUserAdmin::OUserAdmin(Window* pParent,const SfxItemSet& _rAttrSet)
,m_PB_DELETEUSER( this , ResId(PB_DELETEUSER))
,m_FL_TABLE_GRANTS( this , ResId(FL_TABLE_GRANTS))
,m_TableCtrl( this , ResId(CTRL_TABLE_GRANTS))
- ,m_pAdminDialog(NULL)
{
DBG_CTOR(OUserAdmin,NULL);
m_LB_USER.SetSelectHdl(LINK(this, OUserAdmin, ListDblClickHdl));
@@ -237,7 +236,7 @@ OUserAdmin::OUserAdmin(Window* pParent,const SfxItemSet& _rAttrSet)
OUserAdmin::~OUserAdmin()
{
DBG_DTOR(OUserAdmin,NULL);
- ::comphelper::disposeComponent(m_xConnection);
+ m_xConnection = NULL;
}
// -----------------------------------------------------------------------
void OUserAdmin::FillUserNames()
@@ -248,30 +247,33 @@ void OUserAdmin::FillUserNames()
Reference<XDatabaseMetaData> xMetaData = m_xConnection->getMetaData();
- m_UserName = xMetaData->getUserName();
-
- // first we need the users
- if(m_xUsers.is())
+ if ( xMetaData.is() )
{
- m_LB_USER.Clear();
+ m_UserName = xMetaData->getUserName();
- m_aUserNames = m_xUsers->getElementNames();
- const ::rtl::OUString* pBegin = m_aUserNames.getConstArray();
- const ::rtl::OUString* pEnd = pBegin + m_aUserNames.getLength();
- ::rtl::OUString sUserName = m_UserName;
- for(;pBegin != pEnd;++pBegin)
- m_LB_USER.InsertEntry(*pBegin);
-
- m_LB_USER.SelectEntryPos(0);
- if(m_xUsers->hasByName(m_UserName))
+ // first we need the users
+ if ( m_xUsers.is() )
{
- Reference<XAuthorizable> xAuth;
- m_xUsers->getByName(m_UserName) >>= xAuth;
- m_TableCtrl.setGrantUser(xAuth);
- }
+ m_LB_USER.Clear();
- m_TableCtrl.setUserName(GetUser());
- m_TableCtrl.Init();
+ m_aUserNames = m_xUsers->getElementNames();
+ const ::rtl::OUString* pBegin = m_aUserNames.getConstArray();
+ const ::rtl::OUString* pEnd = pBegin + m_aUserNames.getLength();
+ ::rtl::OUString sUserName = m_UserName;
+ for(;pBegin != pEnd;++pBegin)
+ m_LB_USER.InsertEntry(*pBegin);
+
+ m_LB_USER.SelectEntryPos(0);
+ if(m_xUsers->hasByName(m_UserName))
+ {
+ Reference<XAuthorizable> xAuth;
+ m_xUsers->getByName(m_UserName) >>= xAuth;
+ m_TableCtrl.setGrantUser(xAuth);
+ }
+
+ m_TableCtrl.setUserName(GetUser());
+ m_TableCtrl.Init();
+ }
}
}
@@ -290,25 +292,6 @@ SfxTabPage* OUserAdmin::Create( Window* pParent, const SfxItemSet& _rAttrSet )
return ( new OUserAdmin( pParent, _rAttrSet ) );
}
// -----------------------------------------------------------------------
-sal_Bool OUserAdmin::FillItemSet( SfxItemSet& _rSet )
-{
- return sal_True;
-}
-// -----------------------------------------------------------------------
-sal_Int32* OUserAdmin::getDetailIds()
-{
- static sal_Int32* pRelevantIds = NULL;
- if (!pRelevantIds)
- {
- static sal_Int32 nRelevantIds[] =
- {
- 0
- };
- pRelevantIds = nRelevantIds;
- }
- return pRelevantIds;
-}
-// -----------------------------------------------------------------------
IMPL_LINK( OUserAdmin, UserHdl, PushButton *, pButton )
{
try
@@ -367,6 +350,7 @@ IMPL_LINK( OUserAdmin, UserHdl, PushButton *, pButton )
}
}
}
+ FillUserNames();
}
catch(SQLException& e)
{
@@ -378,7 +362,6 @@ IMPL_LINK( OUserAdmin, UserHdl, PushButton *, pButton )
return 0;
}
- FillUserNames();
return 0;
}
// -----------------------------------------------------------------------
@@ -401,45 +384,52 @@ String OUserAdmin::GetUser()
return m_LB_USER.GetSelectEntry();
}
// -----------------------------------------------------------------------------
-void OUserAdmin::ActivatePage( const SfxItemSet& rCoreAttrs )
+int OUserAdmin::DeactivatePage(SfxItemSet* _pSet)
+{
+ int nResult = OGenericAdministrationPage::DeactivatePage(_pSet);
+ ::comphelper::disposeComponent(m_xConnection);
+ return nResult;
+}
+// -----------------------------------------------------------------------------
+void OUserAdmin::fillControls(::std::vector< ISaveValueWrapper* >& _rControlList)
+{
+}
+// -----------------------------------------------------------------------
+void OUserAdmin::fillWindows(::std::vector< ISaveValueWrapper* >& _rControlList)
+{
+}
+// -----------------------------------------------------------------------------
+void OUserAdmin::implInitControls(const SfxItemSet& _rSet, sal_Bool _bSaveValue)
{
- DBG_CHKTHIS( OUserAdmin, NULL );
- OGenericAdministrationPage::ActivatePage(rCoreAttrs);
-
m_TableCtrl.setORB(m_xORB);
-
- if(!m_xConnection.is() && m_pAdminDialog)
+ try
{
- try
+ if ( !m_xConnection.is() && m_pAdminDialog )
{
Reference< XDataDefinitionSupplier > xDriver(m_pAdminDialog->getDriver(),UNO_QUERY);
- if(xDriver.is())
+ if ( xDriver.is() )
{
m_xConnection = m_pAdminDialog->createConnection();
- if(m_xConnection.is())
+ if ( m_xConnection.is() )
{
// now set the tables supplier at the table control
Reference< XTablesSupplier > xTablesSup = xDriver->getDataDefinitionByConnection(m_xConnection);
- m_TableCtrl.setTablesSupplier(xTablesSup);
Reference<XUsersSupplier> xUsersSup(xTablesSup,UNO_QUERY);
- if(xUsersSup.is())
+ if ( xUsersSup.is() )
+ {
+ m_TableCtrl.setTablesSupplier(xTablesSup);
m_xUsers = xUsersSup->getUsers();
+ }
}
}
}
- catch(SQLException& e)
- {
- ::dbaui::showError(::dbtools::SQLExceptionInfo(e),this,m_xORB);
- }
+ FillUserNames();
}
- FillUserNames();
-}
-// -----------------------------------------------------------------------------
-int OUserAdmin::DeactivatePage(SfxItemSet* _pSet)
-{
- int nResult = OGenericAdministrationPage::DeactivatePage(_pSet);
- ::comphelper::disposeComponent(m_xConnection);
- return nResult;
-}
-// -----------------------------------------------------------------------------
+ catch(SQLException& e)
+ {
+ ::dbaui::showError(::dbtools::SQLExceptionInfo(e),this,m_xORB);
+ }
+
+ OGenericAdministrationPage::implInitControls(_rSet, _bSaveValue);
+} \ No newline at end of file