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 // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_cppuhelper.hxx"
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski #include <cppuhelper/access_control.hxx>
28*b1cdbd2cSJim Jagielski 
29*b1cdbd2cSJim Jagielski #include <com/sun/star/security/XAccessController.hpp>
30*b1cdbd2cSJim Jagielski #include <com/sun/star/security/RuntimePermission.hpp>
31*b1cdbd2cSJim Jagielski #include <com/sun/star/io/FilePermission.hpp>
32*b1cdbd2cSJim Jagielski #include <com/sun/star/connection/SocketPermission.hpp>
33*b1cdbd2cSJim Jagielski 
34*b1cdbd2cSJim Jagielski #define OUSTR(x) ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM(x) )
35*b1cdbd2cSJim Jagielski 
36*b1cdbd2cSJim Jagielski 
37*b1cdbd2cSJim Jagielski using namespace ::rtl;
38*b1cdbd2cSJim Jagielski using namespace ::osl;
39*b1cdbd2cSJim Jagielski using namespace ::com::sun::star;
40*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::uno;
41*b1cdbd2cSJim Jagielski 
42*b1cdbd2cSJim Jagielski namespace
43*b1cdbd2cSJim Jagielski {
str_ac_singleton()44*b1cdbd2cSJim Jagielski     inline OUString str_ac_singleton()
45*b1cdbd2cSJim Jagielski     {
46*b1cdbd2cSJim Jagielski         return OUSTR("/singletons/com.sun.star.security.theAccessController");
47*b1cdbd2cSJim Jagielski     }
48*b1cdbd2cSJim Jagielski }
49*b1cdbd2cSJim Jagielski 
50*b1cdbd2cSJim Jagielski namespace cppu
51*b1cdbd2cSJim Jagielski {
52*b1cdbd2cSJim Jagielski //__________________________________________________________________________________________________
AccessControl(Reference<XComponentContext> const & xContext)53*b1cdbd2cSJim Jagielski AccessControl::AccessControl( Reference< XComponentContext > const & xContext )
54*b1cdbd2cSJim Jagielski     SAL_THROW( (RuntimeException) )
55*b1cdbd2cSJim Jagielski {
56*b1cdbd2cSJim Jagielski     if (! (xContext->getValueByName( str_ac_singleton() ) >>= m_xController))
57*b1cdbd2cSJim Jagielski     {
58*b1cdbd2cSJim Jagielski         throw SecurityException(
59*b1cdbd2cSJim Jagielski             OUSTR("no access controller!"), Reference< XInterface >() );
60*b1cdbd2cSJim Jagielski     }
61*b1cdbd2cSJim Jagielski }
62*b1cdbd2cSJim Jagielski //__________________________________________________________________________________________________
AccessControl(Reference<security::XAccessController> const & xController)63*b1cdbd2cSJim Jagielski AccessControl::AccessControl(
64*b1cdbd2cSJim Jagielski     Reference< security::XAccessController > const & xController )
65*b1cdbd2cSJim Jagielski     SAL_THROW( (RuntimeException) )
66*b1cdbd2cSJim Jagielski     : m_xController( xController )
67*b1cdbd2cSJim Jagielski {
68*b1cdbd2cSJim Jagielski     if (! m_xController.is())
69*b1cdbd2cSJim Jagielski     {
70*b1cdbd2cSJim Jagielski         throw SecurityException(
71*b1cdbd2cSJim Jagielski             OUSTR("no access controller!"), Reference< XInterface >() );
72*b1cdbd2cSJim Jagielski     }
73*b1cdbd2cSJim Jagielski }
74*b1cdbd2cSJim Jagielski //__________________________________________________________________________________________________
AccessControl(AccessControl const & ac)75*b1cdbd2cSJim Jagielski AccessControl::AccessControl( AccessControl const & ac )
76*b1cdbd2cSJim Jagielski     SAL_THROW( (RuntimeException) )
77*b1cdbd2cSJim Jagielski     : m_xController( ac.m_xController )
78*b1cdbd2cSJim Jagielski {
79*b1cdbd2cSJim Jagielski     if (! m_xController.is())
80*b1cdbd2cSJim Jagielski     {
81*b1cdbd2cSJim Jagielski         throw SecurityException(
82*b1cdbd2cSJim Jagielski             OUSTR("no access controller!"), Reference< XInterface >() );
83*b1cdbd2cSJim Jagielski     }
84*b1cdbd2cSJim Jagielski }
85*b1cdbd2cSJim Jagielski 
86*b1cdbd2cSJim Jagielski #ifdef SAL_W32
87*b1cdbd2cSJim Jagielski #pragma pack(push, 8)
88*b1cdbd2cSJim Jagielski #endif
89*b1cdbd2cSJim Jagielski     // binary comp. to all Permission structs
90*b1cdbd2cSJim Jagielski     struct __permission
91*b1cdbd2cSJim Jagielski     {
92*b1cdbd2cSJim Jagielski         rtl_uString * m_str1;
93*b1cdbd2cSJim Jagielski         rtl_uString * m_str2;
94*b1cdbd2cSJim Jagielski     };
95*b1cdbd2cSJim Jagielski #ifdef SAL_W32
96*b1cdbd2cSJim Jagielski #pragma pack(pop)
97*b1cdbd2cSJim Jagielski #endif
98*b1cdbd2cSJim Jagielski 
99*b1cdbd2cSJim Jagielski //--------------------------------------------------------------------------------------------------
__checkPermission(Reference<security::XAccessController> const & xController,Type const & type,rtl_uString * str1,rtl_uString * str2)100*b1cdbd2cSJim Jagielski inline void __checkPermission(
101*b1cdbd2cSJim Jagielski     Reference< security::XAccessController > const & xController,
102*b1cdbd2cSJim Jagielski     Type const & type, rtl_uString * str1, rtl_uString * str2 )
103*b1cdbd2cSJim Jagielski     SAL_THROW( (RuntimeException) )
104*b1cdbd2cSJim Jagielski {
105*b1cdbd2cSJim Jagielski     __permission perm;
106*b1cdbd2cSJim Jagielski     perm.m_str1 = str1;
107*b1cdbd2cSJim Jagielski     perm.m_str2 = str2;
108*b1cdbd2cSJim Jagielski 
109*b1cdbd2cSJim Jagielski     uno_Any a;
110*b1cdbd2cSJim Jagielski     a.pType = type.getTypeLibType();
111*b1cdbd2cSJim Jagielski     a.pData = &perm;
112*b1cdbd2cSJim Jagielski 
113*b1cdbd2cSJim Jagielski     xController->checkPermission( * static_cast< Any * >( &a ) );
114*b1cdbd2cSJim Jagielski }
115*b1cdbd2cSJim Jagielski //__________________________________________________________________________________________________
checkRuntimePermission(OUString const & name)116*b1cdbd2cSJim Jagielski void AccessControl::checkRuntimePermission(
117*b1cdbd2cSJim Jagielski     OUString const & name )
118*b1cdbd2cSJim Jagielski     SAL_THROW( (RuntimeException) )
119*b1cdbd2cSJim Jagielski {
120*b1cdbd2cSJim Jagielski     __checkPermission(
121*b1cdbd2cSJim Jagielski         m_xController,
122*b1cdbd2cSJim Jagielski         ::getCppuType( (security::RuntimePermission *)0 ), name.pData, 0 );
123*b1cdbd2cSJim Jagielski }
124*b1cdbd2cSJim Jagielski //__________________________________________________________________________________________________
checkFilePermission(OUString const & url,OUString const & actions)125*b1cdbd2cSJim Jagielski void AccessControl::checkFilePermission(
126*b1cdbd2cSJim Jagielski     OUString const & url,
127*b1cdbd2cSJim Jagielski     OUString const & actions )
128*b1cdbd2cSJim Jagielski     SAL_THROW( (RuntimeException) )
129*b1cdbd2cSJim Jagielski {
130*b1cdbd2cSJim Jagielski     __checkPermission(
131*b1cdbd2cSJim Jagielski         m_xController,
132*b1cdbd2cSJim Jagielski         ::getCppuType( (io::FilePermission *)0 ), url.pData, actions.pData );
133*b1cdbd2cSJim Jagielski }
134*b1cdbd2cSJim Jagielski //__________________________________________________________________________________________________
checkSocketPermission(OUString const & host,OUString const & actions)135*b1cdbd2cSJim Jagielski void AccessControl::checkSocketPermission(
136*b1cdbd2cSJim Jagielski     OUString const & host,
137*b1cdbd2cSJim Jagielski     OUString const & actions )
138*b1cdbd2cSJim Jagielski     SAL_THROW( (RuntimeException) )
139*b1cdbd2cSJim Jagielski {
140*b1cdbd2cSJim Jagielski     __checkPermission(
141*b1cdbd2cSJim Jagielski         m_xController,
142*b1cdbd2cSJim Jagielski         ::getCppuType( (connection::SocketPermission *)0 ), host.pData, actions.pData );
143*b1cdbd2cSJim Jagielski }
144*b1cdbd2cSJim Jagielski 
145*b1cdbd2cSJim Jagielski }
146