2010-09-09 05:14:17 +02:00
< ? php
2010-10-07 02:40:58 +02:00
// Included here for completeness, but this is a very dangerous operation.
// It is the caller's responsibility to confirm the requestor's intent and
// authorisation to do this.
function user_remove ( $uid ) {
2011-02-03 12:58:47 +01:00
if ( ! $uid )
return ;
$a = get_app ();
logger ( 'Removing user: ' . $uid );
2012-01-19 01:21:30 +01:00
$r = q ( " select * from user where uid = %d limit 1 " , intval ( $uid ));
call_hooks ( 'remove_user' , $r [ 0 ]);
2015-02-01 13:32:05 +01:00
// save username (actually the nickname as it is guaranteed
2012-03-22 09:46:52 +01:00
// unique), so it cannot be re-registered in the future.
q ( " insert into userd ( username ) values ( '%s' ) " ,
$r [ 0 ][ 'nickname' ]
);
2012-01-19 01:21:30 +01:00
2012-11-02 21:43:47 +01:00
// don't delete yet, will be done later when contacts have deleted my stuff
// q("DELETE FROM `contact` WHERE `uid` = %d", intval($uid));
2012-04-12 14:15:45 +02:00
q ( " DELETE FROM `gcign` WHERE `uid` = %d " , intval ( $uid ));
2010-10-07 02:40:58 +02:00
q ( " DELETE FROM `group` WHERE `uid` = %d " , intval ( $uid ));
q ( " DELETE FROM `group_member` WHERE `uid` = %d " , intval ( $uid ));
q ( " DELETE FROM `intro` WHERE `uid` = %d " , intval ( $uid ));
2011-03-18 05:15:27 +01:00
q ( " DELETE FROM `event` WHERE `uid` = %d " , intval ( $uid ));
2010-10-07 02:40:58 +02:00
q ( " DELETE FROM `item` WHERE `uid` = %d " , intval ( $uid ));
2012-04-12 14:15:45 +02:00
q ( " DELETE FROM `item_id` WHERE `uid` = %d " , intval ( $uid ));
2010-10-07 02:40:58 +02:00
q ( " DELETE FROM `mail` WHERE `uid` = %d " , intval ( $uid ));
2012-04-12 14:15:45 +02:00
q ( " DELETE FROM `mailacct` WHERE `uid` = %d " , intval ( $uid ));
q ( " DELETE FROM `manage` WHERE `uid` = %d " , intval ( $uid ));
q ( " DELETE FROM `notify` WHERE `uid` = %d " , intval ( $uid ));
2010-10-07 02:40:58 +02:00
q ( " DELETE FROM `photo` WHERE `uid` = %d " , intval ( $uid ));
2012-04-12 14:15:45 +02:00
q ( " DELETE FROM `attach` WHERE `uid` = %d " , intval ( $uid ));
2010-10-07 02:40:58 +02:00
q ( " DELETE FROM `profile` WHERE `uid` = %d " , intval ( $uid ));
q ( " DELETE FROM `profile_check` WHERE `uid` = %d " , intval ( $uid ));
2011-03-18 05:15:27 +01:00
q ( " DELETE FROM `pconfig` WHERE `uid` = %d " , intval ( $uid ));
2012-04-12 14:15:45 +02:00
q ( " DELETE FROM `search` WHERE `uid` = %d " , intval ( $uid ));
q ( " DELETE FROM `spam` WHERE `uid` = %d " , intval ( $uid ));
2012-11-02 21:43:47 +01:00
// don't delete yet, will be done later when contacts have deleted my stuff
// q("DELETE FROM `user` WHERE `uid` = %d", intval($uid));
q ( " UPDATE `user` SET `account_removed` = 1, `account_expires_on` = UTC_TIMESTAMP() WHERE `uid` = %d " , intval ( $uid ));
proc_run ( 'php' , " include/notifier.php " , " removeme " , $uid );
2015-03-30 22:22:11 +02:00
// Send an update to the directory
proc_run ( 'php' , " include/directory.php " , $r [ 0 ][ 'url' ]);
2010-10-18 23:34:59 +02:00
if ( $uid == local_user ()) {
2010-10-07 02:40:58 +02:00
unset ( $_SESSION [ 'authenticated' ]);
unset ( $_SESSION [ 'uid' ]);
2011-02-03 12:58:47 +01:00
goaway ( $a -> get_baseurl ());
2010-10-07 02:40:58 +02:00
}
}
2010-09-09 05:14:17 +02:00
function contact_remove ( $id ) {
2012-04-29 06:56:17 +02:00
$r = q ( " select uid from contact where id = %d limit 1 " ,
intval ( $id )
);
if (( ! count ( $r )) || ( ! intval ( $r [ 0 ][ 'uid' ])))
return ;
$archive = get_pconfig ( $r [ 0 ][ 'uid' ], 'system' , 'archive_removed_contacts' );
if ( $archive ) {
2014-03-11 23:52:32 +01:00
q ( " update contact set `archive` = 1, `network` = 'none', `writable` = 0 where id = %d " ,
2012-04-29 06:56:17 +02:00
intval ( $id )
);
return ;
}
2014-03-11 23:52:32 +01:00
q ( " DELETE FROM `contact` WHERE `id` = %d " ,
2010-09-09 05:14:17 +02:00
intval ( $id )
);
q ( " DELETE FROM `item` WHERE `contact-id` = %d " ,
intval ( $id )
);
q ( " DELETE FROM `photo` WHERE `contact-id` = %d " ,
intval ( $id )
);
2010-12-06 04:42:28 +01:00
q ( " DELETE FROM `mail` WHERE `contact-id` = %d " ,
intval ( $id )
);
2011-03-18 05:15:27 +01:00
q ( " DELETE FROM `event` WHERE `cid` = %d " ,
intval ( $id )
);
2011-10-14 00:39:05 +02:00
q ( " DELETE FROM `queue` WHERE `cid` = %d " ,
intval ( $id )
);
2010-09-09 05:14:17 +02:00
}
2012-04-24 04:42:57 +02:00
// sends an unfriend message. Does not remove the contact
function terminate_friendship ( $user , $self , $contact ) {
$a = get_app ();
require_once ( 'include/datetime.php' );
if ( $contact [ 'network' ] === NETWORK_OSTATUS ) {
$slap = replace_macros ( get_markup_template ( 'follow_slap.tpl' ), array (
'$name' => $user [ 'username' ],
'$profile_page' => $a -> get_baseurl () . '/profile/' . $user [ 'nickname' ],
'$photo' => $self [ 'photo' ],
'$thumb' => $self [ 'thumb' ],
'$published' => datetime_convert ( 'UTC' , 'UTC' , 'now' , ATOM_TIME ),
2015-08-14 07:48:28 +02:00
'$item_id' => 'urn:X-dfrn:' . $a -> get_hostname () . ':unfollow:' . get_guid ( 32 ),
2012-04-24 04:42:57 +02:00
'$title' => '' ,
'$type' => 'text' ,
'$content' => t ( 'stopped following' ),
'$nick' => $user [ 'nickname' ],
'$verb' => 'http://ostatus.org/schema/1.0/unfollow' , // ACTIVITY_UNFOLLOW,
'$ostat_follow' => '' // '<as:verb>http://ostatus.org/schema/1.0/unfollow</as:verb>' . "\r\n"
));
if (( x ( $contact , 'notify' )) && ( strlen ( $contact [ 'notify' ]))) {
require_once ( 'include/salmon.php' );
slapper ( $user , $contact [ 'notify' ], $slap );
}
}
elseif ( $contact [ 'network' ] === NETWORK_DIASPORA ) {
require_once ( 'include/diaspora.php' );
diaspora_unshare ( $user , $contact );
}
elseif ( $contact [ 'network' ] === NETWORK_DFRN ) {
require_once ( 'include/items.php' );
dfrn_deliver ( $user , $contact , 'placeholder' , 1 );
}
}
2010-09-09 05:14:17 +02:00
// Contact has refused to recognise us as a friend. We will start a countdown.
// If they still don't recognise us in 32 days, the relationship is over,
// and we won't waste any more time trying to communicate with them.
// This provides for the possibility that their database is temporarily messed
// up or some other transient event and that there's a possibility we could recover from it.
2015-11-07 18:25:35 +01:00
2010-09-09 05:14:17 +02:00
if ( ! function_exists ( 'mark_for_death' )) {
function mark_for_death ( $contact ) {
2012-06-15 01:56:46 +02:00
if ( $contact [ 'archive' ])
return ;
2010-09-09 05:14:17 +02:00
if ( $contact [ 'term-date' ] == '0000-00-00 00:00:00' ) {
2014-03-11 23:52:32 +01:00
q ( " UPDATE `contact` SET `term-date` = '%s' WHERE `id` = %d " ,
2010-09-09 05:14:17 +02:00
dbesc ( datetime_convert ()),
intval ( $contact [ 'id' ])
);
}
else {
2012-06-14 04:59:20 +02:00
// TODO: We really should send a notification to the owner after 2-3 weeks
// so they won't be surprised when the contact vanishes and can take
// remedial action if this was a serious mistake or glitch
2010-09-09 05:14:17 +02:00
$expiry = $contact [ 'term-date' ] . ' + 32 days ' ;
if ( datetime_convert () > datetime_convert ( 'UTC' , 'UTC' , $expiry )) {
2015-11-07 18:25:35 +01:00
// relationship is really truly dead.
2012-06-14 04:59:20 +02:00
// archive them rather than delete
// though if the owner tries to unarchive them we'll start the whole process over again
2014-03-11 23:52:32 +01:00
q ( " update contact set `archive` = 1 where id = %d " ,
2012-06-14 04:59:20 +02:00
intval ( $contact [ 'id' ])
);
2012-11-02 23:54:03 +01:00
q ( " UPDATE `item` SET `private` = 2 WHERE `contact-id` = %d AND `uid` = %d " , intval ( $contact [ 'id' ]), intval ( $contact [ 'uid' ]));
2010-09-09 05:14:17 +02:00
2012-06-14 04:59:20 +02:00
//contact_remove($contact['id']);
2010-09-09 05:14:17 +02:00
}
}
}}
if ( ! function_exists ( 'unmark_for_death' )) {
function unmark_for_death ( $contact ) {
// It's a miracle. Our dead contact has inexplicably come back to life.
2014-03-11 23:52:32 +01:00
q ( " UPDATE `contact` SET `term-date` = '%s' WHERE `id` = %d " ,
2010-09-09 05:14:17 +02:00
dbesc ( '0000-00-00 00:00:00' ),
intval ( $contact [ 'id' ])
);
}}
2015-10-31 00:01:33 +01:00
function get_contact_details_by_url ( $url , $uid = - 1 ) {
2015-10-30 01:30:42 +01:00
require_once ( " mod/proxy.php " );
require_once ( " include/bbcode.php " );
if ( $uid == - 1 )
$uid = local_user ();
2015-11-06 00:47:54 +01:00
$r = q ( " SELECT `id` AS `gid`, `url`, `name`, `nick`, `addr`, `photo`, `location`, `about`, `keywords`, `gender`, `community`, `network` FROM `gcontact` WHERE `nurl` = '%s' LIMIT 1 " ,
2015-10-30 01:30:42 +01:00
dbesc ( normalise_link ( $url )));
2015-11-06 00:47:54 +01:00
if ( $r ) {
2015-10-30 01:30:42 +01:00
$profile = $r [ 0 ];
2015-11-06 00:47:54 +01:00
2015-11-06 09:15:20 +01:00
if ((( $profile [ " addr " ] == " " ) OR ( $profile [ " name " ] == " " )) AND
in_array ( $profile [ " network " ], array ( NETWORK_DFRN , NETWORK_DIASPORA , NETWORK_OSTATUS )))
2015-11-06 00:47:54 +01:00
proc_run ( 'php' , " include/update_gcontact.php " , $profile [ " gid " ]);
} else {
2015-10-30 01:30:42 +01:00
$r = q ( " SELECT `url`, `name`, `nick`, `avatar` AS `photo`, `location`, `about` FROM `unique_contacts` WHERE `url` = '%s' " ,
dbesc ( normalise_link ( $url )));
if ( count ( $r )) {
$profile = $r [ 0 ];
$profile [ " keywords " ] = " " ;
$profile [ " gender " ] = " " ;
$profile [ " community " ] = false ;
$profile [ " network " ] = " " ;
2015-11-05 08:37:00 +01:00
$profile [ " addr " ] = " " ;
2015-10-30 01:30:42 +01:00
}
}
// Fetching further contact data from the contact table
2015-11-05 08:37:00 +01:00
$r = q ( " SELECT `id`, `uid`, `url`, `network`, `name`, `nick`, `addr`, `location`, `about`, `keywords`, `gender`, `photo`, `addr`, `forum`, `prv`, `bd` FROM `contact` WHERE `nurl` = '%s' AND `uid` = %d AND `network` = '%s' " ,
2015-10-30 01:30:42 +01:00
dbesc ( normalise_link ( $url )), intval ( $uid ), dbesc ( $profile [ " network " ]));
if ( ! count ( $r ))
2015-11-05 08:37:00 +01:00
$r = q ( " SELECT `id`, `uid`, `url`, `network`, `name`, `nick`, `addr`, `location`, `about`, `keywords`, `gender`, `photo`, `addr`, `forum`, `prv`, `bd` FROM `contact` WHERE `nurl` = '%s' AND `uid` = %d " ,
2015-10-30 01:30:42 +01:00
dbesc ( normalise_link ( $url )), intval ( $uid ));
if ( ! count ( $r ))
2015-11-05 08:37:00 +01:00
$r = q ( " SELECT `id`, `uid`, `url`, `network`, `name`, `nick`, `addr`, `location`, `about`, `keywords`, `gender`, `photo`, `addr`, `forum`, `prv`, `bd` FROM `contact` WHERE `nurl` = '%s' AND `uid` = 0 " ,
2015-10-30 01:30:42 +01:00
dbesc ( normalise_link ( $url )));
if ( $r ) {
if ( isset ( $r [ 0 ][ " url " ]) AND $r [ 0 ][ " url " ])
$profile [ " url " ] = $r [ 0 ][ " url " ];
if ( isset ( $r [ 0 ][ " name " ]) AND $r [ 0 ][ " name " ])
$profile [ " name " ] = $r [ 0 ][ " name " ];
if ( isset ( $r [ 0 ][ " nick " ]) AND $r [ 0 ][ " nick " ] AND ( $profile [ " nick " ] == " " ))
$profile [ " nick " ] = $r [ 0 ][ " nick " ];
2015-11-05 08:37:00 +01:00
if ( isset ( $r [ 0 ][ " addr " ]) AND $r [ 0 ][ " addr " ] AND ( $profile [ " addr " ] == " " ))
$profile [ " addr " ] = $r [ 0 ][ " addr " ];
2015-10-30 01:30:42 +01:00
if ( isset ( $r [ 0 ][ " photo " ]) AND $r [ 0 ][ " photo " ])
$profile [ " photo " ] = $r [ 0 ][ " photo " ];
if ( isset ( $r [ 0 ][ " location " ]) AND $r [ 0 ][ " location " ])
$profile [ " location " ] = $r [ 0 ][ " location " ];
if ( isset ( $r [ 0 ][ " about " ]) AND $r [ 0 ][ " about " ])
$profile [ " about " ] = $r [ 0 ][ " about " ];
if ( isset ( $r [ 0 ][ " keywords " ]) AND $r [ 0 ][ " keywords " ])
$profile [ " keywords " ] = $r [ 0 ][ " keywords " ];
if ( isset ( $r [ 0 ][ " gender " ]) AND $r [ 0 ][ " gender " ])
$profile [ " gender " ] = $r [ 0 ][ " gender " ];
2015-11-03 14:31:15 +01:00
if ( isset ( $r [ 0 ][ " forum " ]) OR isset ( $r [ 0 ][ " prv " ]))
2015-10-30 01:30:42 +01:00
$profile [ " community " ] = ( $r [ 0 ][ " forum " ] OR $r [ 0 ][ " prv " ]);
if ( isset ( $r [ 0 ][ " network " ]) AND $r [ 0 ][ " network " ])
$profile [ " network " ] = $r [ 0 ][ " network " ];
if ( isset ( $r [ 0 ][ " addr " ]) AND $r [ 0 ][ " addr " ])
$profile [ " addr " ] = $r [ 0 ][ " addr " ];
if ( isset ( $r [ 0 ][ " bd " ]) AND $r [ 0 ][ " bd " ])
$profile [ " bd " ] = $r [ 0 ][ " bd " ];
if ( $r [ 0 ][ " uid " ] == 0 )
$profile [ " cid " ] = 0 ;
else
$profile [ " cid " ] = $r [ 0 ][ " id " ];
} else
$profile [ " cid " ] = 0 ;
if ( isset ( $profile [ " photo " ]))
$profile [ " photo " ] = proxy_url ( $profile [ " photo " ], false , PROXY_SIZE_SMALL );
if ( isset ( $profile [ " location " ]))
$profile [ " location " ] = bbcode ( $profile [ " location " ]);
if ( isset ( $profile [ " about " ]))
$profile [ " about " ] = bbcode ( $profile [ " about " ]);
if (( $profile [ " cid " ] == 0 ) AND ( $profile [ " network " ] == NETWORK_DIASPORA )) {
$profile [ " location " ] = " " ;
$profile [ " about " ] = " " ;
}
return ( $profile );
}
2011-08-25 07:40:26 +02:00
if ( ! function_exists ( 'contact_photo_menu' )){
2015-11-29 09:35:35 +01:00
function contact_photo_menu ( $contact , $uid = 0 ) {
2011-08-25 07:40:26 +02:00
$a = get_app ();
2015-02-01 13:32:05 +01:00
2011-08-25 07:40:26 +02:00
$contact_url = " " ;
$pm_url = " " ;
$status_link = " " ;
$photos_link = " " ;
$posts_link = " " ;
2013-11-05 22:06:23 +01:00
$contact_drop_link = " " ;
2012-07-20 06:03:31 +02:00
$poke_link = " " ;
2011-08-25 07:40:26 +02:00
2015-11-29 09:35:35 +01:00
if ( $uid == 0 )
$uid = local_user ();
if ( $contact [ " uid " ] != $uid ) {
if ( $uid == 0 ) {
$profile_link = zrl ( $contact [ 'url' ]);
$menu = Array ( 'profile' => array ( t ( " View Profile " ), $profile_link , true ));
return $menu ;
}
$r = q ( " SELECT * FROM `contact` WHERE `nurl` = '%s' AND `network` = '%s' AND `uid` = %d " ,
dbesc ( $contact [ " nurl " ]), dbesc ( $contact [ " network " ]), intval ( $uid ));
if ( $r )
return contact_photo_menu ( $r [ 0 ], $uid );
else {
$profile_link = zrl ( $contact [ 'url' ]);
$connlnk = 'follow/?url=' . $contact [ 'url' ];
$menu = Array (
'profile' => array ( t ( " View Profile " ), $profile_link , true ),
'follow' => array ( t ( " Connect/Follow " ), $connlnk , true )
);
return $menu ;
}
}
2011-08-25 07:40:26 +02:00
$sparkle = false ;
if ( $contact [ 'network' ] === NETWORK_DFRN ) {
$sparkle = true ;
$profile_link = $a -> get_baseurl () . '/redir/' . $contact [ 'id' ];
}
else
$profile_link = $contact [ 'url' ];
if ( $profile_link === 'mailbox' )
$profile_link = '' ;
if ( $sparkle ) {
$status_link = $profile_link . " ?url=status " ;
$photos_link = $profile_link . " ?url=photos " ;
$profile_link = $profile_link . " ?url=profile " ;
}
2015-10-05 00:14:39 +02:00
if ( in_array ( $contact [ " network " ], array ( NETWORK_DFRN , NETWORK_DIASPORA )))
$pm_url = $a -> get_baseurl () . '/message/new/' . $contact [ 'id' ];
if ( $contact [ " network " ] == NETWORK_DFRN )
$poke_link = $a -> get_baseurl () . '/poke/?f=&c=' . $contact [ 'id' ];
2011-08-25 08:20:04 +02:00
$contact_url = $a -> get_baseurl () . '/contacts/' . $contact [ 'id' ];
2013-02-01 09:12:37 +01:00
$posts_link = $a -> get_baseurl () . '/network/0?nets=all&cid=' . $contact [ 'id' ];
2013-12-17 11:19:06 +01:00
$contact_drop_link = $a -> get_baseurl () . " /contacts/ " . $contact [ 'id' ] . '/drop?confirm=1' ;
2015-02-01 13:32:05 +01:00
2011-08-25 07:40:26 +02:00
2015-11-07 18:25:35 +01:00
/**
* menu array :
* " name " => [ " Label " , " link " , ( bool ) Should the link opened in a new tab ? ]
*/
2011-08-25 07:40:26 +02:00
$menu = Array (
2015-11-07 18:25:35 +01:00
'status' => array ( t ( " View Status " ), $status_link , true ),
'profile' => array ( t ( " View Profile " ), $profile_link , true ),
'photos' => array ( t ( " View Photos " ), $photos_link , true ),
'network' => array ( t ( " Network Posts " ), $posts_link , false ),
'edit' => array ( t ( " Edit Contact " ), $contact_url , false ),
'drop' => array ( t ( " Drop Contact " ), $contact_drop_link , false ),
'pm' => array ( t ( " Send PM " ), $pm_url , false ),
'poke' => array ( t ( " Poke " ), $poke_link , false ),
2011-08-25 07:40:26 +02:00
);
2015-02-01 13:32:05 +01:00
2012-05-13 10:15:54 +02:00
$args = array ( 'contact' => $contact , 'menu' => & $menu );
2015-02-01 13:32:05 +01:00
2011-08-25 07:40:26 +02:00
call_hooks ( 'contact_photo_menu' , $args );
2015-02-01 13:32:05 +01:00
2015-10-05 00:14:39 +02:00
$menucondensed = array ();
2015-11-07 18:25:35 +01:00
foreach ( $menu AS $menuname => $menuitem )
2015-10-05 00:14:39 +02:00
if ( $menuitem [ 1 ] != " " )
2015-11-07 18:25:35 +01:00
$menucondensed [ $menuname ] = $menuitem ;
2015-10-05 00:14:39 +02:00
return $menucondensed ;
2011-08-25 07:40:26 +02:00
}}
2012-04-11 05:50:31 +02:00
function random_profile () {
2015-07-29 07:32:00 +02:00
$r = q ( " SELECT `url` FROM `gcontact` WHERE `network` = '%s'
AND `last_contact` >= `last_failure`
AND `updated` > UTC_TIMESTAMP - INTERVAL 1 MONTH
ORDER BY rand () LIMIT 1 " ,
dbesc ( NETWORK_DFRN ));
2012-04-11 05:50:31 +02:00
if ( count ( $r ))
return dirname ( $r [ 0 ][ 'url' ]);
return '' ;
2012-04-12 16:48:28 +02:00
}
2012-04-13 08:06:41 +02:00
function contacts_not_grouped ( $uid , $start = 0 , $count = 0 ) {
2012-04-13 08:14:41 +02:00
2012-04-13 08:06:41 +02:00
if ( ! $count ) {
$r = q ( " select count(*) as total from contact where uid = %d and self = 0 and id not in (select distinct(`contact-id`) from group_member where uid = %d) " ,
intval ( $uid ),
intval ( $uid )
);
2012-04-13 08:14:41 +02:00
2012-04-13 08:06:41 +02:00
return $r ;
}
2012-04-13 08:14:41 +02:00
$r = q ( " select * from contact where uid = %d and self = 0 and id not in (select distinct(`contact-id`) from group_member where uid = %d) and blocked = 0 and pending = 0 limit %d, %d " ,
2012-04-13 08:06:41 +02:00
intval ( $uid ),
2012-04-12 16:48:28 +02:00
intval ( $uid ),
2012-04-13 08:06:41 +02:00
intval ( $start ),
intval ( $count )
2012-04-12 16:48:28 +02:00
);
2012-04-13 08:14:41 +02:00
2012-04-12 16:48:28 +02:00
return $r ;
}
2015-02-01 10:26:35 +01:00
function get_contact ( $url , $uid = 0 ) {
require_once ( " include/Scrape.php " );
$data = array ();
2015-02-01 13:32:05 +01:00
$contactid = 0 ;
2015-02-01 10:26:35 +01:00
// is it an address in the format user@server.tld?
if ( ! strstr ( $url , " http " ) OR strstr ( $url , " @ " )) {
$data = probe_url ( $url );
$url = $data [ " url " ];
if ( $url == " " )
return 0 ;
}
2015-02-01 13:32:05 +01:00
$contact = q ( " SELECT `id`, `avatar-date` FROM `contact` WHERE `nurl` = '%s' AND `uid` = %d " ,
2015-02-01 10:26:35 +01:00
dbesc ( normalise_link ( $url )),
intval ( $uid ));
2015-02-01 13:32:05 +01:00
if ( ! $contact )
2015-02-01 16:32:58 +01:00
$contact = q ( " SELECT `id`, `avatar-date` FROM `contact` WHERE `alias` IN ('%s', '%s') AND `uid` = %d " ,
dbesc ( $url ),
2015-02-01 13:32:05 +01:00
dbesc ( normalise_link ( $url )),
intval ( $uid ));
if ( $contact ) {
$contactid = $contact [ 0 ][ " id " ];
2015-02-01 16:32:58 +01:00
// Update the contact every 7 days
$update_photo = ( $contact [ 0 ][ 'avatar-date' ] < datetime_convert ( '' , '' , 'now -7 days' ));
//$update_photo = ($contact[0]['avatar-date'] < datetime_convert('','','now -12 hours'));
2015-02-01 13:32:05 +01:00
if ( ! $update_photo )
return ( $contactid );
2015-05-09 19:39:47 +02:00
} elseif ( $uid != 0 )
return 0 ;
2015-02-01 10:26:35 +01:00
if ( ! count ( $data ))
$data = probe_url ( $url );
// Does this address belongs to a valid network?
if ( ! in_array ( $data [ " network " ], array ( NETWORK_DFRN , NETWORK_OSTATUS , NETWORK_DIASPORA )))
return 0 ;
2015-02-01 13:32:05 +01:00
// tempory programming. Can be deleted after 2015-02-07
if (( $data [ " alias " ] == " " ) AND ( normalise_link ( $data [ " url " ]) != normalise_link ( $url )))
$data [ " alias " ] = normalise_link ( $url );
2015-02-01 10:26:35 +01:00
2015-02-01 13:32:05 +01:00
if ( $contactid == 0 ) {
q ( " INSERT INTO `contact` (`uid`, `created`, `url`, `nurl`, `addr`, `alias`, `notify`, `poll`,
`name` , `nick` , `photo` , `network` , `pubkey` , `rel` , `priority` ,
`batch` , `request` , `confirm` , `poco` ,
`writable` , `blocked` , `readonly` , `pending` )
VALUES ( % d , '%s' , '%s' , '%s' , '%s' , '%s' , '%s' , '%s' , '%s' , '%s' , '%s' , '%s' , '%s' , % d , % d , '%s' , '%s' , '%s' , '%s' , 1 , 0 , 0 , 0 ) " ,
intval ( $uid ),
dbesc ( datetime_convert ()),
dbesc ( $data [ " url " ]),
dbesc ( normalise_link ( $data [ " url " ])),
dbesc ( $data [ " addr " ]),
dbesc ( $data [ " alias " ]),
dbesc ( $data [ " notify " ]),
dbesc ( $data [ " poll " ]),
dbesc ( $data [ " name " ]),
dbesc ( $data [ " nick " ]),
dbesc ( $data [ " photo " ]),
dbesc ( $data [ " network " ]),
dbesc ( $data [ " pubkey " ]),
intval ( CONTACT_IS_SHARING ),
intval ( $data [ " priority " ]),
dbesc ( $data [ " batch " ]),
dbesc ( $data [ " request " ]),
dbesc ( $data [ " confirm " ]),
dbesc ( $data [ " poco " ])
);
$contact = q ( " SELECT `id` FROM `contact` WHERE `nurl` = '%s' AND `uid` = %d " ,
dbesc ( normalise_link ( $data [ " url " ])),
intval ( $uid ));
if ( ! $contact )
return 0 ;
$contactid = $contact [ 0 ][ " id " ];
}
2015-02-01 10:26:35 +01:00
require_once ( " Photo.php " );
2015-02-01 13:32:05 +01:00
$photos = import_profile_photo ( $data [ " photo " ], $uid , $contactid );
2015-02-01 10:26:35 +01:00
2015-02-01 13:32:05 +01:00
q ( " UPDATE `contact` SET `photo` = '%s', `thumb` = '%s', `micro` = '%s',
`addr` = '%s' , `alias` = '%s' , `name` = '%s' , `nick` = '%s' ,
`name-date` = '%s' , `uri-date` = '%s' , `avatar-date` = '%s' WHERE `id` = % d " ,
2015-02-01 10:26:35 +01:00
dbesc ( $photos [ 0 ]),
dbesc ( $photos [ 1 ]),
dbesc ( $photos [ 2 ]),
2015-02-01 13:32:05 +01:00
dbesc ( $data [ " addr " ]),
dbesc ( $data [ " alias " ]),
dbesc ( $data [ " name " ]),
dbesc ( $data [ " nick " ]),
2015-02-01 10:26:35 +01:00
dbesc ( datetime_convert ()),
dbesc ( datetime_convert ()),
dbesc ( datetime_convert ()),
2015-02-01 13:32:05 +01:00
intval ( $contactid )
2015-02-01 10:26:35 +01:00
);
2015-02-01 13:32:05 +01:00
return $contactid ;
2015-02-01 10:26:35 +01:00
}