Page Menu
Home
Phorge
Search
Configure Global Search
Log In
Files
F2522363
DirectoryLDAP.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Flag For Later
Award Token
Size
3 KB
Referenced Files
None
Subscribers
None
DirectoryLDAP.php
View Options
<?php
/**
* This file is part of the Kolab Server Free/Busy Service
*
* @author Thomas Bruederli <bruederli@kolabsys.com>
*
* Copyright (C) 2013, Kolab Systems AG <contact@kolabsys.com>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
namespace
Kolab\FreeBusy
;
// PEAR modules operate in global namespace
use
\Net_LDAP3
;
use
\Monolog\Logger
as
Monolog
;
/**
* Implementation of an address lookup using an LDAP directory
*/
class
DirectoryLDAP
extends
Directory
{
private
$ldap
;
private
$logger
;
private
$ready
=
false
;
/**
* Default constructor loading directory configuration
*/
public
function
__construct
(
$config
)
{
$this
->
config
=
$config
;
$host
=
parse_url
(
$config
[
'host'
]);
$ldap_config
=
array
(
'hosts'
=>
array
(
$host
[
'host'
]),
'port'
=>
$host
[
'port'
]
?:
389
,
'use_tls'
=>
$host
[
'scheme'
]
==
'tls'
||
$host
[
'scheme'
]
==
'ldaps'
,
'root_dn'
=>
$config
[
'base_dn'
],
'return_attributes'
=>
(
array
)
$config
[
'attributes'
],
'log_hook'
=>
array
(
$this
,
'log'
),
)
+
$config
;
// instantiate Net_LDAP3 and connect with logger
$this
->
logger
=
Logger
::
get
(
'ldap'
,
intval
(
$config
[
'loglevel'
]));
$this
->
ldap
=
new
Net_LDAP3
(
$ldap_config
);
// connect + bind to LDAP server
if
(
$this
->
ldap
->
connect
())
{
$this
->
ready
=
$this
->
ldap
->
bind
(
$config
[
'bind_dn'
],
$config
[
'bind_pw'
]);
}
if
(
$this
->
ready
)
{
$this
->
logger
->
addInfo
(
"Connected to $config[host] with '$config[bind_dn]'"
);
}
else
{
$this
->
logger
->
addWarning
(
"Connectiion to $config[host] with '$config[bind_dn]' failed!"
);
}
}
/**
* Callback for Net_LDAP3 logging
*/
public
function
log
(
$level
,
$msg
)
{
// map PHP log levels to Monolog levels
static
$loglevels
=
array
(
LOG_DEBUG
=>
Monolog
::
DEBUG
,
LOG_NOTICE
=>
Monolog
::
NOTICE
,
LOG_INFO
=>
Monolog
::
INFO
,
LOG_WARNING
=>
Monolog
::
WARNING
,
LOG_ERR
=>
Monolog
::
ERROR
,
LOG_CRIT
=>
Monolog
::
CRITICAL
,
LOG_ALERT
=>
Monolog
::
ALERT
,
LOG_EMERG
=>
Monolog
::
EMERGENCY
,
);
$msg
=
is_array
(
$msg
)
?
join
(
'; '
,
$msg
)
:
strval
(
$msg
);
$this
->
logger
->
addRecord
(
$loglevels
[
$level
],
$msg
);
}
/**
* @see Directory::resolve()
*/
public
function
resolve
(
$user
)
{
$result
=
array
(
's'
=>
$user
);
if
(
$this
->
ready
)
{
// search with configured filter
$filter
=
preg_replace
(
'/%s/i'
,
$user
,
$this
->
config
[
'filter'
]);
$ldapresult
=
$this
->
ldap
->
search
(
$this
->
config
[
'base_dn'
],
$filter
,
'sub'
);
// got a valid result
if
(
$ldapresult
&&
$ldapresult
->
count
())
{
$ldapresult
->
rewind
();
$entry
=
Net_LDAP3
::
normalize_entry
(
$ldapresult
->
current
());
// get the first entry
$this
->
logger
->
addInfo
(
"Found "
.
$ldapresult
->
count
()
.
" entries for $filter"
,
$entry
);
// convert entry attributes to strings and add them to the final result hash array
foreach
(
$entry
as
$k
=>
$v
)
{
if
(!
empty
(
$v
))
{
$result
[
$k
]
=
strval
(
is_array
(
$v
)
?
$v
[
0
]
:
$v
);
}
}
return
$result
;
}
$this
->
logger
->
addInfo
(
"No entry found for $filter"
);
}
return
false
;
}
}
File Metadata
Details
Attached
Mime Type
text/x-php
Expires
Sun, Jan 11, 4:10 AM (5 h, 57 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
421954
Default Alt Text
DirectoryLDAP.php (3 KB)
Attached To
Mode
R28 freebusy
Attached
Detach File
Event Timeline
Log In to Comment