1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski #ifndef __FRAMEWORK_DISPATCH_UIEVENTLOGHELPER_HXX_
25*b1cdbd2cSJim Jagielski #define __FRAMEWORK_DISPATCH_UIEVENTLOGHELPER_HXX_
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski #include <com/sun/star/beans/PropertyValue.hpp>
28*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XModuleManager.hpp>
29*b1cdbd2cSJim Jagielski #include <com/sun/star/lang/XMultiServiceFactory.hpp>
30*b1cdbd2cSJim Jagielski #include <com/sun/star/uno/Reference.hxx>
31*b1cdbd2cSJim Jagielski #include <com/sun/star/uno/Sequence.hxx>
32*b1cdbd2cSJim Jagielski #include <com/sun/star/uno/XInterface.hpp>
33*b1cdbd2cSJim Jagielski #include <com/sun/star/util/URL.hpp>
34*b1cdbd2cSJim Jagielski #include <comphelper/uieventslogger.hxx>
35*b1cdbd2cSJim Jagielski #include <rtl/ustring.hxx>
36*b1cdbd2cSJim Jagielski #include <services.h>
37*b1cdbd2cSJim Jagielski 
38*b1cdbd2cSJim Jagielski namespace framework
39*b1cdbd2cSJim Jagielski {
40*b1cdbd2cSJim Jagielski     class UiEventLogHelper
41*b1cdbd2cSJim Jagielski     {
42*b1cdbd2cSJim Jagielski         public:
UiEventLogHelper(const::rtl::OUString & aWidgetname)43*b1cdbd2cSJim Jagielski             UiEventLogHelper(const ::rtl::OUString& aWidgetname)
44*b1cdbd2cSJim Jagielski                 : m_aWidgetName(aWidgetname)
45*b1cdbd2cSJim Jagielski                 , m_hasAppName(false)
46*b1cdbd2cSJim Jagielski             { }
47*b1cdbd2cSJim Jagielski 
log(const::com::sun::star::uno::Reference<com::sun::star::lang::XMultiServiceFactory> & rServiceManager,const::com::sun::star::uno::Reference<com::sun::star::uno::XInterface> & rModel,const::com::sun::star::util::URL & rUrl,const::com::sun::star::uno::Sequence<::com::sun::star::beans::PropertyValue> & rArgs)48*b1cdbd2cSJim Jagielski             void log(const ::com::sun::star::uno::Reference< com::sun::star::lang::XMultiServiceFactory >& rServiceManager,
49*b1cdbd2cSJim Jagielski                 const ::com::sun::star::uno::Reference< com::sun::star::uno::XInterface >& rModel,
50*b1cdbd2cSJim Jagielski                 const ::com::sun::star::util::URL& rUrl,
51*b1cdbd2cSJim Jagielski                 const ::com::sun::star::uno::Sequence< ::com::sun::star::beans::PropertyValue>& rArgs)
52*b1cdbd2cSJim Jagielski             {
53*b1cdbd2cSJim Jagielski 
54*b1cdbd2cSJim Jagielski                 if(!m_hasAppName && rServiceManager.is() && rModel.is())
55*b1cdbd2cSJim Jagielski                 {
56*b1cdbd2cSJim Jagielski                     try
57*b1cdbd2cSJim Jagielski                     {
58*b1cdbd2cSJim Jagielski                         static ::rtl::OUString our_aModuleManagerName = SERVICENAME_MODULEMANAGER;
59*b1cdbd2cSJim Jagielski                         ::com::sun::star::uno::Reference< ::com::sun::star::frame::XModuleManager > xModuleManager(
60*b1cdbd2cSJim Jagielski                             rServiceManager->createInstance(our_aModuleManagerName)
61*b1cdbd2cSJim Jagielski                             , ::com::sun::star::uno::UNO_QUERY_THROW);
62*b1cdbd2cSJim Jagielski                         m_aAppName = xModuleManager->identify(rModel);
63*b1cdbd2cSJim Jagielski                         m_hasAppName = true;
64*b1cdbd2cSJim Jagielski                     } catch(::com::sun::star::uno::Exception&) {}
65*b1cdbd2cSJim Jagielski                 }
66*b1cdbd2cSJim Jagielski                 ::com::sun::star::uno::Sequence< ::com::sun::star::beans::PropertyValue> aArgsWithOrigin(rArgs);
67*b1cdbd2cSJim Jagielski                 ::comphelper::UiEventsLogger::appendDispatchOrigin(aArgsWithOrigin, m_aAppName, m_aWidgetName);
68*b1cdbd2cSJim Jagielski                 ::comphelper::UiEventsLogger::logDispatch(rUrl, aArgsWithOrigin);
69*b1cdbd2cSJim Jagielski             }
70*b1cdbd2cSJim Jagielski 
71*b1cdbd2cSJim Jagielski         private:
72*b1cdbd2cSJim Jagielski             const ::rtl::OUString m_aWidgetName;
73*b1cdbd2cSJim Jagielski             bool m_hasAppName;
74*b1cdbd2cSJim Jagielski             ::rtl::OUString m_aAppName;
75*b1cdbd2cSJim Jagielski     };
76*b1cdbd2cSJim Jagielski }
77*b1cdbd2cSJim Jagielski 
78*b1cdbd2cSJim Jagielski #endif // __FRAMEWORK_DISPATCH_UIEVENTLOGHELPER_HXX_
79