LibreOffice Module cppuhelper (master) 1
access_control.hxx
Go to the documentation of this file.
1/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2/*
3 * This file is part of the LibreOffice project.
4 *
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8 *
9 * This file incorporates work covered by the following license notice:
10 *
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
18 */
19
20/*
21 * This file is part of LibreOffice published API.
22 */
23#ifndef INCLUDED_CPPUHELPER_ACCESS_CONTROL_HXX
24#define INCLUDED_CPPUHELPER_ACCESS_CONTROL_HXX
25
27#include "com/sun/star/uno/Reference.hxx"
28
29namespace com { namespace sun { namespace star { namespace security { class XAccessController; } } } }
30namespace com { namespace sun { namespace star { namespace uno { class XComponentContext; } } } }
31
32namespace cppu
33{
34
38{
39 css::uno::Reference< css::security::XAccessController > m_xController;
40
41public:
47 css::uno::Reference< css::uno::XComponentContext > const & xContext );
53 css::uno::Reference< css::security::XAccessController > const & xController );
59
60#if defined LIBO_INTERNAL_ONLY
61 AccessControl & operator =(AccessControl const &) = default; // avoid deprecation warnings
62#endif
63
66 void SAL_CALL clear()
67 { m_xController.clear(); }
68
73 css::uno::Reference< css::security::XAccessController > const & SAL_CALL get() const
74 { return m_xController; }
75
80 css::security::XAccessController * SAL_CALL operator -> () const
81 { return m_xController.get(); }
82
83
90 void SAL_CALL checkRuntimePermission(
91 ::rtl::OUString const & name );
92
99 void SAL_CALL checkFilePermission(
100 ::rtl::OUString const & url,
101 ::rtl::OUString const & actions );
102
110 void SAL_CALL checkSocketPermission(
111 ::rtl::OUString const & host,
112 ::rtl::OUString const & actions );
113};
114
115}
116
117#endif
118
119/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
Helper class for retrieving access controller singleton from component context.
AccessControl(css::uno::Reference< css::security::XAccessController > const &xController)
Ctor.
void SAL_CALL clear()
Clears the access controller reference being used.
AccessControl(css::uno::Reference< css::uno::XComponentContext > const &xContext)
Ctor.
css::uno::Reference< css::security::XAccessController > m_xController
AccessControl(::cppu::AccessControl const &ac)
Copy ctor.
css::uno::Reference< css::security::XAccessController > const &SAL_CALL get() const
Returns access to the access controller reference being used.
#define CPPUHELPER_DLLPUBLIC
#define SAL_WARN_UNUSED