2011-03-22 03:07:46 -07:00
< ? php
2016-02-07 15:11:34 +01:00
function uexport_init ( & $a ){
2016-12-20 11:56:34 +01:00
if ( ! local_user ()) {
2011-03-22 03:07:46 -07: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 11:13:01 -04:00
}
2016-02-07 15:11:34 +01:00
function uexport_content ( & $a ){
2014-04-24 11:58:04 +02:00
2012-10-17 11:13:01 -04: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 ();
}
}
/**
* options shown on " Export personal data " page
* list of array ( 'link url' , 'link text' , 'help text' )
*/
$options = array (
2016-02-17 23:47:32 +01:00
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)' )),
2012-10-17 11:13:01 -04:00
);
call_hooks ( 'uexport_options' , $options );
2014-04-24 11:58:04 +02:00
2012-10-17 11:13:01 -04:00
$tpl = get_markup_template ( " uexport.tpl " );
return replace_macros ( $tpl , array (
2016-12-19 14:26:13 +01:00
'$baseurl' => App :: get_baseurl (),
2012-10-17 11:13:01 -04:00
'$title' => t ( 'Export personal data' ),
'$options' => $options
));
2014-04-24 11:58:04 +02:00
2016-02-07 15:11:34 +01:00
2012-10-17 11:13:01 -04:00
}
function _uexport_multirow ( $query ) {
$result = array ();
$r = q ( $query );
2016-12-14 09:41:33 +01:00
// if (dbm::is_result($r)) {
2012-11-07 09:26:05 -05:00
if ( $r ){
2012-10-17 11:13:01 -04:00
foreach ( $r as $rr ){
$p = array ();
2011-03-22 03:07:46 -07:00
foreach ( $rr as $k => $v )
2012-10-17 11:13:01 -04:00
$p [ $k ] = $v ;
$result [] = $p ;
}
2011-03-22 03:07:46 -07:00
}
2012-10-17 11:13:01 -04:00
return $result ;
}
function _uexport_row ( $query ) {
$result = array ();
$r = q ( $query );
2012-11-07 09:26:05 -05:00
if ( $r ) {
2011-03-22 03:07:46 -07:00
foreach ( $r as $rr )
foreach ( $rr as $k => $v )
2012-10-17 11:13:01 -04:00
$result [ $k ] = $v ;
2011-03-22 03:07:46 -07:00
}
2012-10-17 11:13:01 -04:00
return $result ;
}
2011-03-22 03:07:46 -07:00
2016-02-07 15:11:34 +01:00
function uexport_account ( $a ){
2012-10-17 11:13:01 -04:00
$user = _uexport_row (
sprintf ( " SELECT * FROM `user` WHERE `uid` = %d LIMIT 1 " , intval ( local_user ()) )
2011-03-22 03:07:46 -07:00
);
2014-04-24 11:58:04 +02:00
2012-10-17 11:13:01 -04:00
$contact = _uexport_multirow (
sprintf ( " SELECT * FROM `contact` WHERE `uid` = %d " , intval ( local_user ()) )
);
$profile = _uexport_multirow (
sprintf ( " SELECT * FROM `profile` WHERE `uid` = %d " , intval ( local_user ()) )
);
$photo = _uexport_multirow (
2012-11-07 09:26:05 -05:00
sprintf ( " SELECT * FROM `photo` WHERE uid = %d AND profile = 1 " , intval ( local_user ()) )
2012-10-17 11:13:01 -04:00
);
foreach ( $photo as & $p ) $p [ 'data' ] = bin2hex ( $p [ 'data' ]);
2011-03-22 03:07:46 -07:00
2012-10-17 11:13:01 -04:00
$pconfig = _uexport_multirow (
2012-11-07 09:26:05 -05:00
sprintf ( " SELECT * FROM `pconfig` WHERE uid = %d " , intval ( local_user ()) )
2012-10-17 11:13:01 -04:00
);
2011-03-22 03:07:46 -07:00
2012-10-17 11:13:01 -04:00
$group = _uexport_multirow (
2012-11-07 09:26:05 -05:00
sprintf ( " SELECT * FROM `group` WHERE uid = %d " , intval ( local_user ()) )
2012-10-17 11:13:01 -04:00
);
2014-04-24 11:58:04 +02:00
2012-10-17 11:13:01 -04:00
$group_member = _uexport_multirow (
2012-11-07 09:26:05 -05:00
sprintf ( " SELECT * FROM `group_member` WHERE uid = %d " , intval ( local_user ()) )
2012-10-17 11:13:01 -04:00
);
$output = array (
'version' => FRIENDICA_VERSION ,
'schema' => DB_UPDATE_VERSION ,
2016-12-19 14:26:13 +01:00
'baseurl' => App :: get_baseurl (),
2016-02-17 23:47:32 +01:00
'user' => $user ,
'contact' => $contact ,
'profile' => $profile ,
2012-10-17 11:13:01 -04:00
'photo' => $photo ,
'pconfig' => $pconfig ,
'group' => $group ,
'group_member' => $group_member ,
);
//echo "<pre>"; var_dump(json_encode($output)); killme();
2011-06-02 20:42:09 -07:00
echo json_encode ( $output );
2016-02-07 15:11:34 +01:00
2012-10-17 11:13:01 -04:00
}
/**
* echoes account data and items as separated json , one per line
*/
function uexport_all ( & $a ) {
2016-02-17 23:47:32 +01:00
uexport_account ( $a );
2013-06-28 03:16:25 -04:00
echo " \n " ;
2012-10-17 11:13:01 -04:00
2011-03-22 16:19:00 -07:00
$r = q ( " SELECT count(*) as `total` FROM `item` WHERE `uid` = %d " ,
intval ( local_user ())
);
2016-12-14 09:41:33 +01:00
if ( dbm :: is_result ( $r ))
2011-03-22 16:19:00 -07:00
$total = $r [ 0 ][ 'total' ];
// chunk the output to avoid exhausting memory
for ( $x = 0 ; $x < $total ; $x += 500 ) {
$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-22 16:19:00 -07:00
foreach ( $r as $rr )
foreach ( $rr as $k => $v )
$item [][ $k ] = $v ;
2013-06-28 03:16:25 -04:00
} */
2011-03-22 16:19:00 -07:00
2013-06-28 03:16:25 -04:00
$output = array ( 'item' => $r );
echo json_encode ( $output ) . " \n " ;
2011-03-22 16:19:00 -07:00
}
2016-02-07 15:11:34 +01:00
2014-04-24 11:58:04 +02:00
}