ecf6f6f256
Change-Id: I593eb3c02768423fc8cea8d93c112655860228d9 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/167258 Tested-by: Jenkins Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
228 lines
7.8 KiB
C++
228 lines
7.8 KiB
C++
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
/*
|
|
* This file is part of the LibreOffice project.
|
|
*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
*
|
|
* This file incorporates work covered by the following license notice:
|
|
*
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
* contributor license agreements. See the NOTICE file distributed
|
|
* with this work for additional information regarding copyright
|
|
* ownership. The ASF licenses this file to you under the Apache
|
|
* License, Version 2.0 (the "License"); you may not use this file
|
|
* except in compliance with the License. You may obtain a copy of
|
|
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
|
|
*/
|
|
|
|
#include <o3tl/safeint.hxx>
|
|
#include "webconninfo.hxx"
|
|
#include <com/sun/star/task/InteractionHandler.hpp>
|
|
#include <com/sun/star/task/PasswordContainer.hpp>
|
|
#include <com/sun/star/task/UrlRecord.hpp>
|
|
#include <com/sun/star/task/XPasswordContainer2.hpp>
|
|
#include <comphelper/processfactory.hxx>
|
|
#include <comphelper/docpasswordrequest.hxx>
|
|
|
|
using namespace ::com::sun::star;
|
|
|
|
|
|
namespace svx
|
|
{
|
|
|
|
// class WebConnectionInfoDialog -----------------------------------------
|
|
|
|
WebConnectionInfoDialog::WebConnectionInfoDialog(weld::Window* pParent)
|
|
: GenericDialogController(pParent, u"cui/ui/storedwebconnectiondialog.ui"_ustr, u"StoredWebConnectionDialog"_ustr)
|
|
, m_nPos( -1 )
|
|
, m_xRemoveBtn(m_xBuilder->weld_button(u"remove"_ustr))
|
|
, m_xRemoveAllBtn(m_xBuilder->weld_button(u"removeall"_ustr))
|
|
, m_xChangeBtn(m_xBuilder->weld_button(u"change"_ustr))
|
|
, m_xPasswordsLB(m_xBuilder->weld_tree_view(u"logins"_ustr))
|
|
{
|
|
std::vector<int> aWidths
|
|
{
|
|
o3tl::narrowing<int>(m_xPasswordsLB->get_approximate_digit_width() * 50)
|
|
};
|
|
m_xPasswordsLB->set_column_fixed_widths(aWidths);
|
|
m_xPasswordsLB->set_size_request(m_xPasswordsLB->get_approximate_digit_width() * 70,
|
|
m_xPasswordsLB->get_height_rows(8));
|
|
|
|
m_xPasswordsLB->connect_column_clicked(LINK(this, WebConnectionInfoDialog, HeaderBarClickedHdl));
|
|
|
|
FillPasswordList();
|
|
|
|
m_xRemoveBtn->connect_clicked( LINK( this, WebConnectionInfoDialog, RemovePasswordHdl ) );
|
|
m_xRemoveAllBtn->connect_clicked( LINK( this, WebConnectionInfoDialog, RemoveAllPasswordsHdl ) );
|
|
m_xChangeBtn->connect_clicked( LINK( this, WebConnectionInfoDialog, ChangePasswordHdl ) );
|
|
m_xPasswordsLB->connect_changed( LINK( this, WebConnectionInfoDialog, EntrySelectedHdl ) );
|
|
|
|
m_xRemoveBtn->set_sensitive( false );
|
|
m_xChangeBtn->set_sensitive( false );
|
|
|
|
m_xPasswordsLB->make_sorted();
|
|
}
|
|
|
|
WebConnectionInfoDialog::~WebConnectionInfoDialog()
|
|
{
|
|
}
|
|
|
|
IMPL_LINK(WebConnectionInfoDialog, HeaderBarClickedHdl, int, nColumn, void)
|
|
{
|
|
if (nColumn == 0) // only the first column is sorted
|
|
{
|
|
m_xPasswordsLB->set_sort_order(!m_xPasswordsLB->get_sort_order());
|
|
}
|
|
}
|
|
|
|
void WebConnectionInfoDialog::FillPasswordList()
|
|
{
|
|
try
|
|
{
|
|
uno::Reference< task::XPasswordContainer2 > xMasterPasswd(
|
|
task::PasswordContainer::create(comphelper::getProcessComponentContext()));
|
|
|
|
if ( xMasterPasswd->isPersistentStoringAllowed() )
|
|
{
|
|
uno::Reference< task::XInteractionHandler > xInteractionHandler =
|
|
task::InteractionHandler::createWithParent(comphelper::getProcessComponentContext(), nullptr);
|
|
|
|
const uno::Sequence< task::UrlRecord > aURLEntries = xMasterPasswd->getAllPersistent( xInteractionHandler );
|
|
sal_Int32 nCount = 0;
|
|
for ( task::UrlRecord const & urlEntry : aURLEntries )
|
|
{
|
|
for ( auto const & user : urlEntry.UserList )
|
|
{
|
|
m_xPasswordsLB->append(OUString::number(nCount), urlEntry.Url);
|
|
m_xPasswordsLB->set_text(nCount, user.UserName, 1);
|
|
++nCount;
|
|
}
|
|
}
|
|
|
|
// remember pos of first url container entry.
|
|
m_nPos = nCount;
|
|
|
|
const uno::Sequence< OUString > aUrls
|
|
= xMasterPasswd->getUrls( true /* OnlyPersistent */ );
|
|
|
|
for ( OUString const & url : aUrls )
|
|
{
|
|
m_xPasswordsLB->append(OUString::number(nCount), url);
|
|
m_xPasswordsLB->set_text(nCount, u"*"_ustr);
|
|
++nCount;
|
|
}
|
|
}
|
|
}
|
|
catch( uno::Exception& )
|
|
{}
|
|
}
|
|
|
|
|
|
IMPL_LINK_NOARG(WebConnectionInfoDialog, RemovePasswordHdl, weld::Button&, void)
|
|
{
|
|
try
|
|
{
|
|
int nEntry = m_xPasswordsLB->get_selected_index();
|
|
if (nEntry != -1)
|
|
{
|
|
OUString aURL = m_xPasswordsLB->get_text(nEntry, 0);
|
|
OUString aUserName = m_xPasswordsLB->get_text(nEntry, 1);
|
|
|
|
uno::Reference< task::XPasswordContainer2 > xPasswdContainer(
|
|
task::PasswordContainer::create(comphelper::getProcessComponentContext()));
|
|
|
|
int nPos = m_xPasswordsLB->get_id(nEntry).toInt32();
|
|
if ( nPos < m_nPos )
|
|
{
|
|
xPasswdContainer->removePersistent( aURL, aUserName );
|
|
}
|
|
else
|
|
{
|
|
xPasswdContainer->removeUrl( aURL );
|
|
}
|
|
|
|
m_xPasswordsLB->remove(nEntry);
|
|
}
|
|
}
|
|
catch( uno::Exception& )
|
|
{}
|
|
}
|
|
|
|
IMPL_LINK_NOARG(WebConnectionInfoDialog, RemoveAllPasswordsHdl, weld::Button&, void)
|
|
{
|
|
try
|
|
{
|
|
uno::Reference< task::XPasswordContainer2 > xPasswdContainer(
|
|
task::PasswordContainer::create(comphelper::getProcessComponentContext()));
|
|
|
|
// should the master password be requested before?
|
|
xPasswdContainer->removeAllPersistent();
|
|
|
|
const uno::Sequence< OUString > aUrls
|
|
= xPasswdContainer->getUrls( true /* OnlyPersistent */ );
|
|
for ( OUString const & url : aUrls )
|
|
xPasswdContainer->removeUrl( url );
|
|
|
|
m_xPasswordsLB->clear();
|
|
}
|
|
catch( uno::Exception& )
|
|
{}
|
|
}
|
|
|
|
IMPL_LINK_NOARG(WebConnectionInfoDialog, ChangePasswordHdl, weld::Button&, void)
|
|
{
|
|
try
|
|
{
|
|
int nEntry = m_xPasswordsLB->get_selected_index();
|
|
if (nEntry != -1)
|
|
{
|
|
OUString aURL = m_xPasswordsLB->get_text(nEntry, 0);
|
|
OUString aUserName = m_xPasswordsLB->get_text(nEntry, 1);
|
|
|
|
rtl::Reference<::comphelper::SimplePasswordRequest> pPasswordRequest
|
|
= new ::comphelper::SimplePasswordRequest;
|
|
|
|
uno::Reference< task::XInteractionHandler > xInteractionHandler =
|
|
task::InteractionHandler::createWithParent(comphelper::getProcessComponentContext(), m_xDialog->GetXWindow());
|
|
xInteractionHandler->handle( pPasswordRequest );
|
|
|
|
if ( pPasswordRequest->isPassword() )
|
|
{
|
|
uno::Sequence<OUString> aPasswd { pPasswordRequest->getPassword() };
|
|
|
|
uno::Reference< task::XPasswordContainer2 > xPasswdContainer(
|
|
task::PasswordContainer::create(comphelper::getProcessComponentContext()));
|
|
xPasswdContainer->addPersistent(
|
|
aURL, aUserName, aPasswd, xInteractionHandler );
|
|
}
|
|
}
|
|
}
|
|
catch( uno::Exception& )
|
|
{}
|
|
}
|
|
|
|
|
|
IMPL_LINK_NOARG(WebConnectionInfoDialog, EntrySelectedHdl, weld::TreeView&, void)
|
|
{
|
|
int nEntry = m_xPasswordsLB->get_selected_index();
|
|
if (nEntry == -1)
|
|
{
|
|
m_xRemoveBtn->set_sensitive(false);
|
|
m_xChangeBtn->set_sensitive(false);
|
|
}
|
|
else
|
|
{
|
|
m_xRemoveBtn->set_sensitive(true);
|
|
|
|
// url container entries (-> use system credentials) have
|
|
// no password
|
|
int nPos = m_xPasswordsLB->get_id(nEntry).toInt32();
|
|
m_xChangeBtn->set_sensitive(nPos < m_nPos);
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|