diff options
-rw-r--r-- | include/sfx2/docfile.hxx | 8 | ||||
-rw-r--r-- | sfx2/source/doc/docfile.cxx | 7 | ||||
-rw-r--r-- | sfx2/source/doc/objserv.cxx | 6 | ||||
-rw-r--r-- | xmlsecurity/inc/bitmaps.hlst | 4 | ||||
-rw-r--r-- | xmlsecurity/inc/digitalsignaturesdialog.hxx | 73 | ||||
-rw-r--r-- | xmlsecurity/source/component/documentdigitalsignatures.cxx | 14 | ||||
-rw-r--r-- | xmlsecurity/source/dialogs/digitalsignaturesdialog.cxx | 225 | ||||
-rw-r--r-- | xmlsecurity/uiconfig/ui/digitalsignaturesdialog.ui | 138 | ||||
-rw-r--r-- | xmlsecurity/uiconfig/ui/selectcertificatedialog.ui | 1 |
9 files changed, 283 insertions, 193 deletions
diff --git a/include/sfx2/docfile.hxx b/include/sfx2/docfile.hxx index 8019c8a676d2..64c18b05dcf8 100644 --- a/include/sfx2/docfile.hxx +++ b/include/sfx2/docfile.hxx @@ -58,6 +58,11 @@ class SfxFrame; class Timer; class DateTime; +namespace weld +{ + class Window; +} + class SFX2_DLLPUBLIC SfxMedium : public SvRefBase { std::unique_ptr< SfxMedium_Impl > pImpl; @@ -263,7 +268,8 @@ public: const css::uno::Reference< css::ucb::XCommandEnvironment >& xComEnv ); SAL_DLLPRIVATE bool - SignContents_Impl(bool bSignScriptingContent, bool bHasValidDocumentSignature, + SignContents_Impl(weld::Window* pDialogParent, + bool bSignScriptingContent, bool bHasValidDocumentSignature, const OUString& aSignatureLineId = OUString(), const css::uno::Reference<css::security::XCertificate>& xCert = css::uno::Reference<css::security::XCertificate>(), diff --git a/sfx2/source/doc/docfile.cxx b/sfx2/source/doc/docfile.cxx index ef0f6e2d8943..6efbb67e4270 100644 --- a/sfx2/source/doc/docfile.cxx +++ b/sfx2/source/doc/docfile.cxx @@ -129,6 +129,7 @@ #include <openflag.hxx> #include <officecfg/Office/Common.hxx> #include <comphelper/propertysequence.hxx> +#include <vcl/weld.hxx> #include <com/sun/star/io/WrongFormatException.hpp> @@ -3888,7 +3889,9 @@ bool SfxMedium::SignDocumentContentUsingCertificate(bool bHasValidDocumentSignat return bChanges; } -bool SfxMedium::SignContents_Impl(bool bSignScriptingContent, bool bHasValidDocumentSignature, +bool SfxMedium::SignContents_Impl(weld::Window* pDialogParent, + bool bSignScriptingContent, + bool bHasValidDocumentSignature, const OUString& aSignatureLineId, const Reference<XCertificate>& xCert, const Reference<XGraphic>& xValidGraphic, @@ -3909,6 +3912,8 @@ bool SfxMedium::SignContents_Impl(bool bSignScriptingContent, bool bHasValidDocu uno::Reference< security::XDocumentDigitalSignatures > xSigner( security::DocumentDigitalSignatures::createWithVersionAndValidSignature( comphelper::getProcessComponentContext(), aODFVersion, bHasValidDocumentSignature ) ); + if (pDialogParent) + xSigner->setParentWindow(pDialogParent->GetXWindow()); uno::Reference< embed::XStorage > xWriteableZipStor; diff --git a/sfx2/source/doc/objserv.cxx b/sfx2/source/doc/objserv.cxx index f18ddcc5d0bb..41412c832fea 100644 --- a/sfx2/source/doc/objserv.cxx +++ b/sfx2/source/doc/objserv.cxx @@ -1740,7 +1740,7 @@ void SfxObjectShell::SignDocumentContent(weld::Window* pDialogParent) if (CheckIsReadonly(false)) return; - bool bSignSuccess = GetMedium()->SignContents_Impl(false, HasValidSignatures()); + bool bSignSuccess = GetMedium()->SignContents_Impl(pDialogParent, false, HasValidSignatures()); AfterSigning(bSignSuccess, false); } @@ -1836,7 +1836,7 @@ void SfxObjectShell::SignSignatureLine(weld::Window* pDialogParent, if (CheckIsReadonly(false)) return; - bool bSignSuccess = GetMedium()->SignContents_Impl( + bool bSignSuccess = GetMedium()->SignContents_Impl(pDialogParent, false, HasValidSignatures(), aSignatureLineId, xCert, xValidGraphic, xInvalidGraphic, aComment); AfterSigning(bSignSuccess, false); @@ -1861,7 +1861,7 @@ void SfxObjectShell::SignScriptingContent(weld::Window* pDialogParent) if (CheckIsReadonly(true)) return; - bool bSignSuccess = GetMedium()->SignContents_Impl(true, HasValidSignatures()); + bool bSignSuccess = GetMedium()->SignContents_Impl(pDialogParent, true, HasValidSignatures()); AfterSigning(bSignSuccess, true); } diff --git a/xmlsecurity/inc/bitmaps.hlst b/xmlsecurity/inc/bitmaps.hlst index 1af4ff3c6234..52a9df754e48 100644 --- a/xmlsecurity/inc/bitmaps.hlst +++ b/xmlsecurity/inc/bitmaps.hlst @@ -15,6 +15,10 @@ #define BMP_CERT_OK "xmlsecurity/res/certificate_16.png" #define BMP_CERT_NOT_OK "xmlsecurity/res/notcertificate_16.png" +#define BMP_SIG_VALID "xmlsecurity/res/signet_11x16.png" +#define BMP_SIG_INVALID "svx/res/caution_11x16.png" +#define BMP_SIG_NOT_VALIDATED "xmlsecurity/res/notcertificate_16.png" + #endif /* vim:set shiftwidth=4 softtabstop=4 expandtab cinoptions=b1,g0,N-s cinkeys+=0=break: */ diff --git a/xmlsecurity/inc/digitalsignaturesdialog.hxx b/xmlsecurity/inc/digitalsignaturesdialog.hxx index 41cc458a7380..6fd74ad70964 100644 --- a/xmlsecurity/inc/digitalsignaturesdialog.hxx +++ b/xmlsecurity/inc/digitalsignaturesdialog.hxx @@ -20,10 +20,7 @@ #ifndef INCLUDED_XMLSECURITY_INC_DIGITALSIGNATURESDIALOG_HXX #define INCLUDED_XMLSECURITY_INC_DIGITALSIGNATURESDIALOG_HXX -#include <vcl/dialog.hxx> -#include <vcl/fixed.hxx> -#include <vcl/button.hxx> -#include <svtools/simptabl.hxx> +#include <vcl/weld.hxx> #include <com/sun/star/beans/PropertyValue.hpp> #include "documentsignaturehelper.hxx" @@ -48,7 +45,7 @@ namespace xml { namespace dom { class HeaderBar; -class DigitalSignaturesDialog : public ModalDialog +class DigitalSignaturesDialog : public weld::GenericDialogController { private: css::uno::Reference< css::uno::XComponentContext >& mxCtx; @@ -57,28 +54,6 @@ private: bool mbVerifySignatures; bool mbSignaturesChanged; - VclPtr<FixedText> m_pHintDocFT; - VclPtr<FixedText> m_pHintBasicFT; - VclPtr<FixedText> m_pHintPackageFT; - VclPtr<SvSimpleTable> m_pSignaturesLB; - VclPtr<FixedImage> m_pSigsValidImg; - VclPtr<FixedText> m_pSigsValidFI; - VclPtr<FixedImage> m_pSigsInvalidImg; - VclPtr<FixedText> m_pSigsInvalidFI; - VclPtr<FixedImage> m_pSigsNotvalidatedImg; - VclPtr<FixedText> m_pSigsNotvalidatedFI; - VclPtr<FixedImage> m_pSigsOldSignatureImg; - VclPtr<FixedText> m_pSigsOldSignatureFI; - - VclPtr<CheckBox> m_pAdESCompliantCB; - - VclPtr<PushButton> m_pViewBtn; - VclPtr<PushButton> m_pAddBtn; - VclPtr<PushButton> m_pRemoveBtn; - VclPtr<PushButton> m_pStartCertMgrBtn; - - VclPtr<CloseButton> m_pCloseBtn; - OUString const m_sODFVersion; //Signals if the document contains already a document signature. This is only //important when we are signing macros and if the value is true. @@ -87,15 +62,34 @@ private: bool m_bAdESCompliant; - DECL_LINK(AdESCompliantCheckBoxHdl, CheckBox&, void); - DECL_LINK(ViewButtonHdl, Button*, void); - DECL_LINK(AddButtonHdl, Button*, void); - DECL_LINK(RemoveButtonHdl, Button*, void); - DECL_LINK(SignatureHighlightHdl, SvTreeListBox*, void ); - DECL_LINK(SignatureSelectHdl, SvTreeListBox*, bool ); - DECL_LINK(StartVerifySignatureHdl, LinkParamNone*, bool ); - DECL_LINK(OKButtonHdl, Button*, void ); - DECL_STATIC_LINK(DigitalSignaturesDialog, CertMgrButtonHdl, Button*, void ); + std::unique_ptr<weld::Label> m_xHintDocFT; + std::unique_ptr<weld::Label> m_xHintBasicFT; + std::unique_ptr<weld::Label> m_xHintPackageFT; + std::unique_ptr<weld::TreeView> m_xSignaturesLB; + std::unique_ptr<weld::Image> m_xSigsValidImg; + std::unique_ptr<weld::Label> m_xSigsValidFI; + std::unique_ptr<weld::Image> m_xSigsInvalidImg; + std::unique_ptr<weld::Label> m_xSigsInvalidFI; + std::unique_ptr<weld::Image> m_xSigsNotvalidatedImg; + std::unique_ptr<weld::Label> m_xSigsNotvalidatedFI; + std::unique_ptr<weld::Image> m_xSigsOldSignatureImg; + std::unique_ptr<weld::Label> m_xSigsOldSignatureFI; + std::unique_ptr<weld::CheckButton> m_xAdESCompliantCB; + std::unique_ptr<weld::Button> m_xViewBtn; + std::unique_ptr<weld::Button> m_xAddBtn; + std::unique_ptr<weld::Button> m_xRemoveBtn; + std::unique_ptr<weld::Button> m_xStartCertMgrBtn; + std::unique_ptr<weld::Button> m_xCloseBtn; + + DECL_LINK(AdESCompliantCheckBoxHdl, weld::ToggleButton&, void); + DECL_LINK(ViewButtonHdl, weld::Button&, void); + DECL_LINK(AddButtonHdl, weld::Button&, void); + DECL_LINK(RemoveButtonHdl, weld::Button&, void); + DECL_LINK(SignatureHighlightHdl, weld::TreeView&, void); + DECL_LINK(SignatureSelectHdl, weld::TreeView&, void); + DECL_LINK(StartVerifySignatureHdl, LinkParamNone*, bool); + DECL_LINK(OKButtonHdl, weld::Button&, void); + DECL_LINK(CertMgrButtonHdl, weld::Button&, void); void ImplGetSignatureInformations(bool bUseTempStream, bool bCacheLastSignature); void ImplFillSignaturesBox(); @@ -114,11 +108,10 @@ private: bool canAddRemove(); public: - DigitalSignaturesDialog( vcl::Window* pParent, css::uno::Reference< + DigitalSignaturesDialog(weld::Window* pParent, css::uno::Reference< css::uno::XComponentContext >& rxCtx, DocumentSignatureMode eMode, bool bReadOnly, const OUString& sODFVersion, bool bHasDocumentSignature); virtual ~DigitalSignaturesDialog() override; - virtual void dispose() override; // Initialize the dialog and the security environment, returns TRUE on success bool Init(); @@ -127,8 +120,8 @@ public: void SetStorage( const css::uno::Reference < css::embed::XStorage >& rxStore ); void SetSignatureStream( const css::uno::Reference < css::io::XStream >& rxStream ); - // Execute the dialog... - short Execute() override; + // Execute the dialog... + short run() override; // Did signatures change? bool SignaturesChanged() const { return mbSignaturesChanged; } diff --git a/xmlsecurity/source/component/documentdigitalsignatures.cxx b/xmlsecurity/source/component/documentdigitalsignatures.cxx index 2eeb6d9d13d8..4076af53bd86 100644 --- a/xmlsecurity/source/component/documentdigitalsignatures.cxx +++ b/xmlsecurity/source/component/documentdigitalsignatures.cxx @@ -398,19 +398,19 @@ bool DocumentDigitalSignatures::ImplViewSignatures( DocumentSignatureMode eMode, bool bReadOnly ) { bool bChanges = false; - ScopedVclPtrInstance<DigitalSignaturesDialog> aSignaturesDialog( - nullptr, mxCtx, eMode, bReadOnly, m_sODFVersion, + DigitalSignaturesDialog aSignaturesDialog( + Application::GetFrameWeld(mxParentWindow), mxCtx, eMode, bReadOnly, m_sODFVersion, m_bHasDocumentSignature); - bool bInit = aSignaturesDialog->Init(); + bool bInit = aSignaturesDialog.Init(); SAL_WARN_IF( !bInit, "xmlsecurity.comp", "Error initializing security context!" ); if ( bInit ) { - aSignaturesDialog->SetStorage(rxStorage); + aSignaturesDialog.SetStorage(rxStorage); - aSignaturesDialog->SetSignatureStream( xSignStream ); - if ( aSignaturesDialog->Execute() ) + aSignaturesDialog.SetSignatureStream( xSignStream ); + if (aSignaturesDialog.run() == RET_OK) { - if ( aSignaturesDialog->SignaturesChanged() ) + if (aSignaturesDialog.SignaturesChanged()) { bChanges = true; // If we have a storage and no stream, we are responsible for commit diff --git a/xmlsecurity/source/dialogs/digitalsignaturesdialog.cxx b/xmlsecurity/source/dialogs/digitalsignaturesdialog.cxx index dd93f64b55d9..00e96005d816 100644 --- a/xmlsecurity/source/dialogs/digitalsignaturesdialog.cxx +++ b/xmlsecurity/source/dialogs/digitalsignaturesdialog.cxx @@ -50,6 +50,7 @@ #include <unotools/datetime.hxx> #include <vcl/treelistentry.hxx> +#include <bitmaps.hlst> #include <strings.hrc> #include <resourcemanager.hxx> #include <comphelper/xmlsechelper.hxx> @@ -106,115 +107,87 @@ namespace } DigitalSignaturesDialog::DigitalSignaturesDialog( - vcl::Window* pParent, + weld::Window* pParent, uno::Reference< uno::XComponentContext >& rxCtx, DocumentSignatureMode eMode, bool bReadOnly, const OUString& sODFVersion, bool bHasDocumentSignature) - : ModalDialog(pParent, "DigitalSignaturesDialog", "xmlsec/ui/digitalsignaturesdialog.ui") + : GenericDialogController(pParent, "xmlsec/ui/digitalsignaturesdialog.ui", "DigitalSignaturesDialog") , mxCtx(rxCtx) , maSignatureManager(rxCtx, eMode) , m_sODFVersion (sODFVersion) , m_bHasDocumentSignature(bHasDocumentSignature) , m_bWarningShowSignMacro(false) + , m_xHintDocFT(m_xBuilder->weld_label("dochint")) + , m_xHintBasicFT(m_xBuilder->weld_label("macrohint")) + , m_xHintPackageFT(m_xBuilder->weld_label("packagehint")) + , m_xSignaturesLB(m_xBuilder->weld_tree_view("signatures")) + , m_xSigsValidImg(m_xBuilder->weld_image("validimg")) + , m_xSigsValidFI(m_xBuilder->weld_label("validft")) + , m_xSigsInvalidImg(m_xBuilder->weld_image("invalidimg")) + , m_xSigsInvalidFI(m_xBuilder->weld_label("invalidft")) + , m_xSigsNotvalidatedImg(m_xBuilder->weld_image("notvalidatedimg")) + , m_xSigsNotvalidatedFI(m_xBuilder->weld_label("notvalidatedft")) + , m_xSigsOldSignatureImg(m_xBuilder->weld_image("oldsignatureimg")) + , m_xSigsOldSignatureFI(m_xBuilder->weld_label("oldsignatureft")) + , m_xAdESCompliantCB(m_xBuilder->weld_check_button("adescompliant")) + , m_xViewBtn(m_xBuilder->weld_button("view")) + , m_xAddBtn(m_xBuilder->weld_button("sign")) + , m_xRemoveBtn(m_xBuilder->weld_button("remove")) + , m_xStartCertMgrBtn(m_xBuilder->weld_button("start_certmanager")) + , m_xCloseBtn(m_xBuilder->weld_button("close")) { - get(m_pHintDocFT, "dochint"); - get(m_pHintBasicFT, "macrohint"); - get(m_pHintPackageFT, "packagehint"); - get(m_pAdESCompliantCB, "adescompliant"); - get(m_pViewBtn, "view"); - get(m_pAddBtn, "sign"); - get(m_pRemoveBtn, "remove"); - get(m_pCloseBtn, "close"); - get(m_pStartCertMgrBtn, "start_certmanager"); - get(m_pSigsValidImg, "validimg"); - get(m_pSigsValidFI, "validft"); - get(m_pSigsInvalidImg, "invalidimg"); - get(m_pSigsInvalidFI, "invalidft"); - get(m_pSigsNotvalidatedImg, "notvalidatedimg"); - get(m_pSigsNotvalidatedFI, "notvalidatedft"); - get(m_pSigsOldSignatureImg, "oldsignatureimg"); - get(m_pSigsOldSignatureFI, "oldsignatureft"); - m_bAdESCompliant = !DocumentSignatureHelper::isODFPre_1_2(m_sODFVersion); - Size aControlSize(375, 109); - const long nControlWidth = aControlSize.Width(); - aControlSize = LogicToPixel(aControlSize, MapMode(MapUnit::MapAppFont)); - SvSimpleTableContainer *pSignatures = get<SvSimpleTableContainer>("signatures"); - pSignatures->set_width_request(aControlSize.Width()); - pSignatures->set_height_request(aControlSize.Height()); + auto nControlWidth = m_xSignaturesLB->get_approximate_digit_width() * 105; + m_xSignaturesLB->set_size_request(nControlWidth, m_xSignaturesLB->get_height_rows(10)); - m_pSignaturesLB = VclPtr<SvSimpleTable>::Create(*pSignatures); // Give the first column 6 percent, try to distribute the rest equally. - static long aTabs[] = { 0, 6*nControlWidth/100, 25*nControlWidth/100, 44*nControlWidth/100, 62*nControlWidth/100, 81*nControlWidth/100 }; - m_pSignaturesLB->SetTabs(SAL_N_ELEMENTS(aTabs), aTabs); - - m_pSignaturesLB->InsertHeaderEntry("\t" + get<FixedText>("signed")->GetText() + "\t" - + get<FixedText>("issued")->GetText() + "\t" + get<FixedText>("date")->GetText() + "\t" - + get<FixedText>("description")->GetText() + "\t" + get<FixedText>("type")->GetText()); + std::vector<int> aWidths; + aWidths.push_back(6*nControlWidth/100); + auto nColWidth = (nControlWidth - aWidths[0]) / 4; + aWidths.push_back(nColWidth); + aWidths.push_back(nColWidth); + aWidths.push_back(nColWidth); + m_xSignaturesLB->set_column_fixed_widths(aWidths); mbVerifySignatures = true; mbSignaturesChanged = false; - m_pSignaturesLB->SetSelectHdl( LINK( this, DigitalSignaturesDialog, SignatureHighlightHdl ) ); - m_pSignaturesLB->SetDoubleClickHdl( LINK( this, DigitalSignaturesDialog, SignatureSelectHdl ) ); + m_xSignaturesLB->connect_changed( LINK( this, DigitalSignaturesDialog, SignatureHighlightHdl ) ); + m_xSignaturesLB->connect_row_activated( LINK( this, DigitalSignaturesDialog, SignatureSelectHdl ) ); - m_pAdESCompliantCB->SetToggleHdl( LINK( this, DigitalSignaturesDialog, AdESCompliantCheckBoxHdl ) ); - m_pAdESCompliantCB->Check(m_bAdESCompliant); + m_xAdESCompliantCB->connect_toggled( LINK( this, DigitalSignaturesDialog, AdESCompliantCheckBoxHdl ) ); + m_xAdESCompliantCB->set_active(m_bAdESCompliant); - m_pViewBtn->SetClickHdl( LINK( this, DigitalSignaturesDialog, ViewButtonHdl ) ); - m_pViewBtn->Disable(); + m_xViewBtn->connect_clicked( LINK( this, DigitalSignaturesDialog, ViewButtonHdl ) ); + m_xViewBtn->set_sensitive(false); - m_pAddBtn->SetClickHdl( LINK( this, DigitalSignaturesDialog, AddButtonHdl ) ); + m_xAddBtn->connect_clicked( LINK( this, DigitalSignaturesDialog, AddButtonHdl ) ); if ( bReadOnly ) - m_pAddBtn->Disable(); + m_xAddBtn->set_sensitive(false); - m_pRemoveBtn->SetClickHdl( LINK( this, DigitalSignaturesDialog, RemoveButtonHdl ) ); - m_pRemoveBtn->Disable(); + m_xRemoveBtn->connect_clicked( LINK( this, DigitalSignaturesDialog, RemoveButtonHdl ) ); + m_xRemoveBtn->set_sensitive(false); - m_pStartCertMgrBtn->SetClickHdl( LINK( this, DigitalSignaturesDialog, CertMgrButtonHdl ) ); + m_xStartCertMgrBtn->connect_clicked( LINK( this, DigitalSignaturesDialog, CertMgrButtonHdl ) ); - m_pCloseBtn->SetClickHdl( LINK( this, DigitalSignaturesDialog, OKButtonHdl) ); + m_xCloseBtn->connect_clicked( LINK( this, DigitalSignaturesDialog, OKButtonHdl) ); switch( maSignatureManager.meSignatureMode ) { case DocumentSignatureMode::Content: - m_pHintDocFT->Show(); + m_xHintDocFT->show(); break; case DocumentSignatureMode::Macros: - m_pHintBasicFT->Show(); + m_xHintBasicFT->show(); break; case DocumentSignatureMode::Package: - m_pHintPackageFT->Show(); + m_xHintPackageFT->show(); break; } } DigitalSignaturesDialog::~DigitalSignaturesDialog() { - disposeOnce(); -} - -void DigitalSignaturesDialog::dispose() -{ - m_pSignaturesLB.disposeAndClear(); - m_pHintDocFT.clear(); - m_pHintBasicFT.clear(); - m_pHintPackageFT.clear(); - m_pSigsValidImg.clear(); - m_pSigsValidFI.clear(); - m_pSigsInvalidImg.clear(); - m_pSigsInvalidFI.clear(); - m_pSigsNotvalidatedImg.clear(); - m_pSigsNotvalidatedFI.clear(); - m_pSigsOldSignatureImg.clear(); - m_pSigsOldSignatureFI.clear(); - m_pAdESCompliantCB.clear(); - m_pViewBtn.clear(); - m_pAddBtn.clear(); - m_pRemoveBtn.clear(); - m_pCloseBtn.clear(); - m_pStartCertMgrBtn.clear(); - ModalDialog::dispose(); } bool DigitalSignaturesDialog::Init() @@ -237,7 +210,7 @@ void DigitalSignaturesDialog::SetStorage( const css::uno::Reference < css::embed { // PDF supports AdES. m_bAdESCompliant = true; - m_pAdESCompliantCB->Check(m_bAdESCompliant); + m_xAdESCompliantCB->set_active(m_bAdESCompliant); return; } @@ -277,7 +250,7 @@ bool DigitalSignaturesDialog::canAddRemove() if ( (!bSave1_1 && bDoc1_1) || (bSave1_1 && bDoc1_1) ) { //#4 - std::unique_ptr<weld::MessageDialog> xBox(Application::CreateMessageDialog(GetFrameWeld(), + std::unique_ptr<weld::MessageDialog> xBox(Application::CreateMessageDialog(m_xDialog.get(), VclMessageType::Warning, VclButtonsType::Ok, XsResId(STR_XMLSECDLG_OLD_ODF_FORMAT))); xBox->run(); @@ -297,7 +270,7 @@ bool DigitalSignaturesDialog::canAddRemove() //It the user presses 'Add' or 'Remove' several times then, then the warning //is shown every time until the user presses 'OK'. From then on, the warning //is not displayed anymore as long as the signatures dialog is alive. - std::unique_ptr<weld::MessageDialog> xBox(Application::CreateMessageDialog(GetFrameWeld(), + std::unique_ptr<weld::MessageDialog> xBox(Application::CreateMessageDialog(m_xDialog.get(), VclMessageType::Question, VclButtonsType::YesNo, XsResId(STR_XMLSECDLG_QUERY_REMOVEDOCSIGNBEFORESIGN))); if (xBox->run() == RET_NO) @@ -321,7 +294,7 @@ bool DigitalSignaturesDialog::canRemove() if ( maSignatureManager.meSignatureMode == DocumentSignatureMode::Content ) { - std::unique_ptr<weld::MessageDialog> xBox(Application::CreateMessageDialog(GetFrameWeld(), + std::unique_ptr<weld::MessageDialog> xBox(Application::CreateMessageDialog(m_xDialog.get(), VclMessageType::Question, VclButtonsType::YesNo, XsResId(STR_XMLSECDLG_QUERY_REALLYREMOVE))); short nDlgRet = xBox->run(); @@ -331,7 +304,7 @@ bool DigitalSignaturesDialog::canRemove() return (bRet && canAddRemove()); } -short DigitalSignaturesDialog::Execute() +short DigitalSignaturesDialog::run() { // Verify Signatures and add certificates to ListBox... mbVerifySignatures = true; @@ -357,42 +330,41 @@ short DigitalSignaturesDialog::Execute() // But for refreshing signature information, StartVerifySignatureHdl will be called after each add/remove mbVerifySignatures = false; - return Dialog::Execute(); + return GenericDialogController::run(); } -IMPL_LINK_NOARG(DigitalSignaturesDialog, SignatureHighlightHdl, SvTreeListBox*, void) +IMPL_LINK_NOARG(DigitalSignaturesDialog, SignatureHighlightHdl, weld::TreeView&, void) { - bool bSel = m_pSignaturesLB->FirstSelected(); - m_pViewBtn->Enable( bSel ); - if ( m_pAddBtn->IsEnabled() ) // not read only - m_pRemoveBtn->Enable( bSel ); + bool bSel = m_xSignaturesLB->get_selected_index() != -1; + m_xViewBtn->set_sensitive( bSel ); + if ( m_xAddBtn->get_sensitive() ) // not read only + m_xRemoveBtn->set_sensitive( bSel ); } -IMPL_LINK_NOARG(DigitalSignaturesDialog, OKButtonHdl, Button*, void) +IMPL_LINK_NOARG(DigitalSignaturesDialog, OKButtonHdl, weld::Button&, void) { if (mbSignaturesChanged) maSignatureManager.write(m_bAdESCompliant); - EndDialog(RET_OK); + m_xDialog->response(RET_OK); } -IMPL_LINK_NOARG(DigitalSignaturesDialog, SignatureSelectHdl, SvTreeListBox*, bool) +IMPL_LINK_NOARG(DigitalSignaturesDialog, SignatureSelectHdl, weld::TreeView&, void) { ImplShowSignaturesDetails(); - return false; } -IMPL_LINK_NOARG(DigitalSignaturesDialog, AdESCompliantCheckBoxHdl, CheckBox&, void) +IMPL_LINK_NOARG(DigitalSignaturesDialog, AdESCompliantCheckBoxHdl, weld::ToggleButton&, void) { - m_bAdESCompliant = m_pAdESCompliantCB->IsChecked(); + m_bAdESCompliant = m_xAdESCompliantCB->get_active(); } -IMPL_LINK_NOARG(DigitalSignaturesDialog, ViewButtonHdl, Button*, void) +IMPL_LINK_NOARG(DigitalSignaturesDialog, ViewButtonHdl, weld::Button&, void) { ImplShowSignaturesDetails(); } -IMPL_LINK_NOARG(DigitalSignaturesDialog, AddButtonHdl, Button*, void) +IMPL_LINK_NOARG(DigitalSignaturesDialog, AddButtonHdl, weld::Button&, void) { if( ! canAdd()) return; @@ -404,7 +376,7 @@ IMPL_LINK_NOARG(DigitalSignaturesDialog, AddButtonHdl, Button*, void) if (DocumentSignatureHelper::CanSignWithGPG(maSignatureManager.mxStore, m_sODFVersion)) xSecContexts.push_back(maSignatureManager.getGpgSecurityContext()); - CertificateChooser aChooser(GetFrameWeld(), mxCtx, xSecContexts, UserAction::Sign); + CertificateChooser aChooser(m_xDialog.get(), mxCtx, xSecContexts, UserAction::Sign); if (aChooser.run() == RET_OK) { sal_Int32 nSecurityId; @@ -436,7 +408,7 @@ IMPL_LINK_NOARG(DigitalSignaturesDialog, AddButtonHdl, Button*, void) catch ( uno::Exception& ) { OSL_FAIL( "Exception while adding a signature!" ); - std::unique_ptr<weld::MessageDialog> xBox(Application::CreateMessageDialog(GetFrameWeld(), + std::unique_ptr<weld::MessageDialog> xBox(Application::CreateMessageDialog(m_xDialog.get(), VclMessageType::Error, VclButtonsType::Ok, XsResId(STR_XMLSECDLG_SIGNING_FAILED))); xBox->run(); @@ -446,15 +418,16 @@ IMPL_LINK_NOARG(DigitalSignaturesDialog, AddButtonHdl, Button*, void) } } -IMPL_LINK_NOARG(DigitalSignaturesDialog, RemoveButtonHdl, Button*, void) +IMPL_LINK_NOARG(DigitalSignaturesDialog, RemoveButtonHdl, weld::Button&, void) { if (!canRemove()) return; - if( m_pSignaturesLB->FirstSelected() ) + int nEntry = m_xSignaturesLB->get_selected_index(); + if (nEntry != -1) { try { - sal_uInt16 nSelected = static_cast<sal_uInt16>(reinterpret_cast<sal_uIntPtr>( m_pSignaturesLB->FirstSelected()->GetUserData() )); + sal_uInt16 nSelected = m_xSignaturesLB->get_id(nEntry).toUInt32(); maSignatureManager.remove(nSelected); mbSignaturesChanged = true; @@ -471,7 +444,7 @@ IMPL_LINK_NOARG(DigitalSignaturesDialog, RemoveButtonHdl, Button*, void) } } -IMPL_STATIC_LINK(DigitalSignaturesDialog, CertMgrButtonHdl, Button*, pButton, void) +IMPL_LINK_NOARG(DigitalSignaturesDialog, CertMgrButtonHdl, weld::Button&, void) { #ifdef _WIN32 // FIXME: call GpgME::dirInfo("bindir") somewhere in @@ -515,7 +488,7 @@ IMPL_STATIC_LINK(DigitalSignaturesDialog, CertMgrButtonHdl, Button*, pButton, vo } else { - std::unique_ptr<weld::MessageDialog> xInfoBox(Application::CreateMessageDialog(pButton->GetFrameWeld(), + std::unique_ptr<weld::MessageDialog> xInfoBox(Application::CreateMessageDialog(m_xDialog.get(), VclMessageType::Info, VclButtonsType::Ok, XsResId(STR_XMLSECDLG_NO_CERT_MANAGER))); xInfoBox->run(); @@ -529,7 +502,7 @@ IMPL_LINK_NOARG(DigitalSignaturesDialog, StartVerifySignatureHdl, LinkParamNone* void DigitalSignaturesDialog::ImplFillSignaturesBox() { - m_pSignaturesLB->Clear(); + m_xSignaturesLB->clear(); size_t nInfos = maSignatureManager.maCurrentSignatureInformations.size(); size_t nValidSigs = 0, nValidCerts = 0; @@ -615,14 +588,14 @@ void DigitalSignaturesDialog::ImplFillSignaturesBox() nValidSigs++; } - Image aImage; + OUString sImage; if (!bSigValid) { - aImage = m_pSigsInvalidImg->GetImage(); + sImage = BMP_SIG_INVALID; } else if (!bCertValid) { - aImage = m_pSigsNotvalidatedImg->GetImage(); + sImage = BMP_SIG_NOT_VALIDATED; } //Check if the signature is a "old" document signature, that is, which was created //by an version of OOo previous to 3.2 @@ -632,27 +605,28 @@ void DigitalSignaturesDialog::ImplFillSignaturesBox() && (maSignatureManager.mxStore.is() && !DocumentSignatureHelper::isOOo3_2_Signature( maSignatureManager.maCurrentSignatureInformations[n]))) { - aImage = m_pSigsNotvalidatedImg->GetImage(); + sImage = BMP_SIG_NOT_VALIDATED; bAllNewSignatures = false; } else if (maSignatureManager.meSignatureMode == DocumentSignatureMode::Content && DocumentSignatureHelper::isOOo3_2_Signature( maSignatureManager.maCurrentSignatureInformations[n])) { - aImage = m_pSigsValidImg->GetImage(); + sImage = BMP_SIG_VALID; } else if (maSignatureManager.meSignatureMode == DocumentSignatureMode::Macros) { - aImage = m_pSigsValidImg->GetImage(); + sImage = BMP_SIG_VALID; } - SvTreeListEntry* pEntry = m_pSignaturesLB->InsertEntry( OUString(), aImage, aImage ); - m_pSignaturesLB->SetEntryText( aSubject, pEntry, 1 ); - m_pSignaturesLB->SetEntryText( aIssuer, pEntry, 2 ); - m_pSignaturesLB->SetEntryText( aDateTimeStr, pEntry, 3 ); - m_pSignaturesLB->SetEntryText(aDescription, pEntry, 4); - m_pSignaturesLB->SetEntryText(aType, pEntry, 5); - pEntry->SetUserData( reinterpret_cast<void*>(n) ); // misuse user data as index + m_xSignaturesLB->insert(nullptr, n, nullptr, nullptr, + &sImage, nullptr, nullptr, false); + m_xSignaturesLB->set_text(n, aSubject, 1); + m_xSignaturesLB->set_text(n, aIssuer, 2); + m_xSignaturesLB->set_text(n, aDateTimeStr, 3); + m_xSignaturesLB->set_text(n, aDescription, 4); + m_xSignaturesLB->set_text(n, aType, 5); + m_xSignaturesLB->set_id(n, OUString::number(n)); // misuse user data as index } } @@ -660,25 +634,25 @@ void DigitalSignaturesDialog::ImplFillSignaturesBox() bool bAllCertsValid = (nValidCerts == nInfos); bool bShowValidState = nInfos && (bAllSigsValid && bAllCertsValid && bAllNewSignatures); - m_pSigsValidImg->Show( bShowValidState); - m_pSigsValidFI->Show( bShowValidState ); + m_xSigsValidImg->show( bShowValidState); + m_xSigsValidFI->show( bShowValidState ); bool bShowInvalidState = nInfos && !bAllSigsValid; - m_pSigsInvalidImg->Show( bShowInvalidState ); - m_pSigsInvalidFI->Show( bShowInvalidState ); + m_xSigsInvalidImg->show( bShowInvalidState ); + m_xSigsInvalidFI->show( bShowInvalidState ); bool bShowNotValidatedState = nInfos && bAllSigsValid && !bAllCertsValid; - m_pSigsNotvalidatedImg->Show(bShowNotValidatedState); - m_pSigsNotvalidatedFI->Show(bShowNotValidatedState); + m_xSigsNotvalidatedImg->show(bShowNotValidatedState); + m_xSigsNotvalidatedFI->show(bShowNotValidatedState); //bAllNewSignatures is always true if we are not in document mode bool bShowOldSignature = nInfos && bAllSigsValid && bAllCertsValid && !bAllNewSignatures; - m_pSigsOldSignatureImg->Show(bShowOldSignature); - m_pSigsOldSignatureFI->Show(bShowOldSignature); + m_xSigsOldSignatureImg->show(bShowOldSignature); + m_xSigsOldSignatureFI->show(bShowOldSignature); - SignatureHighlightHdl( nullptr ); + SignatureHighlightHdl(*m_xSignaturesLB); } uno::Reference<security::XCertificate> DigitalSignaturesDialog::getCertificate(const SignatureInformation& rInfo) @@ -731,21 +705,22 @@ void DigitalSignaturesDialog::ImplGetSignatureInformations(bool bUseTempStream, void DigitalSignaturesDialog::ImplShowSignaturesDetails() { - if( m_pSignaturesLB->FirstSelected() ) + int nEntry = m_xSignaturesLB->get_selected_index(); + if (nEntry != -1) { - sal_uInt16 nSelected = static_cast<sal_uInt16>(reinterpret_cast<sal_uIntPtr>( m_pSignaturesLB->FirstSelected()->GetUserData() )); + sal_uInt16 nSelected = m_xSignaturesLB->get_id(nEntry).toUInt32(); const SignatureInformation& rInfo = maSignatureManager.maCurrentSignatureInformations[ nSelected ]; uno::Reference<security::XCertificate> xCert = getCertificate(rInfo); if ( xCert.is() ) { uno::Reference<xml::crypto::XSecurityEnvironment> xSecEnv = getSecurityEnvironmentForCertificate(xCert); - CertificateViewer aViewer(GetFrameWeld(), xSecEnv, xCert, false, nullptr); + CertificateViewer aViewer(m_xDialog.get(), xSecEnv, xCert, false, nullptr); aViewer.run(); } else { - std::unique_ptr<weld::MessageDialog> xInfoBox(Application::CreateMessageDialog(GetFrameWeld(), + std::unique_ptr<weld::MessageDialog> xInfoBox(Application::CreateMessageDialog(m_xDialog.get(), VclMessageType::Info, VclButtonsType::Ok, XsResId(STR_XMLSECDLG_NO_CERT_FOUND))); xInfoBox->run(); diff --git a/xmlsecurity/uiconfig/ui/digitalsignaturesdialog.ui b/xmlsecurity/uiconfig/ui/digitalsignaturesdialog.ui index 958b8359bc80..6a8aac825fd3 100644 --- a/xmlsecurity/uiconfig/ui/digitalsignaturesdialog.ui +++ b/xmlsecurity/uiconfig/ui/digitalsignaturesdialog.ui @@ -1,13 +1,33 @@ <?xml version="1.0" encoding="UTF-8"?> -<!-- Generated with glade 3.18.3 --> +<!-- Generated with glade 3.22.1 --> <interface domain="xsc"> <requires lib="gtk+" version="3.18"/> - <requires lib="LibreOffice" version="1.0"/> + <object class="GtkTreeStore" id="liststore3"> + <columns> + <!-- column-name image --> + <column type="GdkPixbuf"/> + <!-- column-name text --> + <column type="gchararray"/> + <!-- column-name text2 --> + <column type="gchararray"/> + <!-- column-name text3 --> + <column type="gchararray"/> + <!-- column-name text4 --> + <column type="gchararray"/> + <!-- column-name text5 --> + <column type="gchararray"/> + <!-- column-name id --> + <column type="gchararray"/> + </columns> + </object> <object class="GtkDialog" id="DigitalSignaturesDialog"> <property name="can_focus">False</property> <property name="border_width">6</property> <property name="title" translatable="yes" context="digitalsignaturesdialog|DigitalSignaturesDialog">Digital Signatures</property> <property name="type_hint">dialog</property> + <child> + <placeholder/> + </child> <child internal-child="vbox"> <object class="GtkBox" id="dialog-vbox1"> <property name="can_focus">False</property> @@ -76,13 +96,104 @@ </packing> </child> <child> - <object class="svtlo-SvSimpleTableContainer" id="signatures"> + <object class="GtkScrolledWindow"> <property name="visible">True</property> <property name="can_focus">True</property> <property name="hexpand">True</property> <property name="vexpand">True</property> - <child internal-child="selection"> - <object class="GtkTreeSelection" id="Simple Table Container-selection1"/> + <property name="shadow_type">in</property> + <child> + <object class="GtkTreeView" id="signatures"> + <property name="visible">True</property> + <property name="can_focus">True</property> + <property name="receives_default">True</property> + <property name="hexpand">True</property> + <property name="vexpand">True</property> + <property name="model">liststore3</property> + <property name="search_column">0</property> + <property name="show_expanders">False</property> + <property name="headers_visible">True</property> + <child internal-child="selection"> + <object class="GtkTreeSelection" id="Macro Library List-selection2"/> + </child> + <child> + <object class="GtkTreeViewColumn" id="treeviewcolumn2"> + <property name="resizable">True</property> + <property name="spacing">6</property> + <child> + <object class="GtkCellRendererPixbuf" id="cellrenderertext0"/> + <attributes> + <attribute name="pixbuf">0</attribute> + </attributes> + </child> + </object> + </child> + <child> + <object class="GtkTreeViewColumn" id="treeviewcolumn3"> + <property name="resizable">True</property> + <property name="spacing">6</property> + <property name="title" translatable="yes" context="digitalsignaturesdialog|signed">Signed by </property> + <child> + <object class="GtkCellRendererText" id="cellrenderer1"/> + <attributes> + <attribute name="text">1</attribute> + </attributes> + </child> + </object> + </child> + <child> + <object class="GtkTreeViewColumn" id="treeviewcolumn4"> + <property name="resizable">True</property> + <property name="spacing">6</property> + <property name="title" translatable="yes" context="digitalsignaturesdialog|issued">Digital ID issued by </property> + <child> + <object class="GtkCellRendererText" id="cellrenderer2"/> + <attributes> + <attribute name="text">2</attribute> + </attributes> + </child> + </object> + </child> + <child> + <object class="GtkTreeViewColumn" id="treeviewcolumn5"> + <property name="resizable">True</property> + <property name="spacing">6</property> + <property name="title" translatable="yes" context="digitalsignaturesdialog|date">Date</property> + <child> + <object class="GtkCellRendererText" id="cellrenderer3"/> + <attributes> + <attribute name="text">3</attribute> + </attributes> + </child> + </object> + </child> + <child> + <object class="GtkTreeViewColumn" id="treeviewcolumn6"> + <property name="resizable">True</property> + <property name="spacing">6</property> + <property name="title" translatable="yes" context="digitalsignaturesdialog|description">Description</property> + <child> + <object class="GtkCellRendererText" id="cellrenderer4"/> + <attributes> + <attribute name="text">4</attribute> + </attributes> + </child> + </object> + </child> + <child> + <object class="GtkTreeViewColumn" id="treeviewcolumn7"> + <property name="resizable">True</property> + <property name="spacing">6</property> + <property name="title" translatable="yes" context="digitalsignaturesdialog|type">Signature type</property> + <child> + <object class="GtkCellRendererText" id="cellrenderer5"/> + <attributes> + <attribute name="text">5</attribute> + </attributes> + </child> + </object> + </child> + </object> </child> </object> <packing> @@ -167,7 +278,6 @@ <property name="can_focus">False</property> <property name="no_show_all">True</property> <property name="hexpand">True</property> - <property name="label" translatable="yes" context="digitalsignaturesdialog|signed">Signed by </property> </object> <packing> <property name="left_attach">0</property> @@ -179,7 +289,6 @@ <property name="can_focus">False</property> <property name="no_show_all">True</property> <property name="hexpand">True</property> - <property name="label" translatable="yes" context="digitalsignaturesdialog|issued">Digital ID issued by </property> </object> <packing> <property name="left_attach">1</property> @@ -191,7 +300,6 @@ <property name="can_focus">False</property> <property name="no_show_all">True</property> <property name="hexpand">True</property> - <property name="label" translatable="yes" context="digitalsignaturesdialog|date">Date</property> </object> <packing> <property name="left_attach">2</property> @@ -202,7 +310,6 @@ <object class="GtkLabel" id="description"> <property name="can_focus">False</property> <property name="no_show_all">True</property> - <property name="label" translatable="yes" context="digitalsignaturesdialog|description">Description</property> </object> <packing> <property name="left_attach">3</property> @@ -213,7 +320,6 @@ <object class="GtkLabel" id="type"> <property name="can_focus">False</property> <property name="no_show_all">True</property> - <property name="label" translatable="yes" context="digitalsignaturesdialog|type">Signature type</property> </object> <packing> <property name="left_attach">4</property> @@ -272,7 +378,7 @@ <object class="GtkImage" id="validimg"> <property name="can_focus">False</property> <property name="no_show_all">True</property> - <property name="pixbuf">xmlsecurity/res/signet_11x16.png</property> + <property name="icon_name">xmlsecurity/res/signet_11x16.png</property> </object> <packing> <property name="left_attach">0</property> @@ -322,7 +428,7 @@ <object class="GtkImage" id="invalidimg"> <property name="can_focus">False</property> <property name="no_show_all">True</property> - <property name="pixbuf">svx/res/caution_11x16.png</property> + <property name="icon_name">svx/res/caution_11x16.png</property> </object> <packing> <property name="left_attach">0</property> @@ -333,7 +439,7 @@ <object class="GtkImage" id="oldsignatureimg"> <property name="can_focus">False</property> <property name="no_show_all">True</property> - <property name="pixbuf">svx/res/caution_11x16.png</property> + <property name="icon_name">svx/res/caution_11x16.png</property> </object> <packing> <property name="left_attach">0</property> @@ -344,7 +450,7 @@ <object class="GtkImage" id="notvalidatedimg"> <property name="can_focus">False</property> <property name="no_show_all">True</property> - <property name="pixbuf">xmlsecurity/res/notcertificate_16.png</property> + <property name="icon_name">xmlsecurity/res/notcertificate_16.png</property> </object> <packing> <property name="left_attach">0</property> @@ -363,10 +469,10 @@ <property name="visible">True</property> <property name="can_focus">True</property> <property name="receives_default">True</property> - <property name="use_underline">True</property> <property name="halign">start</property> + <property name="use_underline">True</property> <property name="xalign">0.5</property> - <property name="draw_indicator">False</property> + <property name="draw_indicator">True</property> </object> <packing> <property name="left_attach">0</property> diff --git a/xmlsecurity/uiconfig/ui/selectcertificatedialog.ui b/xmlsecurity/uiconfig/ui/selectcertificatedialog.ui index f44d0e58f4da..ca46e13fae2a 100644 --- a/xmlsecurity/uiconfig/ui/selectcertificatedialog.ui +++ b/xmlsecurity/uiconfig/ui/selectcertificatedialog.ui @@ -138,6 +138,7 @@ <property name="model">liststore3</property> <property name="search_column">0</property> <property name="show_expanders">False</property> + <property name="headers_visible">True</property> <child internal-child="selection"> <object class="GtkTreeSelection" id="Macro Library List-selection2"/> </child> |