X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=mod%2Fuexport.php;h=cada539bcd251071f4d7ce3fedbb27c87aebb4ee;hb=fb94a0add71642b08bab610d1cfb70eab4598ffc;hp=e0a0b071f6e3636663c6f1d2e89634191e8392fe;hpb=c1193c9c134fb91e2ddbc2bf7b79f6ec1abb2e94;p=friendica.git diff --git a/mod/uexport.php b/mod/uexport.php index e0a0b071f6..cada539bcd 100644 --- a/mod/uexport.php +++ b/mod/uexport.php @@ -1,128 +1,136 @@ argc > 1) { - header("Content-type: application/json"); - header('Content-Disposition: attachment; filename="'.$a->user['nickname'].'.'.$a->argv[1].'"'); - switch($a->argv[1]) { - case "backup": uexport_all($a); killme(); break; - case "account": uexport_account($a); killme(); break; - default: - killme(); - } - } - - /** - * options shown on "Export personal data" page - * list of array( 'link url', 'link text', 'help text' ) - */ - $options = array( - array('uexport/account',t('Export account'),t('Export your account info and contacts. Use this to make a backup of your account and/or to move it to another server.')), - array('uexport/backup',t('Export all'),t('Export your accout info, contacts and all your items as json. Could be a very big file, and could take a lot of time. Use this to make a full backup of your account (photos are not exported)')), - ); - call_hooks('uexport_options', $options); - - $tpl = get_markup_template("uexport.tpl"); - return replace_macros($tpl, array( - '$baseurl' => $a->get_baseurl(), - '$title' => t('Export personal data'), - '$options' => $options - )); - +/// @TODO Change space -> tab where wanted +function uexport_content(App $a) { + + if ($a->argc > 1) { + header("Content-type: application/json"); + header('Content-Disposition: attachment; filename="'.$a->user['nickname'].'.'.$a->argv[1].'"'); + switch($a->argv[1]) { + case "backup": + uexport_all($a); + killme(); + break; + case "account": + uexport_account($a); + killme(); + break; + default: + killme(); + } + } + /** + * options shown on "Export personal data" page + * list of array( 'link url', 'link text', 'help text' ) + */ + $options = array( + array('uexport/account',t('Export account'),t('Export your account info and contacts. Use this to make a backup of your account and/or to move it to another server.')), + array('uexport/backup',t('Export all'),t('Export your accout info, contacts and all your items as json. Could be a very big file, and could take a lot of time. Use this to make a full backup of your account (photos are not exported)')), + ); + call_hooks('uexport_options', $options); + + $tpl = get_markup_template("uexport.tpl"); + return replace_macros($tpl, array( + '$baseurl' => App::get_baseurl(), + '$title' => t('Export personal data'), + '$options' => $options + )); } function _uexport_multirow($query) { $result = array(); $r = q($query); -// if (dbm::is_result($r)) { - if ($r){ + if (dbm::is_result($r)) { foreach($r as $rr){ - $p = array(); - foreach($rr as $k => $v) + $p = array(); + foreach($rr as $k => $v) { $p[$k] = $v; - $result[] = $p; - } + } + $result[] = $p; + } } - return $result; + return $result; } function _uexport_row($query) { $result = array(); $r = q($query); - if ($r) { - foreach($r as $rr) - foreach($rr as $k => $v) + if (dbm::is_result($r)) { + foreach($r as $rr) { + foreach($rr as $k => $v) { $result[$k] = $v; - + } + } } - return $result; + return $result; } function uexport_account($a){ $user = _uexport_row( - sprintf( "SELECT * FROM `user` WHERE `uid` = %d LIMIT 1", intval(local_user()) ) + sprintf( "SELECT * FROM `user` WHERE `uid` = %d LIMIT 1", intval(local_user()) ) ); $contact = _uexport_multirow( - sprintf( "SELECT * FROM `contact` WHERE `uid` = %d ",intval(local_user()) ) + sprintf( "SELECT * FROM `contact` WHERE `uid` = %d ",intval(local_user()) ) ); $profile =_uexport_multirow( - sprintf( "SELECT * FROM `profile` WHERE `uid` = %d ", intval(local_user()) ) + sprintf( "SELECT * FROM `profile` WHERE `uid` = %d ", intval(local_user()) ) ); - $photo = _uexport_multirow( - sprintf( "SELECT * FROM `photo` WHERE uid = %d AND profile = 1", intval(local_user()) ) - ); - foreach ($photo as &$p) $p['data'] = bin2hex($p['data']); + $photo = _uexport_multirow( + sprintf( "SELECT * FROM `photo` WHERE uid = %d AND profile = 1", intval(local_user()) ) + ); + foreach ($photo as &$p) { + $p['data'] = bin2hex($p['data']); + } - $pconfig = _uexport_multirow( - sprintf( "SELECT * FROM `pconfig` WHERE uid = %d",intval(local_user()) ) - ); + $pconfig = _uexport_multirow( + sprintf( "SELECT * FROM `pconfig` WHERE uid = %d",intval(local_user()) ) + ); - $group = _uexport_multirow( - sprintf( "SELECT * FROM `group` WHERE uid = %d",intval(local_user()) ) - ); + $group = _uexport_multirow( + sprintf( "SELECT * FROM `group` WHERE uid = %d",intval(local_user()) ) + ); - $group_member = _uexport_multirow( - sprintf( "SELECT * FROM `group_member` WHERE uid = %d",intval(local_user()) ) - ); + $group_member = _uexport_multirow( + sprintf( "SELECT * FROM `group_member` WHERE uid = %d",intval(local_user()) ) + ); $output = array( - 'version' => FRIENDICA_VERSION, - 'schema' => DB_UPDATE_VERSION, - 'baseurl' => $a->get_baseurl(), - 'user' => $user, - 'contact' => $contact, - 'profile' => $profile, - 'photo' => $photo, - 'pconfig' => $pconfig, - 'group' => $group, - 'group_member' => $group_member, - ); - - //echo "
"; var_dump(json_encode($output)); killme();
-	echo json_encode($output);
+		'version' => FRIENDICA_VERSION,
+		'schema' => DB_UPDATE_VERSION,
+		'baseurl' => App::get_baseurl(),
+		'user' => $user,
+		'contact' => $contact,
+		'profile' => $profile,
+		'photo' => $photo,
+		'pconfig' => $pconfig,
+		'group' => $group,
+		'group_member' => $group_member,
+	);
 
+	//echo "
"; var_dump(json_encode($output)); killme();
+	echo json_encode($output);
 }
 
 /**
  * echoes account data and items as separated json, one per line
  */
-function uexport_all(&$a) {
+function uexport_all(App $a) {
 
 	uexport_account($a);
 	echo "\n";
@@ -130,12 +138,12 @@ function uexport_all(&$a) {
 	$r = q("SELECT count(*) as `total` FROM `item` WHERE `uid` = %d ",
 		intval(local_user())
 	);
-	if (dbm::is_result($r))
+	if (dbm::is_result($r)) {
 		$total = $r[0]['total'];
-
+	}
 	// chunk the output to avoid exhausting memory
 
-	for($x = 0; $x < $total; $x += 500) {
+	for ($x = 0; $x < $total; $x += 500) {
 		$item = array();
 		$r = q("SELECT * FROM `item` WHERE `uid` = %d LIMIT %d, %d",
 			intval(local_user()),
@@ -151,5 +159,4 @@ function uexport_all(&$a) {
 		$output = array('item' => $r);
 		echo json_encode($output)."\n";
 	}
-
 }