summaryrefslogtreecommitdiff
path: root/mail/horde3-turba/files/patch-config__sources.php.dist
diff options
context:
space:
mode:
Diffstat (limited to 'mail/horde3-turba/files/patch-config__sources.php.dist')
-rw-r--r--mail/horde3-turba/files/patch-config__sources.php.dist210
1 files changed, 210 insertions, 0 deletions
diff --git a/mail/horde3-turba/files/patch-config__sources.php.dist b/mail/horde3-turba/files/patch-config__sources.php.dist
new file mode 100644
index 000000000000..aeb73b0e369d
--- /dev/null
+++ b/mail/horde3-turba/files/patch-config__sources.php.dist
@@ -0,0 +1,210 @@
+--- config/sources.php.dist.orig 2007-11-19 08:05:01.000000000 -0900
++++ config/sources.php.dist 2007-12-03 23:35:17.000000000 -0900
+@@ -636,105 +636,108 @@
+ // configuration at all - in case we don't have at least a 3.0.6 Horde
+ // install. (In that case, be sure to change the params array below to suit
+ // your needs.
+-if (!empty($GLOBALS['conf']['imsp']['enabled']) ||
+- !isset($GLOBALS['conf']['imsp']['enabled'])) {
+- // First, get the user name to login to IMSP server with.
+- $_imsp_auth_user = $GLOBALS['prefs']->getValue('imsp_auth_user');
+- $_imsp_auth_pass = $GLOBALS['prefs']->getValue('imsp_auth_pass');
+- if (!strlen($_imsp_auth_user)) {
+- $_imsp_auth_user = Auth::getBareAuth();
+- $_imsp_auth_pass = Auth::getCredential('password');
+- }
+- $cfgSources['imsp'] = array(
+- 'title' => _("IMSP"),
+- 'type' => 'imsp',
+- 'params' => array(
+- 'server' => $GLOBALS['conf']['imsp']['server'],
+- 'port' => $GLOBALS['conf']['imsp']['port'],
+- 'auth_method' => $GLOBALS['conf']['imsp']['auth_method'],
+- // socket, command, and auth_mechanism are for imtest driver.
+- 'socket' => isset($GLOBALS['conf']['imsp']['socket']) ?
+- $GLOBALS['conf']['imsp']['socket'] . $_imsp_auth_user . '.sck' :
+- '',
+- 'command' => isset($GLOBALS['conf']['imsp']['command']) ?
+- $GLOBALS['conf']['imsp']['command'] : '' ,
+- 'auth_mechanism' => isset($GLOBALS['conf']['imsp']['auth_mechanism']) ?
+- $GLOBALS['conf']['imsp']['auth_mechanism'] : '',
+- 'username' => $_imsp_auth_user,
+- 'password' => $_imsp_auth_pass,
+- 'name' => $_imsp_auth_user,
+- 'group_id_field' => 'group',
+- 'group_id_value' => 'group',
+- 'contact_ownership' => false,
+- // Dynamically generated acl rights for current user.
+- 'my_rights' => '',
+- ),
+- 'map' => array(
+- '__key' => 'name',
+- '__type' => '__type',
+- '__members' => '__members',
+- '__owner' => '__owner',
+- '__uid' => '__uid',
+- 'name' => 'fullname',
+- 'email' => 'email',
+- 'alias' => 'alias',
+- 'company' => 'company',
+- 'notes' => 'notes',
+- 'workPhone' => 'phone-work',
+- 'fax' => 'fax',
+- 'homePhone' => 'phone-home',
+- 'cellPhone' => 'cellphone',
+- 'freebusyUrl' => 'freebusyUrl'
+- ),
+- 'search' => array(
+- 'name',
+- 'email',
+- 'alias',
+- 'company',
+- 'homePhone'
+- ),
+- 'strict' => array(),
+- 'export' => true,
+- 'browse' => true,
+- 'use_shares' => false,
+- );
+-
+- /**
+- * Get any other address books this user might be privy to.
+- * The values for attributes such as 'export' and 'browse' for books
+- * that are added below will be the same as the values set in the default
+- * book above. Any entries defined explicitly in cfgSources[]
+- * will override any entries gathered dynamically below.
+- */
+- if (empty($cfgSources['imsp']['use_shares'])) {
+- require_once 'Net/IMSP/Utils.php';
+- $result = Net_IMSP_Utils::getAllBooks($cfgSources['imsp']);
+-
+- if (!is_a($result, 'PEAR_Error')) {
+- $resultCount = count($result);
+- for ($i = 0; $i < $resultCount; $i++) {
+- // Make sure we didn't define this source explicitly,
+- // but set the acls from the server regardless.
+- $dup = false;
+- foreach ($cfgSources as $key => $thisSource) {
+- if (($thisSource['type'] == 'imsp') &&
+- ($thisSource['params']['name'] == $result[$i]['params']['name'])) {
+-
+- $dup = true;
+- $acl = $result[$i]['params']['my_rights'];
+- $cfgSources[$key]['params']['my_rights'] = $acl;
+- break;
+- }
+- }
+- if (!$dup) {
+- $cfgSources[$result[$i]['params']['name']] = $result[$i];
+- }
+- }
+- } else {
+- $notification->push($result);
+- }
+- }
+-}
++//UNCOMMENTIFIMSPif (!empty($GLOBALS['conf']['imsp']['enabled']) ||
++//UNCOMMENTIFIMSP !isset($GLOBALS['conf']['imsp']['enabled'])) {
++//UNCOMMENTIFIMSP // First, get the user name to login to IMSP server with.
++//UNCOMMENTIFIMSP $uid = $GLOBALS['prefs']->getValue('imsp_auth_user');
++//UNCOMMENTIFIMSP $pass = $GLOBALS['prefs']->getValue('imsp_auth_pass');
++//UNCOMMENTIFIMSP if (!strlen($uid)) {
++//UNCOMMENTIFIMSP $uid = Auth::getBareAuth();
++//UNCOMMENTIFIMSP $pass = Auth::getCredential('password');
++//UNCOMMENTIFIMSP }
++//UNCOMMENTIFIMSP // Note we always use the horde username to append to the key even if we
++//UNCOMMENTIFIMSP // have an alternate username set in prefs. This is to prevent the
++//UNCOMMENTIFIMSP // (fringe) case where an IMSP username for one user might be a valid
++//UNCOMMENTIFIMSP // horde username for another user.
++//UNCOMMENTIFIMSP $cfgKey = 'IMSP_' . Auth::getAuth();
++//UNCOMMENTIFIMSP $cfgSources[$cfgKey] = array(
++//UNCOMMENTIFIMSP 'title' => _("IMSP"),
++//UNCOMMENTIFIMSP 'type' => 'imsp',
++//UNCOMMENTIFIMSP 'params' => array(
++//UNCOMMENTIFIMSP 'server' => $GLOBALS['conf']['imsp']['server'],
++//UNCOMMENTIFIMSP 'port' => $GLOBALS['conf']['imsp']['port'],
++//UNCOMMENTIFIMSP 'auth_method' => $GLOBALS['conf']['imsp']['auth_method'],
++//UNCOMMENTIFIMSP // socket, command, and auth_mechanism are for imtest driver.
++//UNCOMMENTIFIMSP 'socket' => isset($GLOBALS['conf']['imsp']['socket']) ?
++//UNCOMMENTIFIMSP $GLOBALS['conf']['imsp']['socket'] . $uid . '.sck' :
++//UNCOMMENTIFIMSP '',
++//UNCOMMENTIFIMSP 'command' => isset($GLOBALS['conf']['imsp']['command']) ?
++//UNCOMMENTIFIMSP $GLOBALS['conf']['imsp']['command'] : '' ,
++//UNCOMMENTIFIMSP 'auth_mechanism' => isset($GLOBALS['conf']['imsp']['auth_mechanism']) ?
++//UNCOMMENTIFIMSP $GLOBALS['conf']['imsp']['auth_mechanism'] : '',
++//UNCOMMENTIFIMSP 'username' => $uid,
++//UNCOMMENTIFIMSP 'password' => $pass,
++//UNCOMMENTIFIMSP 'name' => $uid,
++//UNCOMMENTIFIMSP 'group_id_field' => 'group',
++//UNCOMMENTIFIMSP 'group_id_value' => 'group',
++//UNCOMMENTIFIMSP 'contact_ownership' => false,
++//UNCOMMENTIFIMSP // Dynamically generated acl rights for current user.
++//UNCOMMENTIFIMSP 'my_rights' => '',
++//UNCOMMENTIFIMSP // Flags this as the user's 'root' IMSP address book.
++//UNCOMMENTIFIMSP 'is_root' => true
++//UNCOMMENTIFIMSP ),
++//UNCOMMENTIFIMSP 'map' => array(
++//UNCOMMENTIFIMSP '__key' => 'name',
++//UNCOMMENTIFIMSP '__type' => '__type',
++//UNCOMMENTIFIMSP '__members' => '__members',
++//UNCOMMENTIFIMSP '__owner' => '__owner',
++//UNCOMMENTIFIMSP '__uid' => '__uid',
++//UNCOMMENTIFIMSP 'name' => 'fullname',
++//UNCOMMENTIFIMSP 'email' => 'email',
++//UNCOMMENTIFIMSP 'alias' => 'alias',
++//UNCOMMENTIFIMSP 'company' => 'company',
++//UNCOMMENTIFIMSP 'notes' => 'notes',
++//UNCOMMENTIFIMSP 'workPhone' => 'phone-work',
++//UNCOMMENTIFIMSP 'fax' => 'fax',
++//UNCOMMENTIFIMSP 'homePhone' => 'phone-home',
++//UNCOMMENTIFIMSP 'cellPhone' => 'cellphone',
++//UNCOMMENTIFIMSP 'freebusyUrl' => 'freebusyUrl'
++//UNCOMMENTIFIMSP ),
++//UNCOMMENTIFIMSP 'search' => array(
++//UNCOMMENTIFIMSP 'name',
++//UNCOMMENTIFIMSP 'email',
++//UNCOMMENTIFIMSP 'alias',+//UNCOMMENTIFIMSP 'company',
++//UNCOMMENTIFIMSP 'homePhone'
++//UNCOMMENTIFIMSP ),
++//UNCOMMENTIFIMSP 'strict' => array(),
++//UNCOMMENTIFIMSP 'export' => true,
++//UNCOMMENTIFIMSP 'browse' => true,
++//UNCOMMENTIFIMSP );
++//UNCOMMENTIFIMSP
++//UNCOMMENTIFIMSP /**
++//UNCOMMENTIFIMSP * Get any other address books this user might be privy to.
++//UNCOMMENTIFIMSP * The values for attributes such as 'export' and 'browse' for books
++//UNCOMMENTIFIMSP * that are added below will be the same as the values set in the default
++//UNCOMMENTIFIMSP * book above. Any entries defined explicitly in cfgSources[]
++//UNCOMMENTIFIMSP * will override any entries gathered dynamically below.
++//UNCOMMENTIFIMSP */
++//UNCOMMENTIFIMSP require_once 'Net/IMSP/Utils.php';
++//UNCOMMENTIFIMSP $result = Net_IMSP_Utils::getAllBooks($cfgSources[$cfgKey]);
++//UNCOMMENTIFIMSP $count = 2;
++//UNCOMMENTIFIMSP if (!is_a($result, 'PEAR_Error')) {
++//UNCOMMENTIFIMSP $resultCount = count($result);
++//UNCOMMENTIFIMSP for ($i = 0; $i < $resultCount; $i++) {
++//UNCOMMENTIFIMSP // Make sure we didn't define this source explicitly,
++//UNCOMMENTIFIMSP // but set the acls from the server regardless.
++//UNCOMMENTIFIMSP $dup = false;
++//UNCOMMENTIFIMSP foreach ($cfgSources as $key => $thisSource) {
++//UNCOMMENTIFIMSP if (($thisSource['type'] == 'imsp') &&
++//UNCOMMENTIFIMSP ($thisSource['params']['name'] == $result[$i]['params']['name'])) {
++//UNCOMMENTIFIMSP
++//UNCOMMENTIFIMSP $dup = true;
++//UNCOMMENTIFIMSP $acl = $result[$i]['params']['my_rights'];
++//UNCOMMENTIFIMSP $cfgSources[$key]['params']['my_rights'] = $acl;
++//UNCOMMENTIFIMSP break;
++//UNCOMMENTIFIMSP }
++//UNCOMMENTIFIMSP }
++//UNCOMMENTIFIMSP if (!$dup) {
++//UNCOMMENTIFIMSP $cfgSources[sprintf('IMSP_%d', $count++)] = $result[$i];
++//UNCOMMENTIFIMSP }
++//UNCOMMENTIFIMSP }
++//UNCOMMENTIFIMSP } else {
++//UNCOMMENTIFIMSP $notification->push($result);
++//UNCOMMENTIFIMSP }
++//UNCOMMENTIFIMSP}
+ /* End IMSP sources. */
+
+ /* Begin Kolab sources. */