LibreOffice
LibreOffice 4.1 SDK C/C++ API Reference
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
security.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 #ifndef _OSL_SECURITY_HXX_
21 #define _OSL_SECURITY_HXX_
22 
23 #include <rtl/ustring.hxx>
24 
25 #ifndef _OSL_SECURITY_DECL_HXX
26 # include <osl/security_decl.hxx>
27 #endif
28 
29 namespace osl
30 {
31 
33 {
35 }
36 
38 {
40 }
41 
43  const rtl::OUString& strPasswd)
44 {
46 
47  m_handle = 0;
48 
49  return (osl_loginUser( strName.pData, strPasswd.pData, &m_handle)
51 }
52 
54  const rtl::OUString& strPasswd,
55  const rtl::OUString& strFileServer )
56 {
58 
59  m_handle = NULL;
60 
61  return (osl_loginUserOnFileServer(strName.pData, strPasswd.pData, strFileServer.pData, &m_handle)
63 }
64 
66 {
67  return osl_getUserIdent( m_handle, &strIdent.pData );
68 }
69 
70 
72 {
73  return osl_getUserName( m_handle, &strName.pData );
74 }
75 
76 
77 inline sal_Bool Security::getHomeDir( rtl::OUString& strDirectory) const
78 {
79  return osl_getHomeDir(m_handle, &strDirectory.pData );
80 }
81 
82 
83 inline sal_Bool Security::getConfigDir( rtl::OUString& strDirectory ) const
84 {
85  return osl_getConfigDir( m_handle, &strDirectory.pData );
86 }
87 
89 {
91 }
92 
94 {
95  return m_handle;
96 }
97 
98 
99 }
100 
101 #endif // _OSL_SECURITY_HXX_
102 
103 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
This String class provides base functionality for C++ like Unicode character array handling...
Definition: ustring.hxx:87
Security()
constructor
Definition: security.hxx:32
sal_Bool getUserName(rtl::OUString &strName) const
get the name of the logged in user.
Definition: security.hxx:71
SAL_DLLPUBLIC sal_Bool osl_isAdministrator(oslSecurity Security)
Query if the user who is denotes by this security has administrator rigths.
Definition: security.h:33
SAL_DLLPUBLIC sal_Bool osl_getConfigDir(oslSecurity Security, rtl_uString **strDirectory)
Get the directory for configuration data of the user of this security handle.
SAL_DLLPUBLIC sal_Bool osl_getUserName(oslSecurity Security, rtl_uString **strName)
Get the login name for the user of this security handle.
sal_Bool getUserIdent(rtl::OUString &strIdent) const
get the ident of the logged in user.
Definition: security.hxx:65
oslSecurity getHandle() const
Returns the underlying oslSecurity handle.
Definition: security.hxx:93
SAL_DLLPUBLIC oslSecurity osl_getCurrentSecurity(void)
Create a security handle for the current user.
sal_Bool getConfigDir(rtl::OUString &strDirectory) const
get the directory for configuration data of the logged in user.
Definition: security.hxx:83
sal_Bool getHomeDir(rtl::OUString &strDirectory) const
get the home directory of the logged in user.
Definition: security.hxx:77
SAL_DLLPUBLIC sal_Bool osl_getUserIdent(oslSecurity Security, rtl_uString **strIdent)
Get the login ident for the user of this security handle.
sal_Bool logonUser(const rtl::OUString &strName, const rtl::OUString &strPasswd)
get the security information for one user.
Definition: security.hxx:42
unsigned char sal_Bool
Definition: types.h:37
SAL_DLLPUBLIC oslSecurityError osl_loginUser(rtl_uString *strUserName, rtl_uString *strPasswd, oslSecurity *pSecurity)
Deprecated API Create a security handle for the denoted user.
oslSecurity m_handle
Definition: security_decl.hxx:37
SAL_DLLPUBLIC void osl_freeSecurityHandle(oslSecurity Security)
Free the security handle, created by osl_loginUser or osl_getCurrentSecurity.
~Security()
destructor
Definition: security.hxx:37
void * oslSecurity
Process handle.
Definition: security.h:45
SAL_DLLPUBLIC sal_Bool osl_getHomeDir(oslSecurity Security, rtl_uString **strDirectory)
Get the home directory of the user of this security handle.
SAL_DLLPUBLIC oslSecurityError osl_loginUserOnFileServer(rtl_uString *strUserName, rtl_uString *strPasswd, rtl_uString *strFileServer, oslSecurity *pSecurity)
Create a security handle for the denoted user.
sal_Bool isAdministrator() const
Query if the user who is logged inhas administrator rigths.
Definition: security.hxx:88