2011-03-22 11:07:46 +01:00
< ? php
2016-12-20 10:58:55 +01:00
function uexport_init ( App & $a ){
2016-12-20 11:56:34 +01:00
if ( ! local_user ()) {
2011-03-22 11:07:46 +01:00
killme ();
2016-12-20 11:56:34 +01:00
}
2014-04-24 11:58:04 +02:00
require_once ( " mod/settings.php " );
2016-12-20 11:56:34 +01:00
settings_init ( $a );
2012-10-17 17:13:01 +02:00
}
2016-12-20 10:58:55 +01:00
/// @TODO Change space -> tab where wanted
2016-12-20 10:58:55 +01:00
function uexport_content ( App & $a ){
2014-04-24 11:58:04 +02:00
2017-01-10 00:10:32 +01:00
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 ();
}
}
2016-02-07 15:11:34 +01:00
2017-01-10 00:10:32 +01:00
/**
* 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
));
2012-10-17 17:13:01 +02:00
}
function _uexport_multirow ( $query ) {
$result = array ();
$r = q ( $query );
2017-01-10 00:10:32 +01:00
if ( dbm :: is_result ( $r )) {
2012-10-17 17:13:01 +02:00
foreach ( $r as $rr ){
2017-01-10 00:10:32 +01:00
$p = array ();
foreach ( $rr as $k => $v ) {
2012-10-17 17:13:01 +02:00
$p [ $k ] = $v ;
2017-01-10 00:10:32 +01:00
}
$result [] = $p ;
}
2011-03-22 11:07:46 +01:00
}
2017-01-10 00:10:32 +01:00
return $result ;
2012-10-17 17:13:01 +02:00
}
function _uexport_row ( $query ) {
$result = array ();
$r = q ( $query );
2017-01-10 00:10:32 +01:00
if ( dbm :: is_result ( $r )) {
foreach ( $r as $rr ) {
foreach ( $rr as $k => $v ) {
2012-10-17 17:13:01 +02:00
$result [ $k ] = $v ;
2017-01-10 00:10:32 +01:00
}
}
2011-03-22 11:07:46 +01:00
}
2017-01-10 00:10:32 +01:00
return $result ;
2012-10-17 17:13:01 +02:00
}
2011-03-22 11:07:46 +01:00
2016-02-07 15:11:34 +01:00
function uexport_account ( $a ){
2012-10-17 17:13:01 +02:00
$user = _uexport_row (
2017-01-10 00:10:32 +01:00
sprintf ( " SELECT * FROM `user` WHERE `uid` = %d LIMIT 1 " , intval ( local_user ()) )
2011-03-22 11:07:46 +01:00
);
2014-04-24 11:58:04 +02:00
2012-10-17 17:13:01 +02:00
$contact = _uexport_multirow (
2017-01-10 00:10:32 +01:00
sprintf ( " SELECT * FROM `contact` WHERE `uid` = %d " , intval ( local_user ()) )
2012-10-17 17:13:01 +02:00
);
$profile = _uexport_multirow (
2017-01-10 00:10:32 +01:00
sprintf ( " SELECT * FROM `profile` WHERE `uid` = %d " , intval ( local_user ()) )
2012-10-17 17:13:01 +02:00
);
2017-01-10 00:10:32 +01:00
$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' ]);
}
2011-03-22 11:07:46 +01:00
2017-01-10 00:10:32 +01:00
$pconfig = _uexport_multirow (
sprintf ( " SELECT * FROM `pconfig` WHERE uid = %d " , intval ( local_user ()) )
);
2011-03-22 11:07:46 +01:00
2017-01-10 00:10:32 +01:00
$group = _uexport_multirow (
sprintf ( " SELECT * FROM `group` WHERE uid = %d " , intval ( local_user ()) )
);
2014-04-24 11:58:04 +02:00
2017-01-10 00:10:32 +01:00
$group_member = _uexport_multirow (
sprintf ( " SELECT * FROM `group_member` WHERE uid = %d " , intval ( local_user ()) )
);
2012-10-17 17:13:01 +02:00
$output = array (
2017-01-10 00:10:32 +01:00
'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 ,
);
2016-02-07 15:11:34 +01:00
2017-01-10 00:10:32 +01:00
//echo "<pre>"; var_dump(json_encode($output)); killme();
echo json_encode ( $output );
2012-10-17 17:13:01 +02:00
}
/**
* echoes account data and items as separated json , one per line
*/
2016-12-20 10:58:55 +01:00
function uexport_all ( App & $a ) {
2016-02-17 23:47:32 +01:00
uexport_account ( $a );
2013-06-28 09:16:25 +02:00
echo " \n " ;
2012-10-17 17:13:01 +02:00
2011-03-23 00:19:00 +01:00
$r = q ( " SELECT count(*) as `total` FROM `item` WHERE `uid` = %d " ,
intval ( local_user ())
);
2017-01-10 00:10:32 +01:00
if ( dbm :: is_result ( $r )) {
2011-03-23 00:19:00 +01:00
$total = $r [ 0 ][ 'total' ];
2017-01-10 00:10:32 +01:00
}
2011-03-23 00:19:00 +01:00
// chunk the output to avoid exhausting memory
2017-01-10 00:10:32 +01:00
for ( $x = 0 ; $x < $total ; $x += 500 ) {
2011-03-23 00:19:00 +01:00
$item = array ();
$r = q ( " SELECT * FROM `item` WHERE `uid` = %d LIMIT %d, %d " ,
intval ( local_user ()),
intval ( $x ),
intval ( 500 )
);
2016-12-14 09:41:33 +01:00
/* if ( dbm :: is_result ( $r )) {
2011-03-23 00:19:00 +01:00
foreach ( $r as $rr )
foreach ( $rr as $k => $v )
$item [][ $k ] = $v ;
2013-06-28 09:16:25 +02:00
} */
2011-03-23 00:19:00 +01:00
2013-06-28 09:16:25 +02:00
$output = array ( 'item' => $r );
echo json_encode ( $output ) . " \n " ;
2011-03-23 00:19:00 +01:00
}
2014-04-24 11:58:04 +02:00
}