Merge branch 'friendika-master'
173
boot.php
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
set_time_limit(0);
|
set_time_limit(0);
|
||||||
|
|
||||||
define ( 'BUILD_ID', 1035 );
|
define ( 'BUILD_ID', 1037 );
|
||||||
define ( 'FRIENDIKA_VERSION', '2.10.0905' );
|
define ( 'FRIENDIKA_VERSION', '2.10.0905' );
|
||||||
define ( 'DFRN_PROTOCOL_VERSION', '2.1' );
|
define ( 'DFRN_PROTOCOL_VERSION', '2.1' );
|
||||||
|
|
||||||
|
@ -215,16 +215,9 @@ class App {
|
||||||
|
|
||||||
$this->scheme = ((isset($_SERVER['HTTPS']) && ($_SERVER['HTTPS'])) ? 'https' : 'http' );
|
$this->scheme = ((isset($_SERVER['HTTPS']) && ($_SERVER['HTTPS'])) ? 'https' : 'http' );
|
||||||
|
|
||||||
if(x($_SERVER,'SERVER_NAME'))
|
if(x($_SERVER,'SERVER_NAME')) {
|
||||||
$this->hostname = $_SERVER['SERVER_NAME'];
|
$this->hostname = $_SERVER['SERVER_NAME'];
|
||||||
|
|
||||||
set_include_path("include/$this->hostname" . PATH_SEPARATOR . 'include' . PATH_SEPARATOR . '.' );
|
|
||||||
|
|
||||||
if((x($_SERVER,'QUERY_STRING')) && substr($_SERVER['QUERY_STRING'],0,2) === "q=")
|
|
||||||
$this->query_string = substr($_SERVER['QUERY_STRING'],2);
|
|
||||||
if(x($_GET,'q'))
|
|
||||||
$this->cmd = trim($_GET['q'],'/\\');
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Figure out if we are running at the top of a domain
|
* Figure out if we are running at the top of a domain
|
||||||
* or in a sub-directory and adjust accordingly
|
* or in a sub-directory and adjust accordingly
|
||||||
|
@ -233,6 +226,15 @@ class App {
|
||||||
$path = trim(dirname($_SERVER['SCRIPT_NAME']),'/\\');
|
$path = trim(dirname($_SERVER['SCRIPT_NAME']),'/\\');
|
||||||
if(isset($path) && strlen($path) && ($path != $this->path))
|
if(isset($path) && strlen($path) && ($path != $this->path))
|
||||||
$this->path = $path;
|
$this->path = $path;
|
||||||
|
}
|
||||||
|
|
||||||
|
set_include_path("include/$this->hostname" . PATH_SEPARATOR . 'include' . PATH_SEPARATOR . '.' );
|
||||||
|
|
||||||
|
if((x($_SERVER,'QUERY_STRING')) && substr($_SERVER['QUERY_STRING'],0,2) === "q=")
|
||||||
|
$this->query_string = substr($_SERVER['QUERY_STRING'],2);
|
||||||
|
if(x($_GET,'q'))
|
||||||
|
$this->cmd = trim($_GET['q'],'/\\');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -295,8 +297,20 @@ class App {
|
||||||
}
|
}
|
||||||
|
|
||||||
function set_baseurl($url) {
|
function set_baseurl($url) {
|
||||||
|
$parsed = parse_url($url);
|
||||||
|
|
||||||
$this->baseurl = $url;
|
$this->baseurl = $url;
|
||||||
$this->hostname = basename($url);
|
|
||||||
|
if($parsed) {
|
||||||
|
$this->scheme = $parsed['scheme'];
|
||||||
|
|
||||||
|
$this->hostname = $parsed['host'];
|
||||||
|
if($parsed['port'])
|
||||||
|
$this->hostname .= ':' . $parsed['port'];
|
||||||
|
if($parsed['path'])
|
||||||
|
$this->path = trim($parsed['path'],'\\/');
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_hostname() {
|
function get_hostname() {
|
||||||
|
@ -406,8 +420,12 @@ function system_unavailable() {
|
||||||
if(! function_exists('check_config')) {
|
if(! function_exists('check_config')) {
|
||||||
function check_config(&$a) {
|
function check_config(&$a) {
|
||||||
|
|
||||||
|
|
||||||
load_config('system');
|
load_config('system');
|
||||||
|
|
||||||
|
if(! x($_SERVER,'SERVER_NAME'))
|
||||||
|
return;
|
||||||
|
|
||||||
$build = get_config('system','build');
|
$build = get_config('system','build');
|
||||||
if(! x($build))
|
if(! x($build))
|
||||||
$build = set_config('system','build',BUILD_ID);
|
$build = set_config('system','build',BUILD_ID);
|
||||||
|
@ -608,7 +626,16 @@ function fetch_url($url,$binary = false, &$redirects = 0) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$a->set_curl_code($http_code);
|
$a->set_curl_code($http_code);
|
||||||
|
|
||||||
$body = substr($s,strlen($header)+4);
|
$body = substr($s,strlen($header)+4);
|
||||||
|
|
||||||
|
/* one more try to make sure there are no more headers */
|
||||||
|
|
||||||
|
if(strpos($body,'HTTP/') === 0) {
|
||||||
|
$header = substr($body,0,strpos($body,"\r\n\r\n"));
|
||||||
|
$body = substr($body,strlen($header)+4);
|
||||||
|
}
|
||||||
|
|
||||||
$a->set_curl_headers($header);
|
$a->set_curl_headers($header);
|
||||||
|
|
||||||
curl_close($ch);
|
curl_close($ch);
|
||||||
|
@ -672,6 +699,14 @@ function post_url($url,$params, $headers = null, &$redirects = 0) {
|
||||||
}
|
}
|
||||||
$a->set_curl_code($http_code);
|
$a->set_curl_code($http_code);
|
||||||
$body = substr($s,strlen($header)+4);
|
$body = substr($s,strlen($header)+4);
|
||||||
|
|
||||||
|
/* one more try to make sure there are no more headers */
|
||||||
|
|
||||||
|
if(strpos($body,'HTTP/') === 0) {
|
||||||
|
$header = substr($body,0,strpos($body,"\r\n\r\n"));
|
||||||
|
$body = substr($body,strlen($header)+4);
|
||||||
|
}
|
||||||
|
|
||||||
$a->set_curl_headers($header);
|
$a->set_curl_headers($header);
|
||||||
|
|
||||||
curl_close($ch);
|
curl_close($ch);
|
||||||
|
@ -744,7 +779,7 @@ function login($register = false) {
|
||||||
$lostpass = t('Forgot your password?');
|
$lostpass = t('Forgot your password?');
|
||||||
$lostlink = t('Password Reset');
|
$lostlink = t('Password Reset');
|
||||||
|
|
||||||
if(x($_SESSION,'authenticated')) {
|
if(local_user()) {
|
||||||
$tpl = load_view_file("view/logout.tpl");
|
$tpl = load_view_file("view/logout.tpl");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -1248,7 +1283,7 @@ function del_pconfig($uid,$family,$key) {
|
||||||
unset($a->config[$uid][$family][$key]);
|
unset($a->config[$uid][$family][$key]);
|
||||||
$ret = q("DELETE FROM `pconfig` WHERE `uid` = %d AND `cat` = '%s' AND `k` = '%s' LIMIT 1",
|
$ret = q("DELETE FROM `pconfig` WHERE `uid` = %d AND `cat` = '%s' AND `k` = '%s' LIMIT 1",
|
||||||
intval($uid),
|
intval($uid),
|
||||||
dbesc($cat),
|
dbesc($family),
|
||||||
dbesc($key)
|
dbesc($key)
|
||||||
);
|
);
|
||||||
return $ret;
|
return $ret;
|
||||||
|
@ -2275,3 +2310,117 @@ function proc_run($cmd){
|
||||||
proc_close(proc_open($cmdline." &",array(),$foo));
|
proc_close(proc_open($cmdline." &",array(),$foo));
|
||||||
}}
|
}}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Return full URL to theme which is currently in effect.
|
||||||
|
* Provide a sane default if nothing is chosen or the specified theme does not exist.
|
||||||
|
*/
|
||||||
|
|
||||||
|
if(! function_exists('current_theme_url')) {
|
||||||
|
function current_theme_url() {
|
||||||
|
|
||||||
|
$app_base_themes = array('duepuntozero', 'loozah');
|
||||||
|
|
||||||
|
$a = get_app();
|
||||||
|
|
||||||
|
$system_theme = ((isset($a->config['system']['theme'])) ? $a->config['system']['theme'] : '');
|
||||||
|
$theme_name = ((x($_SESSION,'theme')) ? $_SESSION['theme'] : $system_theme);
|
||||||
|
|
||||||
|
if($theme_name && file_exists('view/theme/' . $theme_name . '/style.css'))
|
||||||
|
return($a->get_baseurl() . '/view/theme/' . $theme_name . '/style.css');
|
||||||
|
|
||||||
|
foreach($app_base_themes as $t) {
|
||||||
|
if(file_exists('view/theme/' . $t . '/style.css'))
|
||||||
|
return($a->get_baseurl() . '/view/theme/' . $t . '/style.css');
|
||||||
|
}
|
||||||
|
|
||||||
|
$fallback = glob('view/theme/*/style.css');
|
||||||
|
if(count($fallback))
|
||||||
|
return($a->get_baseurl() . $fallback[0]);
|
||||||
|
|
||||||
|
|
||||||
|
}}
|
||||||
|
|
||||||
|
if(! function_exists('feed_birthday')) {
|
||||||
|
function feed_birthday($uid,$tz) {
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* Determine the next birthday, but only if the birthday is published
|
||||||
|
* in the default profile. We _could_ also look for a private profile that the
|
||||||
|
* recipient can see, but somebody could get mad at us if they start getting
|
||||||
|
* public birthday greetings when they haven't made this info public.
|
||||||
|
*
|
||||||
|
* Assuming we are able to publish this info, we are then going to convert
|
||||||
|
* the start time from the owner's timezone to UTC.
|
||||||
|
*
|
||||||
|
* This will potentially solve the problem found with some social networks
|
||||||
|
* where birthdays are converted to the viewer's timezone and salutations from
|
||||||
|
* elsewhere in the world show up on the wrong day. We will convert it to the
|
||||||
|
* viewer's timezone also, but first we are going to convert it from the birthday
|
||||||
|
* person's timezone to GMT - so the viewer may find the birthday starting at
|
||||||
|
* 6:00PM the day before, but that will correspond to midnight to the birthday person.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
$birthday = '';
|
||||||
|
|
||||||
|
$p = q("SELECT `dob` FROM `profile` WHERE `is-default` = 1 AND `uid` = %d LIMIT 1",
|
||||||
|
intval($uid)
|
||||||
|
);
|
||||||
|
|
||||||
|
if($p && count($p)) {
|
||||||
|
$tmp_dob = substr($p[0]['dob'],5);
|
||||||
|
if(intval($tmp_dob)) {
|
||||||
|
$y = datetime_convert($tz,$tz,'now','Y');
|
||||||
|
$bd = $y . '-' . $tmp_dob . ' 00:00';
|
||||||
|
$t_dob = strtotime($bd);
|
||||||
|
$now = strtotime(datetime_convert($tz,$tz,'now'));
|
||||||
|
if($t_dob < $now)
|
||||||
|
$bd = $y + 1 . '-' . $tmp_dob . ' 00:00';
|
||||||
|
$birthday = datetime_convert($tz,'UTC',$bd,ATOM_TIME);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $birthday;
|
||||||
|
}}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* return atom link elements for all of our hubs
|
||||||
|
*/
|
||||||
|
|
||||||
|
if(! function_exists('feed_hublinks')) {
|
||||||
|
function feed_hublinks() {
|
||||||
|
|
||||||
|
$hub = get_config('system','huburl');
|
||||||
|
|
||||||
|
$hubxml = '';
|
||||||
|
if(strlen($hub)) {
|
||||||
|
$hubs = explode(',', $hub);
|
||||||
|
if(count($hubs)) {
|
||||||
|
foreach($hubs as $h) {
|
||||||
|
$h = trim($h);
|
||||||
|
if(! strlen($h))
|
||||||
|
continue;
|
||||||
|
$hubxml .= '<link rel="hub" href="' . xmlify($h) . '" />' . "\n" ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $hubxml;
|
||||||
|
}}
|
||||||
|
|
||||||
|
/* return atom link elements for salmon endpoints */
|
||||||
|
|
||||||
|
if(! function_exists('feed_salmonlinks')) {
|
||||||
|
function feed_salmonlinks($nick) {
|
||||||
|
|
||||||
|
$a = get_app();
|
||||||
|
|
||||||
|
$salmon = '<link rel="salmon" href="' . xmlify($a->get_baseurl() . '/salmon/' . $nick) . '" />' . "\n" ;
|
||||||
|
|
||||||
|
// old style links that status.net still needed as of 12/2010
|
||||||
|
|
||||||
|
$salmon .= ' <link rel="http://salmon-protocol.org/ns/salmon-replies" href="' . xmlify($a->get_baseurl() . '/salmon/' . $nick) . '" />' . "\n" ;
|
||||||
|
$salmon .= ' <link rel="http://salmon-protocol.org/ns/salmon-mention" href="' . xmlify($a->get_baseurl() . '/salmon/' . $nick) . '" />' . "\n" ;
|
||||||
|
return $salmon;
|
||||||
|
}}
|
||||||
|
|
||||||
|
|
|
@ -77,6 +77,7 @@ CREATE TABLE IF NOT EXISTS `contact` (
|
||||||
`subhub` tinyint(1) NOT NULL DEFAULT '0',
|
`subhub` tinyint(1) NOT NULL DEFAULT '0',
|
||||||
`hub-verify` char(255) NOT NULL,
|
`hub-verify` char(255) NOT NULL,
|
||||||
`last-update` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
|
`last-update` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
|
||||||
|
`success_update` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
|
||||||
`name-date` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
|
`name-date` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
|
||||||
`uri-date` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
|
`uri-date` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
|
||||||
`avatar-date` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
|
`avatar-date` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
|
||||||
|
|
|
@ -64,6 +64,10 @@ $a->config['system']['huburl'] = 'http://pubsubhubbub.appspot.com';
|
||||||
|
|
||||||
$a->config['system']['rino_encrypt'] = true;
|
$a->config['system']['rino_encrypt'] = true;
|
||||||
|
|
||||||
|
// default system theme
|
||||||
|
|
||||||
|
$a->config['system']['theme'] = 'duepuntozero';
|
||||||
|
|
||||||
|
|
||||||
// Addons or plugins are configured here.
|
// Addons or plugins are configured here.
|
||||||
// This is a comma seperated list of addons to enable. Example:
|
// This is a comma seperated list of addons to enable. Example:
|
||||||
|
|
|
@ -9,74 +9,27 @@ function get_feed_for(&$a, $dfrn_id, $owner_nick, $last_update, $direction = 0)
|
||||||
|
|
||||||
// default permissions - anonymous user
|
// default permissions - anonymous user
|
||||||
|
|
||||||
$sql_extra = "
|
if(! strlen($owner_nick))
|
||||||
AND `allow_cid` = ''
|
|
||||||
AND `allow_gid` = ''
|
|
||||||
AND `deny_cid` = ''
|
|
||||||
AND `deny_gid` = ''
|
|
||||||
";
|
|
||||||
|
|
||||||
if(strlen($owner_nick) && ! intval($owner_nick)) {
|
|
||||||
$r = q("SELECT `uid`, `nickname`, `timezone` FROM `user` WHERE `nickname` = '%s' LIMIT 1",
|
|
||||||
dbesc($owner_nick)
|
|
||||||
);
|
|
||||||
if(count($r)) {
|
|
||||||
$owner_id = $r[0]['uid'];
|
|
||||||
$owner_nick = $r[0]['nickname'];
|
|
||||||
$owner_tz = $r[0]['timezone'];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$r = q("SELECT * FROM `contact` WHERE `self` = 1 AND `uid` = %d LIMIT 1",
|
|
||||||
intval($owner_id)
|
|
||||||
);
|
|
||||||
if(count($r)) {
|
|
||||||
$owner = $r[0];
|
|
||||||
$owner['nickname'] = $owner_nick;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
killme();
|
killme();
|
||||||
|
|
||||||
|
$sql_extra = " AND `allow_cid` = '' AND `allow_gid` = '' AND `deny_cid` = '' AND `deny_gid` = '' ";
|
||||||
|
|
||||||
/**
|
$r = q("SELECT `contact`.*, `user`.`uid` AS `user_uid`, `user`.`nickname`, `user`.`timezone`
|
||||||
*
|
FROM `contact` LEFT JOIN `user` ON `user`.`uid` = `contact`.`uid`
|
||||||
* Determine the next birthday, but only if the birthday is published
|
WHERE `contact`.`self` = 1 AND `user`.`nickname` = '%s' LIMIT 1",
|
||||||
* in the default profile. We _could_ also look for a private profile that the
|
dbesc($owner_nick)
|
||||||
* recipient can see, but somebody could get mad at us if they start getting
|
|
||||||
* public birthday greetings when they haven't made this info public.
|
|
||||||
*
|
|
||||||
* Assuming we are able to publish this info, we are then going to convert
|
|
||||||
* the start time from the owner's timezone to UTC.
|
|
||||||
*
|
|
||||||
* This will potentially solve the problem found with some social networks
|
|
||||||
* where birthdays are converted to the viewer's timezone and salutations from
|
|
||||||
* elsewhere in the world show up on the wrong day. We will convert it to the
|
|
||||||
* viewer's timezone also, but first we are going to convert it from the birthday
|
|
||||||
* person's timezone to GMT - so the viewer may find the birthday starting at
|
|
||||||
* 6:00PM the day before, but that will correspond to midnight to the birthday person.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
$birthday = '';
|
|
||||||
|
|
||||||
$p = q("SELECT `dob` FROM `profile` WHERE `is-default` = 1 AND `uid` = %d LIMIT 1",
|
|
||||||
intval($owner_id)
|
|
||||||
);
|
);
|
||||||
|
|
||||||
if($p && count($p)) {
|
if(! count($r))
|
||||||
$tmp_dob = substr($p[0]['dob'],5);
|
killme();
|
||||||
if(intval($tmp_dob)) {
|
|
||||||
$y = datetime_convert($owner_tz,$owner_tz,'now','Y');
|
|
||||||
$bd = $y . '-' . $tmp_dob . ' 00:00';
|
|
||||||
$t_dob = strtotime($bd);
|
|
||||||
$now = strtotime(datetime_convert($owner_tz,$owner_tz,'now'));
|
|
||||||
if($t_dob < $now)
|
|
||||||
$bd = $y + 1 . '-' . $tmp_dob . ' 00:00';
|
|
||||||
$birthday = datetime_convert($owner_tz,'UTC',$bd,ATOM_TIME);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if($dfrn_id && $dfrn_id != '*') {
|
$owner = $r[0];
|
||||||
|
$owner_id = $owner['user_uid'];
|
||||||
|
$owner_nick = $owner['nickname'];
|
||||||
|
|
||||||
|
$birthday = feed_birthday($owner_id,$owner['timezone']);
|
||||||
|
|
||||||
|
if(strlen($dfrn_id)) {
|
||||||
|
|
||||||
$sql_extra = '';
|
$sql_extra = '';
|
||||||
switch($direction) {
|
switch($direction) {
|
||||||
|
@ -102,7 +55,7 @@ function get_feed_for(&$a, $dfrn_id, $owner_nick, $last_update, $direction = 0)
|
||||||
);
|
);
|
||||||
|
|
||||||
if(! count($r))
|
if(! count($r))
|
||||||
return false;
|
killme();
|
||||||
|
|
||||||
$contact = $r[0];
|
$contact = $r[0];
|
||||||
$groups = init_groups_visitor($contact['id']);
|
$groups = init_groups_visitor($contact['id']);
|
||||||
|
@ -156,7 +109,7 @@ function get_feed_for(&$a, $dfrn_id, $owner_nick, $last_update, $direction = 0)
|
||||||
);
|
);
|
||||||
|
|
||||||
// Will check further below if this actually returned results.
|
// Will check further below if this actually returned results.
|
||||||
// We will provide an empty feed in any case.
|
// We will provide an empty feed if that is the case.
|
||||||
|
|
||||||
$items = $r;
|
$items = $r;
|
||||||
|
|
||||||
|
@ -164,25 +117,9 @@ function get_feed_for(&$a, $dfrn_id, $owner_nick, $last_update, $direction = 0)
|
||||||
|
|
||||||
$atom = '';
|
$atom = '';
|
||||||
|
|
||||||
$hub = get_config('system','huburl');
|
$hubxml = feed_hublinks();
|
||||||
|
|
||||||
$hubxml = '';
|
|
||||||
if(strlen($hub)) {
|
|
||||||
$hubs = explode(',', $hub);
|
|
||||||
if(count($hubs)) {
|
|
||||||
foreach($hubs as $h) {
|
|
||||||
$h = trim($h);
|
|
||||||
if(! strlen($h))
|
|
||||||
continue;
|
|
||||||
$hubxml .= '<link rel="hub" href="' . xmlify($h) . '" />' . "\n" ;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$salmon = '<link rel="salmon" href="' . xmlify($a->get_baseurl() . '/salmon/' . $owner_nick) . '" />' . "\n" ;
|
|
||||||
$salmon .= '<link rel="http://salmon-protocol.org/ns/salmon-replies" href="' . xmlify($a->get_baseurl() . '/salmon/' . $owner_nick) . '" />' . "\n" ;
|
|
||||||
$salmon .= '<link rel="http://salmon-protocol.org/ns/salmon-mention" href="' . xmlify($a->get_baseurl() . '/salmon/' . $owner_nick) . '" />' . "\n" ;
|
|
||||||
|
|
||||||
|
$salmon = feed_salmonlinks($owner_nick);
|
||||||
|
|
||||||
$atom .= replace_macros($feed_template, array(
|
$atom .= replace_macros($feed_template, array(
|
||||||
'$version' => xmlify(FRIENDIKA_VERSION),
|
'$version' => xmlify(FRIENDIKA_VERSION),
|
||||||
|
@ -215,7 +152,7 @@ function get_feed_for(&$a, $dfrn_id, $owner_nick, $last_update, $direction = 0)
|
||||||
|
|
||||||
// public feeds get html, our own nodes use bbcode
|
// public feeds get html, our own nodes use bbcode
|
||||||
|
|
||||||
if($dfrn_id === '*') {
|
if($dfrn_id === '') {
|
||||||
$type = 'html';
|
$type = 'html';
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -922,12 +859,12 @@ function dfrn_deliver($owner,$contact,$atom, $dissolve = false) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/**
|
||||||
*
|
*
|
||||||
* consume_feed - process atom feed and update anything/everything we might need to update
|
* consume_feed - process atom feed and update anything/everything we might need to update
|
||||||
*
|
*
|
||||||
* $xml = the (atom) feed to consume - no RSS spoken here, it might partially work since simplepie
|
* $xml = the (atom) feed to consume - RSS isn't as fully supported but may work for simple feeds.
|
||||||
* handles both, but we don't claim it will work well, and are reasonably certain it won't.
|
*
|
||||||
* $importer = the contact_record (joined to user_record) of the local user who owns this relationship.
|
* $importer = the contact_record (joined to user_record) of the local user who owns this relationship.
|
||||||
* It is this person's stuff that is going to be updated.
|
* It is this person's stuff that is going to be updated.
|
||||||
* $contact = the person who is sending us stuff. If not set, we MAY be processing a "follow" activity
|
* $contact = the person who is sending us stuff. If not set, we MAY be processing a "follow" activity
|
||||||
|
@ -1094,25 +1031,18 @@ function consume_feed($xml,$importer,&$contact, &$hub, $datedir = 0) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Now process the feed
|
|
||||||
if($feed->get_item_quantity()) {
|
|
||||||
|
|
||||||
// in inverse date order
|
// process any deleted entries
|
||||||
if ($datedir)
|
|
||||||
$items = array_reverse($feed->get_items());
|
|
||||||
else
|
|
||||||
$items = $feed->get_items();
|
|
||||||
|
|
||||||
foreach($items as $item) {
|
|
||||||
|
|
||||||
|
$del_entries = $feed->get_feed_tags(NAMESPACE_TOMB, 'deleted-entry');
|
||||||
|
if(is_array($del_entries) && count($del_entries)) {
|
||||||
|
foreach($del_entries as $dentry) {
|
||||||
$deleted = false;
|
$deleted = false;
|
||||||
|
if(isset($dentry['attribs']['']['ref'])) {
|
||||||
$rawdelete = $item->get_item_tags( NAMESPACE_TOMB, 'deleted-entry');
|
$uri = $dentry['attribs']['']['ref'];
|
||||||
if(isset($rawdelete[0]['attribs']['']['ref'])) {
|
|
||||||
$uri = $rawthread[0]['attribs']['']['ref'];
|
|
||||||
$deleted = true;
|
$deleted = true;
|
||||||
if(isset($rawdelete[0]['attribs']['']['when'])) {
|
if(isset($dentry['attribs']['']['when'])) {
|
||||||
$when = $rawthread[0]['attribs']['']['when'];
|
$when = $dentry['attribs']['']['when'];
|
||||||
$when = datetime_convert('UTC','UTC', $when, 'Y-m-d H:i:s');
|
$when = datetime_convert('UTC','UTC', $when, 'Y-m-d H:i:s');
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -1126,6 +1056,10 @@ function consume_feed($xml,$importer,&$contact, &$hub, $datedir = 0) {
|
||||||
);
|
);
|
||||||
if(count($r)) {
|
if(count($r)) {
|
||||||
$item = $r[0];
|
$item = $r[0];
|
||||||
|
|
||||||
|
if(! $item['deleted'])
|
||||||
|
logger('consume_feed: deleting item ' . $item['id'] . ' uri=' . $item['uri'], LOGGER_DEBUG);
|
||||||
|
|
||||||
if($item['uri'] == $item['parent-uri']) {
|
if($item['uri'] == $item['parent-uri']) {
|
||||||
$r = q("UPDATE `item` SET `deleted` = 1, `edited` = '%s', `changed` = '%s',
|
$r = q("UPDATE `item` SET `deleted` = 1, `edited` = '%s', `changed` = '%s',
|
||||||
`body` = '', `title` = ''
|
`body` = '', `title` = ''
|
||||||
|
@ -1147,7 +1081,7 @@ function consume_feed($xml,$importer,&$contact, &$hub, $datedir = 0) {
|
||||||
);
|
);
|
||||||
if($item['last-child']) {
|
if($item['last-child']) {
|
||||||
// ensure that last-child is set in case the comment that had it just got wiped.
|
// ensure that last-child is set in case the comment that had it just got wiped.
|
||||||
$q("UPDATE `item` SET `last-child` = 0, `changed` = '%s' WHERE `parent-uri` = '%s' AND `uid` = %d ",
|
q("UPDATE `item` SET `last-child` = 0, `changed` = '%s' WHERE `parent-uri` = '%s' AND `uid` = %d ",
|
||||||
dbesc(datetime_convert()),
|
dbesc(datetime_convert()),
|
||||||
dbesc($item['parent-uri']),
|
dbesc($item['parent-uri']),
|
||||||
intval($item['uid'])
|
intval($item['uid'])
|
||||||
|
@ -1166,9 +1100,24 @@ function consume_feed($xml,$importer,&$contact, &$hub, $datedir = 0) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
continue;
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Now process the feed
|
||||||
|
|
||||||
|
if($feed->get_item_quantity()) {
|
||||||
|
|
||||||
|
logger('consume_feed: feed item count = ' . $feed->get_item_quantity());
|
||||||
|
|
||||||
|
// in inverse date order
|
||||||
|
if ($datedir)
|
||||||
|
$items = array_reverse($feed->get_items());
|
||||||
|
else
|
||||||
|
$items = $feed->get_items();
|
||||||
|
|
||||||
|
|
||||||
|
foreach($items as $item) {
|
||||||
|
|
||||||
$is_reply = false;
|
$is_reply = false;
|
||||||
$item_id = $item->get_id();
|
$item_id = $item->get_id();
|
||||||
|
@ -1178,7 +1127,6 @@ function consume_feed($xml,$importer,&$contact, &$hub, $datedir = 0) {
|
||||||
$parent_uri = $rawthread[0]['attribs']['']['ref'];
|
$parent_uri = $rawthread[0]['attribs']['']['ref'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if(($is_reply) && is_array($contact)) {
|
if(($is_reply) && is_array($contact)) {
|
||||||
|
|
||||||
// Have we seen it? If not, import it.
|
// Have we seen it? If not, import it.
|
||||||
|
|
|
@ -87,7 +87,7 @@ function notifier_run($argv, $argc){
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = q("SELECT `contact`.*, `user`.`nickname`, `user`.`sprvkey`, `user`.`spubkey`, `user`.`page-flags`
|
$r = q("SELECT `contact`.*, `user`.`timezone`, `user`.`nickname`, `user`.`sprvkey`, `user`.`spubkey`, `user`.`page-flags`
|
||||||
FROM `contact` LEFT JOIN `user` ON `user`.`uid` = `contact`.`uid`
|
FROM `contact` LEFT JOIN `user` ON `user`.`uid` = `contact`.`uid`
|
||||||
WHERE `contact`.`uid` = %d AND `contact`.`self` = 1 LIMIT 1",
|
WHERE `contact`.`uid` = %d AND `contact`.`self` = 1 LIMIT 1",
|
||||||
intval($uid)
|
intval($uid)
|
||||||
|
@ -179,20 +179,14 @@ function notifier_run($argv, $argc){
|
||||||
$mail_template = load_view_file('view/atom_mail.tpl');
|
$mail_template = load_view_file('view/atom_mail.tpl');
|
||||||
|
|
||||||
$atom = '';
|
$atom = '';
|
||||||
$hubxml = '';
|
|
||||||
$slaps = array();
|
$slaps = array();
|
||||||
|
|
||||||
if(strlen($hub)) {
|
$hubxml = feed_hublinks();
|
||||||
$hubs = explode(',', $hub);
|
|
||||||
if(count($hubs)) {
|
$birthday = feed_birthday($owner['uid'],$owner['timezone']);
|
||||||
foreach($hubs as $h) {
|
|
||||||
$h = trim($h);
|
if(strlen($birthday))
|
||||||
if(! strlen($h))
|
$birthday = '<dfrn:birthday>' . xmlify($birthday) . '</dfrn:birthday>';
|
||||||
continue;
|
|
||||||
$hubxml .= '<link rel="hub" href="' . xmlify($h) . '" />' . "\n" ;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$atom .= replace_macros($feed_template, array(
|
$atom .= replace_macros($feed_template, array(
|
||||||
'$version' => xmlify(FRIENDIKA_VERSION),
|
'$version' => xmlify(FRIENDIKA_VERSION),
|
||||||
|
@ -208,7 +202,7 @@ function notifier_run($argv, $argc){
|
||||||
'$picdate' => xmlify(datetime_convert('UTC','UTC',$owner['avatar-date'] . '+00:00' , ATOM_TIME)) ,
|
'$picdate' => xmlify(datetime_convert('UTC','UTC',$owner['avatar-date'] . '+00:00' , ATOM_TIME)) ,
|
||||||
'$uridate' => xmlify(datetime_convert('UTC','UTC',$owner['uri-date'] . '+00:00' , ATOM_TIME)) ,
|
'$uridate' => xmlify(datetime_convert('UTC','UTC',$owner['uri-date'] . '+00:00' , ATOM_TIME)) ,
|
||||||
'$namdate' => xmlify(datetime_convert('UTC','UTC',$owner['name-date'] . '+00:00' , ATOM_TIME)) ,
|
'$namdate' => xmlify(datetime_convert('UTC','UTC',$owner['name-date'] . '+00:00' , ATOM_TIME)) ,
|
||||||
'$birthday' => ''
|
'$birthday' => $birthday
|
||||||
));
|
));
|
||||||
|
|
||||||
if($cmd === 'mail') {
|
if($cmd === 'mail') {
|
||||||
|
@ -394,7 +388,7 @@ function notifier_run($argv, $argc){
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
$max_allowed = ((get_config('system','maxpubdeliver') === false) ? 150 : intval(get_config('system','maxdeliver')));
|
$max_allowed = ((get_config('system','maxpubdeliver') === false) ? 150 : intval(get_config('system','maxpubdeliver')));
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
|
|
@ -28,7 +28,6 @@ function poller_run($argv, $argc){
|
||||||
// run queue delivery process in the background
|
// run queue delivery process in the background
|
||||||
|
|
||||||
$php_path = ((x($a->config,'php_path') && strlen($a->config['php_path'])) ? $a->config['php_path'] : 'php');
|
$php_path = ((x($a->config,'php_path') && strlen($a->config['php_path'])) ? $a->config['php_path'] : 'php');
|
||||||
//proc_close(proc_open("\"$php_path\" \"include/queue.php\" &", array(), $foo));
|
|
||||||
proc_run($php_path,"include/queue.php");
|
proc_run($php_path,"include/queue.php");
|
||||||
|
|
||||||
// clear old cache
|
// clear old cache
|
||||||
|
@ -239,6 +238,7 @@ function poller_run($argv, $argc){
|
||||||
$xml = post_url($contact['poll'],$postvars);
|
$xml = post_url($contact['poll'],$postvars);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
|
||||||
// $contact['network'] !== 'dfrn'
|
// $contact['network'] !== 'dfrn'
|
||||||
|
|
||||||
$xml = fetch_url($contact['poll']);
|
$xml = fetch_url($contact['poll']);
|
||||||
|
@ -246,8 +246,14 @@ function poller_run($argv, $argc){
|
||||||
|
|
||||||
logger('poller: received xml : ' . $xml, LOGGER_DATA);
|
logger('poller: received xml : ' . $xml, LOGGER_DATA);
|
||||||
|
|
||||||
if(! strlen($xml))
|
if(! strstr($xml,'<?xml')) {
|
||||||
|
logger('poller: post_handshake: response from ' . $url . ' did not contain XML.');
|
||||||
|
$r = q("UPDATE `contact` SET `last-update` = '%s' WHERE `id` = %d LIMIT 1",
|
||||||
|
dbesc(datetime_convert()),
|
||||||
|
intval($contact['id'])
|
||||||
|
);
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
consume_feed($xml,$importer,$contact,$hub,1);
|
consume_feed($xml,$importer,$contact,$hub,1);
|
||||||
|
|
||||||
|
@ -271,8 +277,11 @@ function poller_run($argv, $argc){
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
$r = q("UPDATE `contact` SET `last-update` = '%s' WHERE `id` = %d LIMIT 1",
|
$updated = datetime_convert();
|
||||||
dbesc(datetime_convert()),
|
|
||||||
|
$r = q("UPDATE `contact` SET `last-update` = '%s', `success_update` = '%s' WHERE `id` = %d LIMIT 1",
|
||||||
|
dbesc($updated),
|
||||||
|
dbesc($updated),
|
||||||
intval($contact['id'])
|
intval($contact['id'])
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
13
index.php
|
@ -238,21 +238,10 @@ if($a->module != 'install')
|
||||||
require_once('nav.php');
|
require_once('nav.php');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
|
||||||
* Build the page - now that we have all the components
|
* Build the page - now that we have all the components
|
||||||
* Make sure the desired theme exists, though if the default theme doesn't exist we're stuffed.
|
|
||||||
*
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
$default_theme = ((isset($a->config['system']['theme'])) ? $a->config['system']['theme'] : 'default');
|
$a->page['htmlhead'] = replace_macros($a->page['htmlhead'], array('$stylesheet' => current_theme_url()));
|
||||||
if((x($_SESSION,'theme')) && (! file_exists('view/theme/' . $_SESSION['theme'] . '/style.css')))
|
|
||||||
unset($_SESSION['theme']);
|
|
||||||
|
|
||||||
$a->page['htmlhead'] = replace_macros($a->page['htmlhead'], array(
|
|
||||||
'$stylesheet' => $a->get_baseurl() . '/view/theme/'
|
|
||||||
. ((x($_SESSION,'theme')) ? $_SESSION['theme'] : $default_theme)
|
|
||||||
. '/style.css'
|
|
||||||
));
|
|
||||||
|
|
||||||
$page = $a->page;
|
$page = $a->page;
|
||||||
$profile = $a->profile;
|
$profile = $a->profile;
|
||||||
|
|
|
@ -245,6 +245,13 @@ function contacts_content(&$a) {
|
||||||
$sparkle = '';
|
$sparkle = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$last_update = (($r[0]['last-update'] == '0000-00-00 00:00:00')
|
||||||
|
? t('Never')
|
||||||
|
: datetime_convert('UTC',date_default_timezone_get(),$r[0]['last-update'],'D, j M Y, g:i A'));
|
||||||
|
|
||||||
|
if($r[0]['last-update'] !== '0000-00-00 00:00:00')
|
||||||
|
$last_update .= ' ' . (($r[0]['last-update'] == $r[0]['success_update']) ? t("\x28Update was successful\x29") : t("\x28Update was not successful\x29"));
|
||||||
|
|
||||||
$o .= replace_macros($tpl,array(
|
$o .= replace_macros($tpl,array(
|
||||||
'$header' => t('Contact Editor'),
|
'$header' => t('Contact Editor'),
|
||||||
'$visit' => t('Visit $name\'s profile'),
|
'$visit' => t('Visit $name\'s profile'),
|
||||||
|
@ -254,9 +261,7 @@ function contacts_content(&$a) {
|
||||||
'$poll_interval' => contact_poll_interval($r[0]['priority']),
|
'$poll_interval' => contact_poll_interval($r[0]['priority']),
|
||||||
'$lastupdtext' => t('Last updated: '),
|
'$lastupdtext' => t('Last updated: '),
|
||||||
'$updpub' => t('Update public posts: '),
|
'$updpub' => t('Update public posts: '),
|
||||||
'$last_update' => (($r[0]['last-update'] == '0000-00-00 00:00:00')
|
'$last_update' => $last_update,
|
||||||
? t('Never')
|
|
||||||
: datetime_convert('UTC',date_default_timezone_get(),$r[0]['last-update'],'D, j M Y, g:i A')),
|
|
||||||
'$udnow' => t('Update now'),
|
'$udnow' => t('Update now'),
|
||||||
'$profile_select' => contact_profile_assign($r[0]['profile-id'],(($r[0]['network'] !== 'dfrn') ? true : false)),
|
'$profile_select' => contact_profile_assign($r[0]['profile-id'],(($r[0]['network'] !== 'dfrn') ? true : false)),
|
||||||
'$contact_id' => $r[0]['id'],
|
'$contact_id' => $r[0]['id'],
|
||||||
|
|
|
@ -200,16 +200,17 @@ function dfrn_notify_post(&$a) {
|
||||||
|
|
||||||
logger('dfrn_notify: feed item count = ' . $feed->get_item_quantity());
|
logger('dfrn_notify: feed item count = ' . $feed->get_item_quantity());
|
||||||
|
|
||||||
foreach($feed->get_items() as $item) {
|
// process any deleted entries
|
||||||
|
|
||||||
|
$del_entries = $feed->get_feed_tags(NAMESPACE_TOMB, 'deleted-entry');
|
||||||
|
if(is_array($del_entries) && count($del_entries)) {
|
||||||
|
foreach($del_entries as $dentry) {
|
||||||
$deleted = false;
|
$deleted = false;
|
||||||
|
if(isset($dentry['attribs']['']['ref'])) {
|
||||||
$rawdelete = $item->get_item_tags( NAMESPACE_TOMB , 'deleted-entry');
|
$uri = $dentry['attribs']['']['ref'];
|
||||||
if(isset($rawdelete[0]['attribs']['']['ref'])) {
|
|
||||||
$uri = $rawthread[0]['attribs']['']['ref'];
|
|
||||||
$deleted = true;
|
$deleted = true;
|
||||||
if(isset($rawdelete[0]['attribs']['']['when'])) {
|
if(isset($dentry['attribs']['']['when'])) {
|
||||||
$when = $rawthread[0]['attribs']['']['when'];
|
$when = $dentry['attribs']['']['when'];
|
||||||
$when = datetime_convert('UTC','UTC', $when, 'Y-m-d H:i:s');
|
$when = datetime_convert('UTC','UTC', $when, 'Y-m-d H:i:s');
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -222,6 +223,10 @@ function dfrn_notify_post(&$a) {
|
||||||
);
|
);
|
||||||
if(count($r)) {
|
if(count($r)) {
|
||||||
$item = $r[0];
|
$item = $r[0];
|
||||||
|
|
||||||
|
if(! $item['deleted'])
|
||||||
|
logger('dfrn_notify: deleting item ' . $item['id'] . ' uri=' . $item['uri'], LOGGER_DEBUG);
|
||||||
|
|
||||||
if($item['uri'] == $item['parent-uri']) {
|
if($item['uri'] == $item['parent-uri']) {
|
||||||
$r = q("UPDATE `item` SET `deleted` = 1, `edited` = '%s', `changed` = '%s'
|
$r = q("UPDATE `item` SET `deleted` = 1, `edited` = '%s', `changed` = '%s'
|
||||||
WHERE `parent-uri` = '%s' AND `uid` = %d",
|
WHERE `parent-uri` = '%s' AND `uid` = %d",
|
||||||
|
@ -241,7 +246,7 @@ function dfrn_notify_post(&$a) {
|
||||||
);
|
);
|
||||||
if($item['last-child']) {
|
if($item['last-child']) {
|
||||||
// ensure that last-child is set in case the comment that had it just got wiped.
|
// ensure that last-child is set in case the comment that had it just got wiped.
|
||||||
$q("UPDATE `item` SET `last-child` = 0, `changed` = '%s' WHERE `parent-uri` = '%s' AND `uid` = %d ",
|
q("UPDATE `item` SET `last-child` = 0, `changed` = '%s' WHERE `parent-uri` = '%s' AND `uid` = %d ",
|
||||||
dbesc(datetime_convert()),
|
dbesc(datetime_convert()),
|
||||||
dbesc($item['parent-uri']),
|
dbesc($item['parent-uri']),
|
||||||
intval($item['uid'])
|
intval($item['uid'])
|
||||||
|
@ -260,8 +265,12 @@ function dfrn_notify_post(&$a) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
continue;
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
foreach($feed->get_items() as $item) {
|
||||||
|
|
||||||
$is_reply = false;
|
$is_reply = false;
|
||||||
$item_id = $item->get_id();
|
$item_id = $item->get_id();
|
||||||
|
@ -337,7 +346,6 @@ function dfrn_notify_post(&$a) {
|
||||||
$email_tpl, "From: " . t('Administrator') . '@' . $a->get_hostname() );
|
$email_tpl, "From: " . t('Administrator') . '@' . $a->get_hostname() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
xml_status(0);
|
xml_status(0);
|
||||||
// NOTREACHED
|
// NOTREACHED
|
||||||
}
|
}
|
||||||
|
@ -372,7 +380,6 @@ function dfrn_notify_post(&$a) {
|
||||||
$datarray['type'] = 'activity';
|
$datarray['type'] = 'activity';
|
||||||
$datarray['gravity'] = GRAVITY_LIKE;
|
$datarray['gravity'] = GRAVITY_LIKE;
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = item_store($datarray);
|
$r = item_store($datarray);
|
||||||
|
|
||||||
// find out if our user is involved in this conversation and wants to be notified.
|
// find out if our user is involved in this conversation and wants to be notified.
|
||||||
|
|
|
@ -28,7 +28,7 @@ function dfrn_poll_init(&$a) {
|
||||||
if(($dfrn_id === '') && (! x($_POST,'dfrn_id')) && ($a->argc > 1)) {
|
if(($dfrn_id === '') && (! x($_POST,'dfrn_id')) && ($a->argc > 1)) {
|
||||||
logger('dfrn_poll: public feed request from ' . $_SERVER['REMOTE_ADDR'] );
|
logger('dfrn_poll: public feed request from ' . $_SERVER['REMOTE_ADDR'] );
|
||||||
header("Content-type: application/atom+xml");
|
header("Content-type: application/atom+xml");
|
||||||
$o = get_feed_for($a, '*', $a->argv[1],$last_update);
|
$o = get_feed_for($a, '', $a->argv[1],$last_update);
|
||||||
echo $o;
|
echo $o;
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
|
@ -268,6 +268,13 @@ foreach($_FILES AS $key => $val) {
|
||||||
intval($page_owner_uid)
|
intval($page_owner_uid)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Don't make the item visible if the only change was the album name */
|
||||||
|
|
||||||
|
$visibility = 0;
|
||||||
|
if($p[0]['desc'] !== $desc || strlen($rawtags))
|
||||||
|
$visibility = 1;
|
||||||
|
|
||||||
if(! $item_id) {
|
if(! $item_id) {
|
||||||
|
|
||||||
// Create item container
|
// Create item container
|
||||||
|
@ -297,6 +304,7 @@ foreach($_FILES AS $key => $val) {
|
||||||
$arr['deny_cid'] = $p[0]['deny_cid'];
|
$arr['deny_cid'] = $p[0]['deny_cid'];
|
||||||
$arr['deny_gid'] = $p[0]['deny_gid'];
|
$arr['deny_gid'] = $p[0]['deny_gid'];
|
||||||
$arr['last-child'] = 1;
|
$arr['last-child'] = 1;
|
||||||
|
$arr['visible'] = $visibility;
|
||||||
$arr['body'] = '[url=' . $a->get_baseurl() . '/photos/' . $a->data['user']['nickname'] . '/image/' . $p[0]['resource-id'] . ']'
|
$arr['body'] = '[url=' . $a->get_baseurl() . '/photos/' . $a->data['user']['nickname'] . '/image/' . $p[0]['resource-id'] . ']'
|
||||||
. '[img]' . $a->get_baseurl() . '/photo/' . $p[0]['resource-id'] . '-' . $p[0]['scale'] . '.jpg' . '[/img]'
|
. '[img]' . $a->get_baseurl() . '/photo/' . $p[0]['resource-id'] . '-' . $p[0]['scale'] . '.jpg' . '[/img]'
|
||||||
. '[/url]';
|
. '[/url]';
|
||||||
|
|
21
update.php
|
@ -342,3 +342,24 @@ function update_1034() {
|
||||||
q("DELETE FROM `item` WHERE `parent` = 0 AND `created` < UTC_TIMESTAMP() - INTERVAL 2 MINUTE");
|
q("DELETE FROM `item` WHERE `parent` = 0 AND `created` < UTC_TIMESTAMP() - INTERVAL 2 MINUTE");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function update_1035() {
|
||||||
|
|
||||||
|
q("ALTER TABLE `contact` ADD `success_update` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `last-update` ");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function update_1036() {
|
||||||
|
|
||||||
|
$r = dbq("SELECT * FROM `contact` WHERE `network` = 'dfrn' && `photo` LIKE '%include/photo%' ");
|
||||||
|
if(count($r)) {
|
||||||
|
foreach($r as $rr) {
|
||||||
|
q("UPDATE `contact` SET `photo` = '%s', `thumb` = '%s', `micro` = '%s' WHERE `id` = %d LIMIT 1",
|
||||||
|
dbesc(str_replace('include/photo','photo',$rr['photo'])),
|
||||||
|
dbesc(str_replace('include/photo','photo',$rr['thumb'])),
|
||||||
|
dbesc(str_replace('include/photo','photo',$rr['micro'])),
|
||||||
|
intval($rr['id']));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
|
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
|
||||||
<base href="$baseurl" />
|
<base href="$baseurl" />
|
||||||
<link rel="stylesheet" type="text/css" href="$stylesheet" media="all" />
|
<link rel="stylesheet" type="text/css" href="$stylesheet" media="all" />
|
||||||
<link rel="shortcut icon" href="$baseurl/images/ff-32.jpg">
|
<link rel="shortcut icon" href="$baseurl/images/ff-32.jpg" />
|
||||||
|
|
||||||
<!--[if IE]>
|
<!--[if IE]>
|
||||||
<script type="text/javascript" src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
<script type="text/javascript" src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||||
|
|
|
@ -62,3 +62,13 @@ $a->config['system']['huburl'] = 'http://pubsubhubbub.appspot.com';
|
||||||
|
|
||||||
$a->config['system']['rino_encrypt'] = true;
|
$a->config['system']['rino_encrypt'] = true;
|
||||||
|
|
||||||
|
// default system theme
|
||||||
|
|
||||||
|
$a->config['system']['theme'] = 'duepuntozero';
|
||||||
|
|
||||||
|
// Addons or plugins are configured here.
|
||||||
|
// This is a comma seperated list of addons to enable. Example:
|
||||||
|
// $a->config['system']['addon'] = 'js_upload,randplace,oembed';
|
||||||
|
|
||||||
|
$a->config['system']['addon'] = 'js_upload';
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
<base href="$baseurl" />
|
<base href="$baseurl" />
|
||||||
<meta name="generator" content="$generator" />
|
<meta name="generator" content="$generator" />
|
||||||
<link rel="stylesheet" type="text/css" href="$stylesheet" media="all" />
|
<link rel="stylesheet" type="text/css" href="$stylesheet" media="all" />
|
||||||
<link rel="shortcut icon" href="$baseurl/images/ff-32.jpg">
|
<link rel="shortcut icon" href="$baseurl/images/ff-32.jpg" />
|
||||||
|
|
||||||
<!--[if IE]>
|
<!--[if IE]>
|
||||||
<script type="text/javascript" src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
<script type="text/javascript" src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||||
|
|
|
@ -62,6 +62,10 @@ $a->config['system']['huburl'] = 'http://pubsubhubbub.appspot.com';
|
||||||
|
|
||||||
$a->config['system']['rino_encrypt'] = true;
|
$a->config['system']['rino_encrypt'] = true;
|
||||||
|
|
||||||
|
// default system theme
|
||||||
|
|
||||||
|
$a->config['system']['theme'] = 'duepuntozero';
|
||||||
|
|
||||||
// Addons or plugins are configured here.
|
// Addons or plugins are configured here.
|
||||||
// This is a comma seperated list of addons to enable. Example:
|
// This is a comma seperated list of addons to enable. Example:
|
||||||
// $a->config['system']['addon'] = 'js_upload,randplace,oembed';
|
// $a->config['system']['addon'] = 'js_upload,randplace,oembed';
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
<base href="$baseurl" />
|
<base href="$baseurl" />
|
||||||
<meta name="generator" content="$generator" />
|
<meta name="generator" content="$generator" />
|
||||||
<link rel="stylesheet" type="text/css" href="$stylesheet" media="all" />
|
<link rel="stylesheet" type="text/css" href="$stylesheet" media="all" />
|
||||||
<link rel="shortcut icon" href="$baseurl/images/ff-32.jpg">
|
<link rel="shortcut icon" href="$baseurl/images/ff-32.jpg" />
|
||||||
|
|
||||||
<!--[if IE]>
|
<!--[if IE]>
|
||||||
<script type="text/javascript" src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
<script type="text/javascript" src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||||
|
|
|
@ -62,3 +62,12 @@ $a->config['system']['huburl'] = 'http://pubsubhubbub.appspot.com';
|
||||||
|
|
||||||
$a->config['system']['rino_encrypt'] = true;
|
$a->config['system']['rino_encrypt'] = true;
|
||||||
|
|
||||||
|
// default system theme
|
||||||
|
|
||||||
|
$a->config['system']['theme'] = 'duepuntozero';
|
||||||
|
|
||||||
|
// Addons or plugins are configured here.
|
||||||
|
// This is a comma seperated list of addons to enable. Example:
|
||||||
|
// $a->config['system']['addon'] = 'js_upload,randplace,oembed';
|
||||||
|
|
||||||
|
$a->config['system']['addon'] = 'js_upload';
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
<base href="$baseurl" />
|
<base href="$baseurl" />
|
||||||
<meta name="generator" content="$generator" />
|
<meta name="generator" content="$generator" />
|
||||||
<link rel="stylesheet" type="text/css" href="$stylesheet" media="all" />
|
<link rel="stylesheet" type="text/css" href="$stylesheet" media="all" />
|
||||||
<link rel="shortcut icon" href="$baseurl/images/ff-32.jpg">
|
<link rel="shortcut icon" href="$baseurl/images/ff-32.jpg" />
|
||||||
|
|
||||||
<!--[if IE]>
|
<!--[if IE]>
|
||||||
<script type="text/javascript" src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
<script type="text/javascript" src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||||
|
|
|
@ -62,3 +62,12 @@ $a->config['system']['huburl'] = 'http://pubsubhubbub.appspot.com';
|
||||||
|
|
||||||
$a->config['system']['rino_encrypt'] = true;
|
$a->config['system']['rino_encrypt'] = true;
|
||||||
|
|
||||||
|
// default system theme
|
||||||
|
|
||||||
|
$a->config['system']['theme'] = 'duepuntozero';
|
||||||
|
|
||||||
|
// Addons or plugins are configured here.
|
||||||
|
// This is a comma seperated list of addons to enable. Example:
|
||||||
|
// $a->config['system']['addon'] = 'js_upload,randplace,oembed';
|
||||||
|
|
||||||
|
$a->config['system']['addon'] = 'js_upload';
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
@import url('../default/style.css');
|
@import url('../loozah/style.css');
|
||||||
|
|
||||||
footer {
|
footer {
|
||||||
background: #CCC;
|
background: #CCC;
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
@import url('../default/style.css');
|
@import url('../loozah/style.css');
|
||||||
|
|
||||||
nav {
|
nav {
|
||||||
background: #CCC;
|
background: #CCC;
|
||||||
|
|
Before Width: | Height: | Size: 109 B |
Before Width: | Height: | Size: 1 KiB |
|
@ -1210,7 +1210,8 @@ input#dfrn-url {
|
||||||
margin-top: 30px;
|
margin-top: 30px;
|
||||||
}
|
}
|
||||||
#contact-edit-poll-text {
|
#contact-edit-poll-text {
|
||||||
margin-bottom: 10px;
|
margin-top: 15px;
|
||||||
|
margin-bottom: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#contact-edit-update-now {
|
#contact-edit-update-now {
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
@import url('../default/style.css');
|
@import url('../loozah/style.css');
|
||||||
|
|
||||||
footer {
|
footer {
|
||||||
background: #CCC;
|
background: #CCC;
|
||||||
|
|
Before Width: | Height: | Size: 644 B After Width: | Height: | Size: 644 B |
Before Width: | Height: | Size: 4.2 KiB After Width: | Height: | Size: 4.2 KiB |
Before Width: | Height: | Size: 237 B After Width: | Height: | Size: 237 B |
|
@ -1335,8 +1335,10 @@ input#dfrn-url {
|
||||||
margin-top: 30px;
|
margin-top: 30px;
|
||||||
}
|
}
|
||||||
#contact-edit-poll-text {
|
#contact-edit-poll-text {
|
||||||
margin-bottom: 10px;
|
margin-top: 15px;
|
||||||
|
margin-bottom: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#contact-edit-update-now {
|
#contact-edit-update-now {
|
||||||
margin-top: 15px;
|
margin-top: 15px;
|
||||||
}
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
@import url('../default/style.css');
|
@import url('../loozah/style.css');
|
||||||
|
|
||||||
body {
|
body {
|
||||||
background: #DDDDDD;
|
background: #DDDDDD;
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
@import url('../default/style.css');
|
@import url('../loozah/style.css');
|
||||||
|
|
||||||
.error-message {
|
.error-message {
|
||||||
-moz-box-shadow: 5px 5px 5px #888888;
|
-moz-box-shadow: 5px 5px 5px #888888;
|
||||||
|
|