From 4171e4ada3dae464d1688088168318416899dbce Mon Sep 17 00:00:00 2001 From: Miles Lott Date: Sun, 11 Mar 2001 06:07:32 +0000 Subject: [PATCH] Moving to contacts class for Import, so no distinction per LDAP/SQL is needed for the actual import. --- ...ressbook (MySQL) => Import to Addressbook} | 38 +-- addressbook/conv/Import to LDAP | 253 ------------------ 2 files changed, 19 insertions(+), 272 deletions(-) rename addressbook/conv/{Import to Addressbook (MySQL) => Import to Addressbook} (85%) delete mode 100644 addressbook/conv/Import to LDAP diff --git a/addressbook/conv/Import to Addressbook (MySQL) b/addressbook/conv/Import to Addressbook similarity index 85% rename from addressbook/conv/Import to Addressbook (MySQL) rename to addressbook/conv/Import to Addressbook index 37e1ee57e5..8ae7661404 100644 --- a/addressbook/conv/Import to Addressbook (MySQL) +++ b/addressbook/conv/Import to Addressbook @@ -27,14 +27,14 @@ class outlook_conv { var $currentrecord; //used for buffering to allow uid lines to go first var $outlook = array( - "Title" => "TITLE", - "First Name" => "N_Given", - "Middle Name" => "N_Middle", - "Last Name" => "N_Family", - "Suffix" => "N_Suffix", - "Company" => "ORG_Name", //objectclass: organization - "Department" => "ORG_Unit", //objectclass: organizationalPerson - "Job Title" => "TITLE", //objectclass: organizationalPerson + "Title" => "title", + "First Name" => "n_given", + "Middle Name" => "n_middle", + "Last Name" => "n_family", + "Suffix" => "n_suffix", + "Company" => "org_name", //objectclass: organization + "Department" => "org_unit", //objectclass: organizationalPerson + "Job Title" => "title", //objectclass: organizationalPerson "Business Street" => "address2", "Business Street 2" => "", "Business Street 3" => "", @@ -42,11 +42,11 @@ class outlook_conv { "Business State" => "", "Business Postal Code" => "", "Business Country" => "", - "Home Street" => "ADR_Street", - "Home City" => "ADR_Locality", - "Home State" => "ADR_Region", - "Home Postal Code" => "ADR_PostalCode", - "Home Country" => "ADR_CountryName", + "Home Street" => "adr_street", + "Home City" => "adr_locality", + "Home State" => "adr_region", + "Home Postal Code" => "adr_postalcode", + "Home Country" => "adr_countryname", "Home Street 2" => "", "Home Street 3" => "", "Other Street" => "", @@ -55,14 +55,14 @@ class outlook_conv { "Other Postal Code" => "", "Other Country" => "", "Assistant's Phone" => "", - "Business Fax" => "C_TEL", - "Business Phone" => "B_TEL", + "Business Fax" => "c_tel", + "Business Phone" => "b_tel", "Business Phone 2" => "ophone", "Callback" => "", "Car Phone" => "", "Company Main Phone" => "", "Home Fax" => "", - "Home Phone" => "A.TEL", + "Home Phone" => "a_tel", "Home Phone 2" => "", //This will make another homePhone entry "ISDN" => "", "Mobile Phone" => "mphone", //newPilotPerson @@ -81,7 +81,7 @@ class outlook_conv { "Categories" => "", "Children" => "", "Directory Server" => "", - "E-mail Address" => "D_EMAIL", + "E-mail Address" => "d_email", "E-mail Display Name" => "", "E-mail 2 Address" => "", "E-mail 2 Display Name" => "", @@ -97,10 +97,10 @@ class outlook_conv { "Location" => "", "Manager's Name" => "", "Mileage" => "", - "Notes" => "ab_notes", + "Notes" => "note", "Office Location" => "", "Organizational ID Number" => "", - "PO Box" => "postOfficeBox", + "PO Box" => "", "Priority" => "", "Private Profession" => "", "Referred By" => "", diff --git a/addressbook/conv/Import to LDAP b/addressbook/conv/Import to LDAP deleted file mode 100644 index b4dcfbf798..0000000000 --- a/addressbook/conv/Import to LDAP +++ /dev/null @@ -1,253 +0,0 @@ -First NameMiddle NameLast Name... -// PatrickWalsh... -// -// Where the first line explains each optional field. This is what -// will be looked up in the key. -// -// The array need not be in any order and any fields not defined will -// not be transferred. If the val='+', the value will be appended to -// the previous field and any text after the '+' will be appended -// before the value. For example, the following would add a comma and -// a space between LastName and FirstName and store it in FullName: -// -// array("LastName" => "FullName","FirstName" => "+, "); -// -// Also start with a '#' symbol and a comma separated list will be -// turned into a number of the same entries. - -class outlook_conv { - var $basedn; - var $contactsdn; - - var $sn; //these two vars will be used in - var $o; //building a dn field. - var $givenName; //this is used in building a cn field - var $currentrecord; //used for buffering to allow uid lines to go first - - var $outlook = array( - "Title" => "", - "First Name" => "givenName", - "Middle Name" => "", - "Last Name" => "sn", - "Suffix" => "", - "Company" => "o", //objectclass: organization - "Department" => "ou", //objectclass: organizationalPerson - "Job Title" => "title", //objectclass: organizationalPerson - "Business Street" => "postalAddress", - "Business Street 2" => "", - "Business Street 3" => "", - "Business City" => "l", - "Business State" => "st", - "Business Postal Code" => "postalCode", - "Business Country" => "co", - "Home Street" => "homePostalAddress", - "Home City" => "+\n", - "Home State" => "+, ", - "Home Postal Code" => "+ ", - "Home Country" => "+\n", - "Home Street 2" => "", - "Home Street 3" => "", - "Other Street" => "", - "Other City" => "+\n", - "Other State" => "+, ", - "Other Postal Code" => "+ ", - "Other Country" => "+\n", - "Assistant's Phone" => "", - "Business Fax" => "facsimileTelephoneNumber", - "Business Phone" => "telephoneNumber", - "Business Phone 2" => "", - "Callback" => "", - "Car Phone" => "", - "Company Main Phone" => "", - "Home Fax" => "", - "Home Phone" => "homePhone", - "Home Phone 2" => "homePhone", //This will make another homePhone entry - "ISDN" => "", - "Mobile Phone" => "mobile", //newPilotPerson - "Other Fax" => "", - "Other Phone" => "", - "Pager" => "pager", - "Primary Phone" => "", - "Radio Phone" => "", - "TTY/TDD Phone" => "", - "Telex" => "telexNumber", //organization - "Account" => "", - "Anniversary" => "", - "Assistant's Name" => "secretary", //newPilotPerson - "Billing Information" => "", - "Birthday" => "", - "Categories" => "#businessCategory", - "Children" => "", - "Directory Server" => "", - "E-mail Address" => "mail", - "E-mail Display Name" => "", - "E-mail 2 Address" => "otherMailbox", - "E-mail 2 Display Name" => "", - "E-mail 3 Address" => "otherMailbox", //add another... - "E-mail 3 Display Name" => "", - "Gender" => "", - "Government ID Number" => "", - "Hobby" => "", - "Initials" => "", - "Internet Free Busy" => "", - "Keywords" => "", - "Language" => "", - "Location" => "", - "Manager's Name" => "", - "Mileage" => "", - "Notes" => "comment", - "Office Location" => "physicalDeliveryOfficeName", - "Organizational ID Number" => "", - "PO Box" => "postOfficeBox", - "Priority" => "", - "Private Profession" => "", - "Referred By" => "", - "Sensitivity" => "", - "Spouse" => "", - "User 1" => "", - "User 2" => "", - "User 3" => "", - "User 4" => "", - "Web Page" => ""); - -function outlook_start_file($buffer,$basedn="",$context="") { - # Here are some tests for correct basedn and Contacts context. - # If none of these are correct, ldap_add will fail, but at least - # we can give them a fighting chance. - if (!empty($basedn) && empty($context)) { - # Oops, no context, try a default - $context = "ou=Contacts,".$basedn; - } elseif (empty($basedn) && !empty($context)) { - # Oops, no basedn, try this one - $work = split(",",$context); - array_shift($work); - for ($i=0;$ibasedn= $basedn; - $this->contactsdn= $context; - - return $buffer; -} - -function outlook_end_file($buffer) { - $i="zarro"; - return "Successfully imported $i records into LDAP."; -} - -function outlook_start_record($buffer) { - global $phpgw_info; - - $top="\nobjectClass: person -objectClass: organizationalPerson -objectClass: inetOrgPerson -objectClass: outlookPerson"; - - $this->o=""; - $this->sn=""; - $this->givenName=""; - - $this->currentrecord = $top; - return $buffer; -} - -function outlook_end_record($buffer,$private="") { - if (trim($this->sn) != "") { - $this->currentrecord = "cn: ".$this->givenName." ".$this->sn.$this->currentrecord; - } else if (trim($this->o) != "") { - $this->currentrecord = "cn: ".$this->o.$this->currentrecord; - } else if (trim($this->givenName)) { - $this->currentrecord = "cn: ".$this->givenName.$this->currentrecord; - } else { - $this->currentrecord = "cn: (unnamed)".$this->currentrecord; - } - - $time = gettimeofday(); - $uid = ($this->sn?$this->sn:$this->o); - if (strpos($uid, ",")) { - $uid = str_replace(",", "\,", $uid); - $uid = "\"".$uid."\""; - } - $uid = time().$time["usec"].":".$uid; - $this->currentrecord = "dn: uid=$uid,".$this->contactsdn."\nuid: $uid"."\n".$this->currentrecord; - - while ($pos = strpos($this->currentrecord, "|br x=y/|")) { - $startline = strrpos(substr($this->currentrecord,0,$pos), "\n"); - if ($startline == "") {$startline = 0;} - $startattrib = strpos($this->currentrecord, ":", $startline) + 1; - $endline = strpos($this->currentrecord, "\n", $startattrib); - if ($endline == "") { $endline = strlen($this->currentrecord); } - $attrib = str_replace("|br x=y/|", "\r\n", substr($this->currentrecord, $startattrib + 1, $endline - $startattrib - 1)); - $this->currentrecord = substr($this->currentrecord, 0, $startattrib).": ".base64_encode($attrib).substr($this->currentrecord, $endline); - } - return $buffer.$this->currentrecord."\n\n"; -} - -function outlook_new_attrib($buffer,$name,$value) { - if ($name == "sn") { - $this->sn = $value; - } - if ($name == "o") { - $this->o = $value; - } - if ($name == "givenName") { - $this->givenName = $value; - } - - $value = str_replace("\n","|br x=y/|",$value); - $name = str_replace("\n","|br x=y/|",$name); - $value = str_replace("\r","",$value); - $name = str_replace("\r","",$name); - - switch (substr($name,0,1)) { - case '+': - $this->currentrecord .= substr($name,1).$value; - return $buffer; - break; - case '#': - $data = explode(";",$value); - $num = count($data); - $return = ""; - for ( $i=0; $i<$num; $i++ ) { - $return .= "\n".substr($name,1).": $data[$i]"; - } - $this->currentrecord .= $return; - return $buffer; - break; - default: - if ($name == "otherMailbox") { - $this->currentrecord .= "\n$name: smtp\$$value"; - } else { - $this->currentrecord .= "\n$name: $value"; - } - return $buffer; - } -} -} -?>