mirror of
https://git.friendi.ca/friendica/friendica-addons.git
synced 2025-01-18 14:44:32 +00:00
Merge branch 'master' of https://github.com/friendica/friendica-addons
This commit is contained in:
commit
0adfd83b65
19 changed files with 195 additions and 55 deletions
3
altpager/admin.tpl
Executable file
3
altpager/admin.tpl
Executable file
|
@ -0,0 +1,3 @@
|
||||||
|
{{ inc field_radio.tpl with $field=$global }}{{ endinc }}
|
||||||
|
{{ inc field_radio.tpl with $field=$individual }}{{ endinc }}
|
||||||
|
<div class="submit"><input type="submit" name="page_site" value="$submit" /></div>
|
|
@ -61,6 +61,10 @@ function altpager_settings(&$a,&$s) {
|
||||||
if(! local_user())
|
if(! local_user())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
$global = get_config("alt_pager", "global");
|
||||||
|
if($global == 1)
|
||||||
|
return;
|
||||||
|
|
||||||
/* Add our stylesheet to the page so we can make our settings look nice */
|
/* Add our stylesheet to the page so we can make our settings look nice */
|
||||||
|
|
||||||
$a->page['htmlhead'] .= '<link rel="stylesheet" type="text/css" href="' . $a->get_baseurl() . '/addon/altpager/altpager.css' . '" media="all" />' . "\r\n";
|
$a->page['htmlhead'] .= '<link rel="stylesheet" type="text/css" href="' . $a->get_baseurl() . '/addon/altpager/altpager.css' . '" media="all" />' . "\r\n";
|
||||||
|
@ -87,3 +91,18 @@ function altpager_settings(&$a,&$s) {
|
||||||
$s .= '<div class="settings-submit-wrapper" ><input type="submit" name="altpager-submit" class="settings-submit" value="' . t('Submit') . '" /></div></div>';
|
$s .= '<div class="settings-submit-wrapper" ><input type="submit" name="altpager-submit" class="settings-submit" value="' . t('Submit') . '" /></div></div>';
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function altpager_plugin_admin(&$a, &$o){
|
||||||
|
$t = file_get_contents( $a->get_baseurl() . "/addon/altpager/admin.tpl" );
|
||||||
|
$o = replace_macros($t, array(
|
||||||
|
'$submit' => t('Submit'),
|
||||||
|
'$global' => array('altpagerchoice', t('Global'), 1, t('Force global use of the alternate pager'), get_config('alt_pager', 'global') == 1),
|
||||||
|
'$individual' => array('altpagerchoice', t('Individual'), 2, t('Each user chooses whether to use the alternate pager'), get_config('alt_pager', 'global') == 0)
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
function altpager_plugin_admin_post(&$a){
|
||||||
|
$choice = ((x($_POST,'altpagerchoice')) ? notags(trim($_POST['altpagerchoice'])) : '');
|
||||||
|
set_config('alt_pager','global',($choice == 1 ? 1 : 0));
|
||||||
|
info( t('Settings updated.'). EOL );
|
||||||
|
}
|
||||||
|
|
BIN
convert.tgz
BIN
convert.tgz
Binary file not shown.
BIN
editplain.tgz
BIN
editplain.tgz
Binary file not shown.
BIN
fbpost.tgz
BIN
fbpost.tgz
Binary file not shown.
|
@ -140,11 +140,18 @@ function fbpost_post(&$a) {
|
||||||
$value = ((x($_POST,'post_by_default')) ? intval($_POST['post_by_default']) : 0);
|
$value = ((x($_POST,'post_by_default')) ? intval($_POST['post_by_default']) : 0);
|
||||||
set_pconfig($uid,'facebook','post_by_default', $value);
|
set_pconfig($uid,'facebook','post_by_default', $value);
|
||||||
|
|
||||||
|
$value = ((x($_POST,'suppress_view_on_friendica')) ? intval($_POST['suppress_view_on_friendica']) : 0);
|
||||||
|
set_pconfig($uid,'facebook','suppress_view_on_friendica', $value);
|
||||||
|
|
||||||
|
$value = ((x($_POST,'post_to_page')) ? $_POST['post_to_page'] : "0-0");
|
||||||
|
$values = explode("-", $value);
|
||||||
|
set_pconfig($uid,'facebook','post_to_page', $values[0]);
|
||||||
|
set_pconfig($uid,'facebook','page_access_token', $values[1]);
|
||||||
|
|
||||||
info( t('Settings updated.') . EOL);
|
info( t('Settings updated.') . EOL);
|
||||||
}
|
}
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Facebook settings form
|
// Facebook settings form
|
||||||
|
@ -202,7 +209,7 @@ function fbpost_content(&$a) {
|
||||||
$o .= '<div id="fbpost-enable-wrapper">';
|
$o .= '<div id="fbpost-enable-wrapper">';
|
||||||
|
|
||||||
$o .= '<a href="https://www.facebook.com/dialog/oauth?client_id=' . $appid . '&redirect_uri='
|
$o .= '<a href="https://www.facebook.com/dialog/oauth?client_id=' . $appid . '&redirect_uri='
|
||||||
. $a->get_baseurl() . '/fbpost/' . $a->user['nickname'] . '&scope=publish_stream,offline_access">' . t('Install Facebook Post connector for this account.') . '</a>';
|
. $a->get_baseurl() . '/fbpost/' . $a->user['nickname'] . '&scope=publish_stream,manage_pages,photo_upload,user_groups,offline_access">' . t('Install Facebook Post connector for this account.') . '</a>';
|
||||||
$o .= '</div>';
|
$o .= '</div>';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -214,16 +221,56 @@ function fbpost_content(&$a) {
|
||||||
$o .= '<div id="fbpost-enable-wrapper">';
|
$o .= '<div id="fbpost-enable-wrapper">';
|
||||||
|
|
||||||
$o .= '<a href="https://www.facebook.com/dialog/oauth?client_id=' . $appid . '&redirect_uri='
|
$o .= '<a href="https://www.facebook.com/dialog/oauth?client_id=' . $appid . '&redirect_uri='
|
||||||
. $a->get_baseurl() . '/fbpost/' . $a->user['nickname'] . '&scope=publish_stream,offline_access">' . t('Re-authenticate [This is necessary whenever your Facebook password is changed.]') . '</a>';
|
. $a->get_baseurl() . '/fbpost/' . $a->user['nickname'] . '&scope=publish_stream,manage_pages,photo_upload,user_groups,offline_access">' . t('Re-authenticate [This is necessary whenever your Facebook password is changed.]') . '</a>';
|
||||||
$o .= '</div>';
|
$o .= '</div>';
|
||||||
|
|
||||||
$o .= '<div id="fbpost-post-default-form">';
|
$o .= '<div id="fbpost-post-default-form">';
|
||||||
$o .= '<form action="fbpost" method="post" >';
|
$o .= '<form action="fbpost" method="post" >';
|
||||||
$post_by_default = get_pconfig(local_user(),'facebook','post_by_default');
|
$post_by_default = get_pconfig(local_user(),'facebook','post_by_default');
|
||||||
$checked = (($post_by_default) ? ' checked="checked" ' : '');
|
$checked = (($post_by_default) ? ' checked="checked" ' : '');
|
||||||
$o .= '<input type="checkbox" name="post_by_default" value="1"' . $checked . '/>' . ' ' . t('Post to Facebook by default') . EOL;
|
$o .= '<input type="checkbox" name="post_by_default" value="1"' . $checked . '/>' . ' ' . t('Post to Facebook by default') . EOL;
|
||||||
|
|
||||||
$o .= '<input type="submit" name="submit" value="' . t('Submit') . '" /></form></div>';
|
$suppress_view_on_friendica = get_pconfig(local_user(),'facebook','suppress_view_on_friendica');
|
||||||
|
$checked = (($suppress_view_on_friendica) ? ' checked="checked" ' : '');
|
||||||
|
$o .= '<input type="checkbox" name="suppress_view_on_friendica" value="1"' . $checked . '/>' . ' ' . t('Suppress "View on friendica"') . EOL;
|
||||||
|
|
||||||
|
// List all pages
|
||||||
|
$post_to_page = get_pconfig(local_user(),'facebook','post_to_page');
|
||||||
|
$page_access_token = get_pconfig(local_user(),'facebook','page_access_token');
|
||||||
|
$fb_token = get_pconfig($a->user['uid'],'facebook','access_token');
|
||||||
|
$url = 'https://graph.facebook.com/me/accounts';
|
||||||
|
$x = file_get_contents($url."?access_token=".$fb_token);
|
||||||
|
$accounts = json_decode($x);
|
||||||
|
|
||||||
|
$o .= t("Post to page/group:")."<select name='post_to_page'>";
|
||||||
|
if (intval($post_to_page) == 0)
|
||||||
|
$o .= "<option value='0-0' selected>".t('None')."</option>";
|
||||||
|
else
|
||||||
|
$o .= "<option value='0-0'>".t('None')."</option>";
|
||||||
|
|
||||||
|
foreach($accounts->data as $account) {
|
||||||
|
if (is_array($account->perms))
|
||||||
|
if ($post_to_page == $account->id)
|
||||||
|
$o .= "<option value='".$account->id."-".$account->access_token."' selected>".$account->name."</option>";
|
||||||
|
else
|
||||||
|
$o .= "<option value='".$account->id."-".$account->access_token."'>".$account->name."</option>";
|
||||||
|
}
|
||||||
|
|
||||||
|
$url = 'https://graph.facebook.com/me/groups';
|
||||||
|
$x = file_get_contents($url."?access_token=".$fb_token);
|
||||||
|
$groups = json_decode($x);
|
||||||
|
|
||||||
|
foreach($groups->data as $group) {
|
||||||
|
if ($post_to_page == $group->id)
|
||||||
|
$o .= "<option value='".$group->id."-0' selected>".$group->name."</option>";
|
||||||
|
else
|
||||||
|
$o .= "<option value='".$group->id."-0'>".$group->name."</option>";
|
||||||
|
}
|
||||||
|
|
||||||
|
$o .= "</select>";
|
||||||
|
|
||||||
|
$o .= '<p><input type="submit" name="submit" value="' . t('Submit') . '" /></form></div>';
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return $o;
|
return $o;
|
||||||
|
@ -353,10 +400,10 @@ function fbpost_post_hook(&$a,&$b) {
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// only accept comments from the item owner. Other contacts are unknown to FB.
|
// only accept comments from the item owner. Other contacts are unknown to FB.
|
||||||
|
|
||||||
if(! link_compare($b['author-link'], $a->get_baseurl() . '/profile/' . $u[0]['nickname']))
|
if(! link_compare($b['author-link'], $a->get_baseurl() . '/profile/' . $u[0]['nickname']))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|
||||||
logger('facebook reply id=' . $reply);
|
logger('facebook reply id=' . $reply);
|
||||||
}
|
}
|
||||||
|
@ -408,7 +455,7 @@ function fbpost_post_hook(&$a,&$b) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if($b['verb'] == ACTIVITY_LIKE)
|
if($b['verb'] == ACTIVITY_LIKE)
|
||||||
$likes = true;
|
$likes = true;
|
||||||
|
|
||||||
|
|
||||||
$appid = get_config('facebook', 'appid' );
|
$appid = get_config('facebook', 'appid' );
|
||||||
|
@ -421,9 +468,9 @@ function fbpost_post_hook(&$a,&$b) {
|
||||||
$fb_token = get_pconfig($b['uid'],'facebook','access_token');
|
$fb_token = get_pconfig($b['uid'],'facebook','access_token');
|
||||||
|
|
||||||
|
|
||||||
// post to facebook if it's a public post and we've ticked the 'post to Facebook' box,
|
// post to facebook if it's a public post and we've ticked the 'post to Facebook' box,
|
||||||
// or it's a private message with facebook participants
|
// or it's a private message with facebook participants
|
||||||
// or it's a reply or likes action to an existing facebook post
|
// or it's a reply or likes action to an existing facebook post
|
||||||
|
|
||||||
if($fb_token && ($toplevel || $b['private'] || $reply)) {
|
if($fb_token && ($toplevel || $b['private'] || $reply)) {
|
||||||
logger('facebook: able to post');
|
logger('facebook: able to post');
|
||||||
|
@ -506,11 +553,34 @@ function fbpost_post_hook(&$a,&$b) {
|
||||||
$body = $body1.$body2;
|
$body = $body1.$body2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Convert recycle signs
|
||||||
|
$body = str_replace("\t", " ", $body);
|
||||||
|
// recycle 1
|
||||||
|
$recycle = html_entity_decode("♲ ", ENT_QUOTES, 'UTF-8');
|
||||||
|
$body = preg_replace( '/'.$recycle.'\[url\=(\w+.*?)\](\w+.*?)\[\/url\]/i', "\n\t$2:\t", $body);
|
||||||
|
// recycle 2 (Test)
|
||||||
|
$recycle = html_entity_decode("◌ ", ENT_QUOTES, 'UTF-8');
|
||||||
|
$body = preg_replace( '/'.$recycle.'\[url\=(\w+.*?)\](\w+.*?)\[\/url\]/i', "\n\t$2:\t", $body);
|
||||||
|
|
||||||
|
$bodyparts = explode("\t", $body);
|
||||||
|
// Doesn't help with multiple repeats - the problem has to be solved later
|
||||||
|
if (sizeof($bodyparts) == 3) {
|
||||||
|
if (trim($bodyparts[0]) == "")
|
||||||
|
$body = trim($bodyparts[2]);
|
||||||
|
else if (trim($bodyparts[2]) == "")
|
||||||
|
$body = trim($bodyparts[0]);
|
||||||
|
else
|
||||||
|
$body = trim($bodyparts[0])."\n\n".trim($bodyparts[1])."[quote]".trim($bodyparts[2])."[/quote]";
|
||||||
|
//$body = trim(str_replace(array(":\t", "\t"), array(":[quote]", ""), $body))."[/quote]";
|
||||||
|
} else
|
||||||
|
$body = str_replace("\t", "", $body);
|
||||||
|
|
||||||
// At first convert the text to html
|
// At first convert the text to html
|
||||||
$html = bbcode($body, false, false);
|
$html = bbcode($body, false, false);
|
||||||
|
|
||||||
// Then convert it to plain text
|
// Then convert it to plain text
|
||||||
$msg = trim($b['title']." \n\n".html2plain($html, 0, true));
|
$msg = trim($b['title']." \n\n".html2plain($html, 0, true));
|
||||||
|
$msg = str_replace("\n«", "«", $msg); // Quickfix - the original problem lies in the html2plain conversion
|
||||||
$msg = html_entity_decode($msg,ENT_QUOTES,'UTF-8');
|
$msg = html_entity_decode($msg,ENT_QUOTES,'UTF-8');
|
||||||
|
|
||||||
// Removing multiple newlines
|
// Removing multiple newlines
|
||||||
|
@ -568,24 +638,30 @@ function fbpost_post_hook(&$a,&$b) {
|
||||||
|
|
||||||
logger('Facebook post: msg=' . $msg, LOGGER_DATA);
|
logger('Facebook post: msg=' . $msg, LOGGER_DATA);
|
||||||
|
|
||||||
|
$video = "";
|
||||||
|
|
||||||
if($likes) {
|
if($likes) {
|
||||||
$postvars = array('access_token' => $fb_token);
|
$postvars = array('access_token' => $fb_token);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
// message, picture, link, name, caption, description, source, place, tags
|
// message, picture, link, name, caption, description, source, place, tags
|
||||||
|
if(trim($link) != "")
|
||||||
|
if (@exif_imagetype($link) != 0) {
|
||||||
|
$image = $link;
|
||||||
|
$link = "";
|
||||||
|
}
|
||||||
|
|
||||||
$postvars = array(
|
$postvars = array(
|
||||||
'access_token' => $fb_token,
|
'access_token' => $fb_token,
|
||||||
'message' => $msg
|
'message' => $msg
|
||||||
);
|
);
|
||||||
if(trim($image) != "") {
|
if(trim($image) != "")
|
||||||
$postvars['picture'] = $image;
|
$postvars['picture'] = $image;
|
||||||
}
|
|
||||||
if(trim($link) != "") {
|
if(trim($link) != "") {
|
||||||
$postvars['link'] = $link;
|
$postvars['link'] = $link;
|
||||||
|
|
||||||
// The following doesn't work - why?
|
|
||||||
if ((stristr($link,'youtube')) || (stristr($link,'youtu.be')) || (stristr($link,'vimeo'))) {
|
if ((stristr($link,'youtube')) || (stristr($link,'youtu.be')) || (stristr($link,'vimeo'))) {
|
||||||
$postvars['source'] = $link;
|
$video = $link;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(trim($linkname) != "")
|
if(trim($linkname) != "")
|
||||||
|
@ -602,11 +678,41 @@ function fbpost_post_hook(&$a,&$b) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$post_to_page = get_pconfig($b['uid'],'facebook','post_to_page');
|
||||||
|
$page_access_token = get_pconfig($b['uid'],'facebook','page_access_token');
|
||||||
|
if ((intval($post_to_page) != 0) and ($page_access_token != ""))
|
||||||
|
$target = $post_to_page;
|
||||||
|
else
|
||||||
|
$target = "me";
|
||||||
|
|
||||||
if($reply) {
|
if($reply) {
|
||||||
$url = 'https://graph.facebook.com/' . $reply . '/' . (($likes) ? 'likes' : 'comments');
|
$url = 'https://graph.facebook.com/' . $reply . '/' . (($likes) ? 'likes' : 'comments');
|
||||||
} else if (($link != "") or ($image != "") or ($b['title'] == '') or (strlen($msg) < 500)) {
|
} else if (($video != "") or (($image == "") and ($link != ""))) {
|
||||||
$url = 'https://graph.facebook.com/me/feed';
|
// If it is a link to a video or a link without a preview picture then post it as a link
|
||||||
if($b['plink'])
|
if ($video != "")
|
||||||
|
$link = $video;
|
||||||
|
|
||||||
|
$postvars = array(
|
||||||
|
'access_token' => $fb_token,
|
||||||
|
'link' => $link,
|
||||||
|
);
|
||||||
|
if ($msg != $video)
|
||||||
|
$postvars['message'] = $msg;
|
||||||
|
|
||||||
|
$url = 'https://graph.facebook.com/'.$target.'/links';
|
||||||
|
} else if (($link == "") and ($image != "")) {
|
||||||
|
// If it is only an image without a page link then post this image as a photo
|
||||||
|
$postvars = array(
|
||||||
|
'access_token' => $fb_token,
|
||||||
|
'url' => $image,
|
||||||
|
);
|
||||||
|
if ($msg != $image)
|
||||||
|
$postvars['message'] = $msg;
|
||||||
|
|
||||||
|
$url = 'https://graph.facebook.com/'.$target.'/photos';
|
||||||
|
} else if (($link != "") or ($image != "") or ($b['title'] == '') or (strlen($msg) < 500)) {
|
||||||
|
$url = 'https://graph.facebook.com/'.$target.'/feed';
|
||||||
|
if (!get_pconfig($b['uid'],'facebook','suppress_view_on_friendica') and $b['plink'])
|
||||||
$postvars['actions'] = '{"name": "' . t('View on Friendica') . '", "link": "' . $b['plink'] . '"}';
|
$postvars['actions'] = '{"name": "' . t('View on Friendica') . '", "link": "' . $b['plink'] . '"}';
|
||||||
} else {
|
} else {
|
||||||
// if its only a message and a subject and the message is larger than 500 characters then post it as note
|
// if its only a message and a subject and the message is larger than 500 characters then post it as note
|
||||||
|
@ -615,9 +721,13 @@ function fbpost_post_hook(&$a,&$b) {
|
||||||
'message' => bbcode($b['body'], false, false),
|
'message' => bbcode($b['body'], false, false),
|
||||||
'subject' => $b['title'],
|
'subject' => $b['title'],
|
||||||
);
|
);
|
||||||
$url = 'https://graph.facebook.com/me/notes';
|
$url = 'https://graph.facebook.com/'.$target.'/notes';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Post to page?
|
||||||
|
if (!$reply and ($target != "me") and $page_access_token)
|
||||||
|
$postvars['access_token'] = $page_access_token;
|
||||||
|
|
||||||
logger('facebook: post to ' . $url);
|
logger('facebook: post to ' . $url);
|
||||||
logger('facebook: postvars: ' . print_r($postvars,true));
|
logger('facebook: postvars: ' . print_r($postvars,true));
|
||||||
|
|
||||||
|
@ -642,14 +752,14 @@ function fbpost_post_hook(&$a,&$b) {
|
||||||
add_to_queue($a->contact,NETWORK_FACEBOOK,$s);
|
add_to_queue($a->contact,NETWORK_FACEBOOK,$s);
|
||||||
notice( t('Facebook post failed. Queued for retry.') . EOL);
|
notice( t('Facebook post failed. Queued for retry.') . EOL);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($retj->error) && $retj->error->type == "OAuthException" && $retj->error->code == 190) {
|
if (isset($retj->error) && $retj->error->type == "OAuthException" && $retj->error->code == 190) {
|
||||||
logger('Facebook session has expired due to changed password.', LOGGER_DEBUG);
|
logger('Facebook session has expired due to changed password.', LOGGER_DEBUG);
|
||||||
|
|
||||||
$last_notification = get_pconfig($b['uid'], 'facebook', 'session_expired_mailsent');
|
$last_notification = get_pconfig($b['uid'], 'facebook', 'session_expired_mailsent');
|
||||||
if (!$last_notification || $last_notification < (time() - FACEBOOK_SESSION_ERR_NOTIFICATION_INTERVAL)) {
|
if (!$last_notification || $last_notification < (time() - FACEBOOK_SESSION_ERR_NOTIFICATION_INTERVAL)) {
|
||||||
require_once('include/enotify.php');
|
require_once('include/enotify.php');
|
||||||
|
|
||||||
$r = q("SELECT * FROM `user` WHERE `uid` = %d LIMIT 1", intval($b['uid']) );
|
$r = q("SELECT * FROM `user` WHERE `uid` = %d LIMIT 1", intval($b['uid']) );
|
||||||
notification(array(
|
notification(array(
|
||||||
'uid' => $b['uid'],
|
'uid' => $b['uid'],
|
||||||
|
@ -662,7 +772,7 @@ function fbpost_post_hook(&$a,&$b) {
|
||||||
'source_link' => $a->config["system"]["url"],
|
'source_link' => $a->config["system"]["url"],
|
||||||
'source_photo' => $a->config["system"]["url"] . '/images/person-80.jpg',
|
'source_photo' => $a->config["system"]["url"] . '/images/person-80.jpg',
|
||||||
));
|
));
|
||||||
|
|
||||||
set_pconfig($b['uid'], 'facebook', 'session_expired_mailsent', time());
|
set_pconfig($b['uid'], 'facebook', 'session_expired_mailsent', time());
|
||||||
} else logger('Facebook: No notification, as the last one was sent on ' . $last_notification, LOGGER_DEBUG);
|
} else logger('Facebook: No notification, as the last one was sent on ' . $last_notification, LOGGER_DEBUG);
|
||||||
}
|
}
|
||||||
|
|
BIN
forumlist.tgz
BIN
forumlist.tgz
Binary file not shown.
|
@ -26,16 +26,20 @@ function forumlist_uninstall() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function forumlist_getpage($uid,$showhidden = true,$randomise = false) {
|
function forumlist_getpage($uid,$showhidden = true,$randomise = false, $showprivate = false) {
|
||||||
|
|
||||||
|
|
||||||
$forumlist = array();
|
$forumlist = array();
|
||||||
|
|
||||||
$order = (($showhidden) ? '' : " and hidden = 0 ");
|
$order = (($showhidden) ? '' : " and hidden = 0 ");
|
||||||
$order .= (($randomise) ? ' order by rand() ' : ' order by name asc ');
|
$order .= (($randomise) ? ' order by rand() ' : ' order by name asc ');
|
||||||
|
$select = "`forum` = 1";
|
||||||
|
if ($showprivate) {
|
||||||
|
$select = "( `forum` = 1 OR `prv` = 1 )";
|
||||||
|
}
|
||||||
|
|
||||||
$contacts = q("SELECT `contact`.`id`, `contact`.`url`, `contact`.`name`, `contact`.`micro` from contact
|
$contacts = q("SELECT `contact`.`id`, `contact`.`url`, `contact`.`name`, `contact`.`micro` from contact
|
||||||
WHERE `network`= 'dfrn' AND `forum` = 1 AND `uid` = %d
|
WHERE `network`= 'dfrn' AND $select AND `uid` = %d
|
||||||
and blocked = 0 and hidden = 0 and pending = 0 and archive = 0
|
and blocked = 0 and hidden = 0 and pending = 0 and archive = 0
|
||||||
$order ",
|
$order ",
|
||||||
intval($uid)
|
intval($uid)
|
||||||
|
@ -66,7 +70,7 @@ function forumlist_network_mod_init($a,$b) {
|
||||||
|
|
||||||
$randomise = intval(get_pconfig(local_user(),'forumlist','randomise'));
|
$randomise = intval(get_pconfig(local_user(),'forumlist','randomise'));
|
||||||
|
|
||||||
$contacts = forumlist_getpage($a->user['uid'],true,$randomise);
|
$contacts = forumlist_getpage($a->user['uid'],true,$randomise, true);
|
||||||
|
|
||||||
if(count($contacts)) {
|
if(count($contacts)) {
|
||||||
foreach($contacts as $contact) {
|
foreach($contacts as $contact) {
|
||||||
|
@ -99,7 +103,7 @@ function forumlist_profile_advanced($a,&$b) {
|
||||||
|
|
||||||
$randomise = true;
|
$randomise = true;
|
||||||
|
|
||||||
$contacts = forumlist_getpage($a->user['uid'],false,$randomise);
|
$contacts = forumlist_getpage($a->user['uid'],false,$randomise,false);
|
||||||
|
|
||||||
$total_shown = 0;
|
$total_shown = 0;
|
||||||
$more = false;
|
$more = false;
|
||||||
|
@ -122,7 +126,6 @@ function forumlist_profile_advanced($a,&$b) {
|
||||||
function forumlist_plugin_settings_post($a,$post) {
|
function forumlist_plugin_settings_post($a,$post) {
|
||||||
if(! local_user() || (! x($_POST,'forumlist-settings-submit')))
|
if(! local_user() || (! x($_POST,'forumlist-settings-submit')))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// set_pconfig(local_user(),'forumlist','max_forumlists',intval($_POST['forumlist_max_forumlists']));
|
// set_pconfig(local_user(),'forumlist','max_forumlists',intval($_POST['forumlist_max_forumlists']));
|
||||||
set_pconfig(local_user(),'forumlist','randomise',intval($_POST['forumlist_random']));
|
set_pconfig(local_user(),'forumlist','randomise',intval($_POST['forumlist_random']));
|
||||||
set_pconfig(local_user(),'forumlist','show_on_profile',intval($_POST['forumlist_profile']));
|
set_pconfig(local_user(),'forumlist','show_on_profile',intval($_POST['forumlist_profile']));
|
||||||
|
|
BIN
js_upload.tgz
BIN
js_upload.tgz
Binary file not shown.
|
@ -196,7 +196,13 @@ class qqUploadedFileXhr {
|
||||||
*/
|
*/
|
||||||
function save() {
|
function save() {
|
||||||
$input = fopen("php://input", "r");
|
$input = fopen("php://input", "r");
|
||||||
$this->pathnm = tempnam(sys_get_temp_dir(),'frn');
|
|
||||||
|
$upload_dir = get_config('system','tempdir');
|
||||||
|
if(! $upload_dir)
|
||||||
|
$upload_dir = sys_get_temp_dir();
|
||||||
|
|
||||||
|
$this->pathnm = tempnam($upload_dir,'frn');
|
||||||
|
|
||||||
$temp = fopen($this->pathnm,"w");
|
$temp = fopen($this->pathnm,"w");
|
||||||
$realSize = stream_copy_to_stream($input, $temp);
|
$realSize = stream_copy_to_stream($input, $temp);
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
|
|
||||||
#ljpost-enable-label, #ljpost-username-label, #ljpost-password-label, #ljpost-bydefault-label {
|
#ljpost-enable-label, #ljpost-username-label, #ljpost-password-label, #ljpost-bydefault-label {
|
||||||
<<<<<<< HEAD
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 200px;
|
width: 200px;
|
||||||
margin-top: 10px;
|
margin-top: 10px;
|
||||||
|
@ -15,18 +14,3 @@
|
||||||
margin-top: 15px;
|
margin-top: 15px;
|
||||||
}
|
}
|
||||||
|
|
||||||
=======
|
|
||||||
float: left;
|
|
||||||
width: 200px;
|
|
||||||
margin-top: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ljpost-checkbox, #ljpost-username, #ljpost-password, #ljpost-bydefault {
|
|
||||||
float: left;
|
|
||||||
margin-top: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ljpost-submit {
|
|
||||||
margin-top: 15px;
|
|
||||||
}
|
|
||||||
>>>>>>> 99d9fddb6af9e872266666038447771e42ce13b4
|
|
||||||
|
|
Binary file not shown.
BIN
page.tgz
BIN
page.tgz
Binary file not shown.
Binary file not shown.
BIN
smiley_pack.tgz
BIN
smiley_pack.tgz
Binary file not shown.
BIN
statusnet.tgz
BIN
statusnet.tgz
Binary file not shown.
|
@ -495,7 +495,7 @@ function statusnet_shortenmsg($b, $max_char) {
|
||||||
$msg = substr($msg, 0, -1);
|
$msg = substr($msg, 0, -1);
|
||||||
$pos = strrpos($msg, "\n");
|
$pos = strrpos($msg, "\n");
|
||||||
if ($pos > 0)
|
if ($pos > 0)
|
||||||
$msg = substr($msg, 0, $pos-1);
|
$msg = substr($msg, 0, $pos);
|
||||||
else if ($lastchar != "\n")
|
else if ($lastchar != "\n")
|
||||||
$msg = substr($msg, 0, -3)."...";
|
$msg = substr($msg, 0, -3)."...";
|
||||||
}
|
}
|
||||||
|
@ -505,7 +505,7 @@ function statusnet_shortenmsg($b, $max_char) {
|
||||||
while (strpos($msg, " ") !== false)
|
while (strpos($msg, " ") !== false)
|
||||||
$msg = str_replace(" ", " ", $msg);
|
$msg = str_replace(" ", " ", $msg);
|
||||||
|
|
||||||
return(trim($msg." ".$msglink));
|
return(array("msg"=>trim($msg." ".$msglink), "image"=>$image));
|
||||||
}
|
}
|
||||||
|
|
||||||
function statusnet_post_hook(&$a,&$b) {
|
function statusnet_post_hook(&$a,&$b) {
|
||||||
|
@ -538,6 +538,7 @@ function statusnet_post_hook(&$a,&$b) {
|
||||||
// information during shortening of potential links but do not
|
// information during shortening of potential links but do not
|
||||||
// shorten all the links in a 200000 character long essay.
|
// shorten all the links in a 200000 character long essay.
|
||||||
|
|
||||||
|
$tempfile = "";
|
||||||
$intelligent_shortening = get_config('statusnet','intelligent_shortening');
|
$intelligent_shortening = get_config('statusnet','intelligent_shortening');
|
||||||
if (!$intelligent_shortening) {
|
if (!$intelligent_shortening) {
|
||||||
if (! $b['title']=='') {
|
if (! $b['title']=='') {
|
||||||
|
@ -612,18 +613,32 @@ function statusnet_post_hook(&$a,&$b) {
|
||||||
}
|
}
|
||||||
|
|
||||||
$msg = trim($msg);
|
$msg = trim($msg);
|
||||||
} else
|
$postdata = array('status' => $msg);
|
||||||
$msg = statusnet_shortenmsg($b, $max_char);
|
} else {
|
||||||
|
$msgarr = statusnet_shortenmsg($b, $max_char);
|
||||||
|
$msg = $msgarr["msg"];
|
||||||
|
$image = $msgarr["image"];
|
||||||
|
if ($image != "") {
|
||||||
|
$imagedata = file_get_contents($image);
|
||||||
|
$tempfile = tempnam("", "upload");
|
||||||
|
file_put_contents($tempfile, $imagedata);
|
||||||
|
$postdata = array("status"=>$msg, "media"=>"@".$tempfile);
|
||||||
|
} else
|
||||||
|
$postdata = array("status"=>$msg);
|
||||||
|
}
|
||||||
|
|
||||||
// and now dent it :-)
|
// and now dent it :-)
|
||||||
if(strlen($msg)) {
|
if(strlen($msg)) {
|
||||||
$result = $dent->post('statuses/update', array('status' => $msg));
|
//$result = $dent->post('statuses/update', array('status' => $msg));
|
||||||
|
$result = $dent->post('statuses/update', $postdata);
|
||||||
logger('statusnet_post send, result: ' . print_r($result, true).
|
logger('statusnet_post send, result: ' . print_r($result, true).
|
||||||
"\nmessage: ".$msg, LOGGER_DEBUG."\nOriginal post: ".print_r($b));
|
"\nmessage: ".$msg, LOGGER_DEBUG."\nOriginal post: ".print_r($b)."\nPost Data: ".print_r($postdata));
|
||||||
if ($result->error) {
|
if ($result->error) {
|
||||||
logger('Send to StatusNet failed: "' . $result->error . '"');
|
logger('Send to StatusNet failed: "' . $result->error . '"');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if ($tempfile != "")
|
||||||
|
unlink($tempfile);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
BIN
twitter.tgz
BIN
twitter.tgz
Binary file not shown.
|
@ -354,7 +354,7 @@ function twitter_shortenmsg($b) {
|
||||||
$msg = substr($msg, 0, -1);
|
$msg = substr($msg, 0, -1);
|
||||||
$pos = strrpos($msg, "\n");
|
$pos = strrpos($msg, "\n");
|
||||||
if ($pos > 0)
|
if ($pos > 0)
|
||||||
$msg = substr($msg, 0, $pos-1);
|
$msg = substr($msg, 0, $pos);
|
||||||
else if ($lastchar != "\n")
|
else if ($lastchar != "\n")
|
||||||
$msg = substr($msg, 0, -3)."...";
|
$msg = substr($msg, 0, -3)."...";
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue