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