/* -*- 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 . */ #ifndef INCLUDED_DBACCESS_SOURCE_UI_UNO_DBINTERACTION_HXX #define INCLUDED_DBACCESS_SOURCE_UI_UNO_DBINTERACTION_HXX #include #include #include #include #include #include #include #include #include namespace com::sun::star::uno { class XComponentContext; } namespace dbtools { class SQLExceptionInfo; } namespace dbaui { // BasicInteractionHandler typedef ::cppu::WeakImplHelper< css::lang::XServiceInfo , css::lang::XInitialization , css::task::XInteractionHandler2 > BasicInteractionHandler_Base; /** implements an XInteractionHandler for database related interaction requests.

Supported interaction requests by now (specified by an exception: The appropriate exception has to be returned by the getRequest method of the object implementing the XInteractionRequest interface.

  • SQLException: requests to display a standard error dialog for the (maybe chained) exception given
*/ class BasicInteractionHandler :public BasicInteractionHandler_Base { css::uno::Reference< css::awt::XWindow > m_xParentWindow; const css::uno::Reference< css::uno::XComponentContext > m_xContext; const bool m_bFallbackToGeneric; public: BasicInteractionHandler( const css::uno::Reference< css::uno::XComponentContext >& rxContext, const bool i_bFallbackToGeneric ); // XInitialization virtual void SAL_CALL initialize( const css::uno::Sequence< css::uno::Any >& rArgs ) override; // XInteractionHandler2 virtual sal_Bool SAL_CALL handleInteractionRequest( const css::uno::Reference< css::task::XInteractionRequest >& Request ) override; // XInteractionHandler virtual void SAL_CALL handle( const css::uno::Reference< css::task::XInteractionRequest >& Request ) override; protected: bool impl_handle_throw( const css::uno::Reference< css::task::XInteractionRequest >& i_Request ); /// handle SQLExceptions (and derived classes) static void implHandle( const ::dbtools::SQLExceptionInfo& _rSqlInfo, const css::uno::Sequence< css::uno::Reference< css::task::XInteractionContinuation > >& _rContinuations); /// handle parameter requests void implHandle( const css::sdb::ParametersRequest& _rParamRequest, const css::uno::Sequence< css::uno::Reference< css::task::XInteractionContinuation > >& _rContinuations); /// handle document save requests void implHandle( const css::sdb::DocumentSaveRequest& _rParamRequest, const css::uno::Sequence< css::uno::Reference< css::task::XInteractionContinuation > >& _rContinuations); /// handles requests which are not SDB-specific bool implHandleUnknown( const css::uno::Reference< css::task::XInteractionRequest >& _rxRequest ); /// known continuation types enum Continuation { APPROVE, DISAPPROVE, RETRY, ABORT, SUPPLY_PARAMETERS, SUPPLY_DOCUMENTSAVE }; /** check if a given continuation sequence contains a given continuation type

@return the index within _rContinuations of the first occurrence of a continuation of the requested type, -1 of no such continuation exists */ static sal_Int32 getContinuation( Continuation _eCont, const css::uno::Sequence< css::uno::Reference< css::task::XInteractionContinuation > >& _rContinuations); }; // SQLExceptionInteractionHandler class SQLExceptionInteractionHandler : public BasicInteractionHandler { public: explicit SQLExceptionInteractionHandler( const css::uno::Reference< css::uno::XComponentContext >& rxContext ) :BasicInteractionHandler( rxContext, false ) { } // XServiceInfo DECLARE_SERVICE_INFO(); /// @throws css::uno::RuntimeException static OUString getImplementationName_Static( ); /// @throws css::uno::RuntimeException static css::uno::Sequence< OUString > getSupportedServiceNames_Static( ); static css::uno::Reference< css::uno::XInterface > Create(const css::uno::Reference< css::lang::XMultiServiceFactory >&); }; // SQLExceptionInteractionHandler /** an implementation for the legacy css.sdb.InteractionHandler css.sdb.InteractionHandler is deprecated, as it does not only handle database related interactions, but also delegates all kind of unknown requests to a css.task.InteractionHandler. In today's architecture, there's only one central css.task.InteractionHandler, which is to be used for all requests. Depending on configuration information, it decides which handler implementation to delegate a request to. SQLExceptionInteractionHandler is the delegatee which handles only database related interactions. LegacyInteractionHandler is the version which first checks for a database related interaction, and forwards everything else to the css.task.InteractionHandler. */ class LegacyInteractionHandler : public BasicInteractionHandler { public: explicit LegacyInteractionHandler( const css::uno::Reference< css::uno::XComponentContext >& rxContext ) :BasicInteractionHandler( rxContext, true ) { } // XServiceInfo DECLARE_SERVICE_INFO(); /// @throws css::uno::RuntimeException static OUString getImplementationName_Static( ); /// @throws css::uno::RuntimeException static css::uno::Sequence< OUString > getSupportedServiceNames_Static( ); static css::uno::Reference< css::uno::XInterface > Create(const css::uno::Reference< css::lang::XMultiServiceFactory >&); }; } // namespace dbaui #endif // INCLUDED_DBACCESS_SOURCE_UI_UNO_DBINTERACTION_HXX /* vim:set shiftwidth=4 softtabstop=4 expandtab: */