1
0
mirror of https://github.com/owncloudarchive/contacts.git synced 2025-01-18 07:52:21 +01:00

186 lines
4.5 KiB
PHP
Raw Normal View History

2012-01-15 11:40:32 +01:00
<?php
/**
* Copyright (c) 2012 Georg Ehrke <ownclouddev at georgswebsite dot de>
* This file is licensed under the Affero General Public License version 3 or
* later.
* See the COPYING-README file.
*/
namespace OCA\Contacts;
use Sabre\VObject;
2012-01-15 11:47:35 +01:00
//check for addressbooks rights or create new one
2012-01-15 11:40:32 +01:00
ob_start();
2012-09-07 14:32:45 +02:00
\OCP\JSON::checkLoggedIn();
\OCP\App::checkAppEnabled('contacts');
session_write_close();
2012-01-15 11:40:32 +01:00
$nl = "\n";
2012-05-29 23:40:26 +02:00
global $progresskey;
$progresskey = 'contacts.import-' . (isset($_GET['progresskey'])?$_GET['progresskey']:'');
if (isset($_GET['progress']) && $_GET['progress']) {
echo \OC_Cache::get($progresskey);
die;
}
function writeProgress($pct) {
global $progresskey;
\OC_Cache::set($progresskey, $pct, 300);
2012-01-15 11:40:32 +01:00
}
writeProgress('10');
$view = $file = null;
if(isset($_POST['fstype']) && $_POST['fstype'] == 'OC_FilesystemView') {
$view = \OCP\Files::getStorage('contacts');
2012-07-15 04:15:57 +02:00
$file = $view->file_get_contents('/imports/' . $_POST['file']);
} else {
2012-10-10 13:18:05 +02:00
$file = \OC\Files\Filesystem::file_get_contents($_POST['path'] . '/' . $_POST['file']);
}
if(!$file) {
\OCP\JSON::error(array('data' => array('message' => 'Import file was empty.')));
exit();
}
2012-07-20 17:09:03 +02:00
if(isset($_POST['method']) && $_POST['method'] == 'new') {
$id = Addressbook::add(\OCP\USER::getUser(),
2012-07-20 17:09:03 +02:00
$_POST['addressbookname']);
if(!$id) {
\OCP\JSON::error(
2012-07-20 17:09:03 +02:00
array(
'data' => array('message' => 'Error creating address book.')
)
);
exit();
}
Addressbook::setActive($id, 1);
2012-01-15 11:40:32 +01:00
}else{
$id = $_POST['id'];
if(!$id) {
\OCP\JSON::error(
2012-07-20 17:09:03 +02:00
array(
'data' => array(
2012-09-07 14:32:45 +02:00
'message' => 'Error getting the ID of the address book.',
2012-07-20 17:09:03 +02:00
'file'=>$_POST['file']
)
)
);
exit();
}
2012-10-05 05:05:49 +02:00
try {
Addressbook::find($id); // is owner access check
} catch(\Exception $e) {
\OCP\JSON::error(
2012-10-05 05:05:49 +02:00
array(
'data' => array(
'message' => $e->getMessage(),
'file'=>$_POST['file']
)
)
);
exit();
}
2012-01-15 11:40:32 +01:00
}
2012-01-15 11:47:35 +01:00
//analyse the contacts file
2012-05-29 23:40:26 +02:00
writeProgress('40');
2012-07-15 04:15:57 +02:00
$file = str_replace(array("\r","\n\n"), array("\n","\n"), $file);
2012-05-29 23:40:26 +02:00
$lines = explode($nl, $file);
2012-01-15 11:40:32 +01:00
$inelement = false;
$parts = array();
2012-05-29 23:40:26 +02:00
$card = array();
2012-09-07 15:21:03 +02:00
foreach($lines as $line) {
2012-07-20 17:09:03 +02:00
if(strtoupper(trim($line)) == 'BEGIN:VCARD') {
2012-05-29 23:40:26 +02:00
$inelement = true;
} elseif (strtoupper(trim($line)) == 'END:VCARD') {
$card[] = $line;
2012-05-29 23:40:26 +02:00
$parts[] = implode($nl, $card);
$card = array();
$inelement = false;
2012-01-15 11:40:32 +01:00
}
2012-05-29 23:40:26 +02:00
if ($inelement === true && trim($line) != '') {
$card[] = $line;
2012-01-15 11:40:32 +01:00
}
}
2012-05-29 23:40:26 +02:00
//import the contacts
writeProgress('70');
$imported = 0;
$failed = 0;
$partial = 0;
2012-05-29 23:40:26 +02:00
if(!count($parts) > 0) {
\OCP\JSON::error(
2012-07-20 17:09:03 +02:00
array(
'data' => array(
'message' => 'No contacts to import in '
2012-09-07 14:32:45 +02:00
. $_POST['file'].'. Please check if the file is corrupted.',
2012-07-20 17:09:03 +02:00
'file'=>$_POST['file']
)
)
);
2012-07-15 17:34:30 +02:00
if(isset($_POST['fstype']) && $_POST['fstype'] == 'OC_FilesystemView') {
if(!$view->unlink('/imports/' . $_POST['file'])) {
\OCP\Util::writeLog('contacts',
2012-09-07 14:32:45 +02:00
'Import: Error unlinking OC_FilesystemView ' . '/' . $_POST['file'],
\OCP\Util::ERROR);
2012-07-15 17:34:30 +02:00
}
}
exit();
}
2012-09-07 15:21:03 +02:00
foreach($parts as $part) {
2012-11-22 00:14:03 +01:00
try {
$vcard = VObject\Reader::read($part);
} catch (VObject\ParseException $e) {
try {
$vcard = VObject\Reader::read($part, VObject\Reader::OPTION_IGNORE_INVALID_LINES);
$partial += 1;
\OCP\Util::writeLog('contacts',
'Import: Retrying reading card. Error parsing VCard: ' . $e->getMessage(),
\OCP\Util::ERROR);
} catch (\Exception $e) {
$failed += 1;
\OCP\Util::writeLog('contacts',
'Import: skipping card. Error parsing VCard: ' . $e->getMessage(),
\OCP\Util::ERROR);
continue; // Ditch cards that can't be parsed by Sabre.
}
2012-01-15 11:40:32 +01:00
}
2012-05-29 23:40:26 +02:00
try {
$vcard->validate(VCard::REPAIR|VCard::UPGRADE);
} catch (\Exception $e) {
OCP\Util::writeLog('contacts', __LINE__ . ' ' .
'Error validating vcard: ' . $e->getMessage() . $nl . $vcard->serialize(),
\OCP\Util::ERROR);
$failed += 1;
}
try {
VCard::add($id, $vcard);
2012-05-29 23:40:26 +02:00
$imported += 1;
} catch (\Exception $e) {
\OCP\Util::writeLog('contacts', __LINE__ . ' ' .
'Error importing vcard: ' . $e->getMessage() . $nl . $vcard->serialize(),
\OCP\Util::ERROR);
2012-05-29 23:40:26 +02:00
$failed += 1;
}
2012-01-15 11:40:32 +01:00
}
//done the import
writeProgress('100');
2012-01-15 11:40:32 +01:00
sleep(3);
\OC_Cache::remove($progresskey);
if(isset($_POST['fstype']) && $_POST['fstype'] == 'OC_FilesystemView') {
2012-07-15 12:22:14 +02:00
if(!$view->unlink('/imports/' . $_POST['file'])) {
\OCP\Util::writeLog('contacts',
2012-09-07 14:32:45 +02:00
'Import: Error unlinking OC_FilesystemView ' . '/' . $_POST['file'],
\OCP\Util::ERROR);
}
}
\OCP\JSON::success(
2012-07-20 17:09:03 +02:00
array(
'data' => array(
2012-09-07 14:32:45 +02:00
'imported'=>$imported,
'failed'=>$failed,
2012-07-20 17:09:03 +02:00
'file'=>$_POST['file'],
)
)
);