Merge commit 'upstream/master'
BIN
adult_smile.tgz
After Width: | Height: | Size: 648 B |
After Width: | Height: | Size: 2.8 KiB |
BIN
blockem.tgz
|
@ -109,7 +109,7 @@ function blockem_prepare_body(&$a,&$b) {
|
||||||
|
|
||||||
function blockem_display_item(&$a,&$b) {
|
function blockem_display_item(&$a,&$b) {
|
||||||
if(strstr($b['output']['body'],'id="blockem-wrap-'))
|
if(strstr($b['output']['body'],'id="blockem-wrap-'))
|
||||||
$b['output']['thumb'] = $a->get_baseurl() . "/images/default-profile-sm.jpg";
|
$b['output']['thumb'] = $a->get_baseurl() . "/images/person-80.jpg";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
BIN
dwpost.tgz
|
@ -1,15 +1,15 @@
|
||||||
|
|
||||||
#ljpost-enable-label, #ljpost-username-label, #ljpost-password-label, #ljpost-bydefault-label {
|
#dwpost-enable-label, #dwpost-username-label, #dwpost-password-label, #dwpost-bydefault-label {
|
||||||
float: left;
|
float: left;
|
||||||
width: 200px;
|
width: 200px;
|
||||||
margin-top: 10px;
|
margin-top: 10px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ljpost-checkbox, #ljpost-username, #ljpost-password, #ljpost-bydefault {
|
#dwpost-checkbox, #dwpost-username, #dwpost-password, #dwpost-bydefault {
|
||||||
float: left;
|
float: left;
|
||||||
margin-top: 10px;
|
margin-top: 10px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ljpost-submit {
|
#dwpost-submit {
|
||||||
margin-top: 15px;
|
margin-top: 15px;
|
||||||
}
|
}
|
|
@ -4,7 +4,7 @@
|
||||||
* Name: Dreamwidth Post Connector
|
* Name: Dreamwidth Post Connector
|
||||||
* Description: Post to dreamwidth
|
* Description: Post to dreamwidth
|
||||||
* Version: 1.0
|
* Version: 1.0
|
||||||
* Author: Tony Baldwin <http://tonybaldwin.me/friendica/profile/tony>
|
* Author: Tony Baldwin <https://free-haven.org/profile/tony>
|
||||||
* Author: Michael Johnston
|
* Author: Michael Johnston
|
||||||
* Author: Cat Gray <https://free-haven.org/profile/catness>
|
* Author: Cat Gray <https://free-haven.org/profile/catness>
|
||||||
*/
|
*/
|
||||||
|
@ -213,7 +213,7 @@ EOT;
|
||||||
logger('dwpost: data: ' . $xml, LOGGER_DATA);
|
logger('dwpost: data: ' . $xml, LOGGER_DATA);
|
||||||
|
|
||||||
if($dw_blog !== 'test')
|
if($dw_blog !== 'test')
|
||||||
$x = post_url($dw_blog,$xml);
|
$x = post_url($dw_blog,$xml,array("Content-Type: text/xml"));
|
||||||
logger('posted to dreamwidth: ' . ($x) ? $x : '', LOGGER_DEBUG);
|
logger('posted to dreamwidth: ' . ($x) ? $x : '', LOGGER_DEBUG);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
BIN
facebook.tgz
|
@ -47,6 +47,12 @@
|
||||||
* in a future release.
|
* in a future release.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/** TODO
|
||||||
|
* - Implement a method for the administrator to delete all configuration data the plugin has created,
|
||||||
|
* e.g. the app_access_token
|
||||||
|
* - Implement a configuration option to set the polling interval system-wide
|
||||||
|
*/
|
||||||
|
|
||||||
define('FACEBOOK_MAXPOSTLEN', 420);
|
define('FACEBOOK_MAXPOSTLEN', 420);
|
||||||
|
|
||||||
|
|
||||||
|
@ -56,9 +62,8 @@ function facebook_install() {
|
||||||
register_hook('jot_networks', 'addon/facebook/facebook.php', 'facebook_jot_nets');
|
register_hook('jot_networks', 'addon/facebook/facebook.php', 'facebook_jot_nets');
|
||||||
register_hook('connector_settings', 'addon/facebook/facebook.php', 'facebook_plugin_settings');
|
register_hook('connector_settings', 'addon/facebook/facebook.php', 'facebook_plugin_settings');
|
||||||
register_hook('cron', 'addon/facebook/facebook.php', 'facebook_cron');
|
register_hook('cron', 'addon/facebook/facebook.php', 'facebook_cron');
|
||||||
|
register_hook('enotify', 'addon/facebook/facebook.php', 'facebook_enotify');
|
||||||
register_hook('queue_predeliver', 'addon/facebook/facebook.php', 'fb_queue_hook');
|
register_hook('queue_predeliver', 'addon/facebook/facebook.php', 'fb_queue_hook');
|
||||||
|
|
||||||
if (get_config('facebook', 'realtime_active') == 1) facebook_subscription_add_users(); // Restore settings, if the plugin was installed before
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -68,13 +73,12 @@ function facebook_uninstall() {
|
||||||
unregister_hook('jot_networks', 'addon/facebook/facebook.php', 'facebook_jot_nets');
|
unregister_hook('jot_networks', 'addon/facebook/facebook.php', 'facebook_jot_nets');
|
||||||
unregister_hook('connector_settings', 'addon/facebook/facebook.php', 'facebook_plugin_settings');
|
unregister_hook('connector_settings', 'addon/facebook/facebook.php', 'facebook_plugin_settings');
|
||||||
unregister_hook('cron', 'addon/facebook/facebook.php', 'facebook_cron');
|
unregister_hook('cron', 'addon/facebook/facebook.php', 'facebook_cron');
|
||||||
|
unregister_hook('enotify', 'addon/facebook/facebook.php', 'facebook_enotify');
|
||||||
unregister_hook('queue_predeliver', 'addon/facebook/facebook.php', 'fb_queue_hook');
|
unregister_hook('queue_predeliver', 'addon/facebook/facebook.php', 'fb_queue_hook');
|
||||||
|
|
||||||
// hook moved
|
// hook moved
|
||||||
unregister_hook('post_local_end', 'addon/facebook/facebook.php', 'facebook_post_hook');
|
unregister_hook('post_local_end', 'addon/facebook/facebook.php', 'facebook_post_hook');
|
||||||
unregister_hook('plugin_settings', 'addon/facebook/facebook.php', 'facebook_plugin_settings');
|
unregister_hook('plugin_settings', 'addon/facebook/facebook.php', 'facebook_plugin_settings');
|
||||||
|
|
||||||
if (get_config('facebook', 'realtime_active') == 1) facebook_subscription_del_users();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -150,8 +154,12 @@ function facebook_init(&$a) {
|
||||||
$s = fetch_url('https://graph.facebook.com/me/feed?access_token=' . $access_token);
|
$s = fetch_url('https://graph.facebook.com/me/feed?access_token=' . $access_token);
|
||||||
if($s) {
|
if($s) {
|
||||||
$j = json_decode($s);
|
$j = json_decode($s);
|
||||||
|
if (isset($j->data)) {
|
||||||
logger('facebook_init: wall: ' . print_r($j,true), LOGGER_DATA);
|
logger('facebook_init: wall: ' . print_r($j,true), LOGGER_DATA);
|
||||||
fb_consume_stream($uid,$j,($private_wall) ? false : true);
|
fb_consume_stream($uid,$j,($private_wall) ? false : true);
|
||||||
|
} else {
|
||||||
|
logger('facebook_init: wall: got no data from Facebook: ' . print_r($j,true), LOGGER_NORMAL);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -589,7 +597,7 @@ function facebook_cron($a,$b) {
|
||||||
|
|
||||||
if(strlen($a->config['admin_email']) && !get_config('facebook', 'realtime_err_mailsent')) {
|
if(strlen($a->config['admin_email']) && !get_config('facebook', 'realtime_err_mailsent')) {
|
||||||
$res = mail($a->config['admin_email'], t('Problems with Facebook Real-Time Updates'),
|
$res = mail($a->config['admin_email'], t('Problems with Facebook Real-Time Updates'),
|
||||||
"Hi!\n\nThere's a problem with the Facebook Real-Time Updates that cannob be solved automatically. Maybe an permission issue?\n\nThis e-mail will only be sent once.",
|
"Hi!\n\nThere's a problem with the Facebook Real-Time Updates that cannot be solved automatically. Maybe an permission issue?\n\nThis e-mail will only be sent once.",
|
||||||
'From: ' . t('Administrator') . '@' . $_SERVER['SERVER_NAME'] . "\n"
|
'From: ' . t('Administrator') . '@' . $_SERVER['SERVER_NAME'] . "\n"
|
||||||
. 'Content-type: text/plain; charset=UTF-8' . "\n"
|
. 'Content-type: text/plain; charset=UTF-8' . "\n"
|
||||||
. 'Content-transfer-encoding: 8bit'
|
. 'Content-transfer-encoding: 8bit'
|
||||||
|
@ -930,6 +938,7 @@ function facebook_post_hook(&$a,&$b) {
|
||||||
dbesc('fb::' . $retj->id),
|
dbesc('fb::' . $retj->id),
|
||||||
intval($b['id'])
|
intval($b['id'])
|
||||||
);
|
);
|
||||||
|
del_pconfig($b['uid'], 'facebook', 'session_expired_mailsent');
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if(! $likes) {
|
if(! $likes) {
|
||||||
|
@ -938,6 +947,25 @@ function facebook_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) {
|
||||||
|
logger('Facebook session has expired due to changed password.', LOGGER_DEBUG);
|
||||||
|
if (!get_pconfig($b['uid'], 'facebook', 'session_expired_mailsent')) {
|
||||||
|
require_once('include/enotify.php');
|
||||||
|
|
||||||
|
$r = q("SELECT * FROM `user` WHERE `uid` = %d LIMIT 1", intval($b['uid']) );
|
||||||
|
notification(array(
|
||||||
|
'uid' => $b['uid'],
|
||||||
|
'type' => NOTIFY_SYSTEM,
|
||||||
|
'system_type' => 'facebook_connection_invalid',
|
||||||
|
'language' => $r[0]['language'],
|
||||||
|
'to_name' => $r[0]['username'],
|
||||||
|
'to_email' => $r[0]['email'],
|
||||||
|
));
|
||||||
|
|
||||||
|
set_pconfig($b['uid'], 'facebook', 'session_expired_mailsent', '1');
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
logger('Facebook post returns: ' . $x, LOGGER_DEBUG);
|
logger('Facebook post returns: ' . $x, LOGGER_DEBUG);
|
||||||
|
@ -947,6 +975,13 @@ function facebook_post_hook(&$a,&$b) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function facebook_enotify(&$app, &$data) {
|
||||||
|
if (x($data, 'params') && $data['params']['type'] == NOTIFY_SYSTEM && x($data['params'], 'system_type') && $data['params']['system_type'] == 'facebook_connection_invalid') {
|
||||||
|
$data['itemlink'] = '/facebook';
|
||||||
|
$data['epreamble'] = $data['preamble'] = t('Your Facebook connection became invalid. Please Re-authenticate.');
|
||||||
|
$data['subject'] = t('Facebook connection became invalid');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function facebook_post_local(&$a,&$b) {
|
function facebook_post_local(&$a,&$b) {
|
||||||
|
|
||||||
|
@ -1045,15 +1080,23 @@ function fb_consume_all($uid) {
|
||||||
$s = fetch_url('https://graph.facebook.com/me/feed?access_token=' . $access_token);
|
$s = fetch_url('https://graph.facebook.com/me/feed?access_token=' . $access_token);
|
||||||
if($s) {
|
if($s) {
|
||||||
$j = json_decode($s);
|
$j = json_decode($s);
|
||||||
|
if (isset($j->data)) {
|
||||||
logger('fb_consume_stream: wall: ' . print_r($j,true), LOGGER_DATA);
|
logger('fb_consume_stream: wall: ' . print_r($j,true), LOGGER_DATA);
|
||||||
fb_consume_stream($uid,$j,($private_wall) ? false : true);
|
fb_consume_stream($uid,$j,($private_wall) ? false : true);
|
||||||
|
} else {
|
||||||
|
logger('fb_consume_stream: wall: got no data from Facebook: ' . print_r($j,true), LOGGER_NORMAL);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$s = fetch_url('https://graph.facebook.com/me/home?access_token=' . $access_token);
|
$s = fetch_url('https://graph.facebook.com/me/home?access_token=' . $access_token);
|
||||||
if($s) {
|
if($s) {
|
||||||
$j = json_decode($s);
|
$j = json_decode($s);
|
||||||
|
if (isset($j->data)) {
|
||||||
logger('fb_consume_stream: feed: ' . print_r($j,true), LOGGER_DATA);
|
logger('fb_consume_stream: feed: ' . print_r($j,true), LOGGER_DATA);
|
||||||
fb_consume_stream($uid,$j,false);
|
fb_consume_stream($uid,$j,false);
|
||||||
|
} else {
|
||||||
|
logger('fb_consume_stream: feed: got no data from Facebook: ' . print_r($j,true), LOGGER_NORMAL);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1078,7 +1121,7 @@ function fb_consume_stream($uid,$j,$wall = false) {
|
||||||
$a = get_app();
|
$a = get_app();
|
||||||
|
|
||||||
|
|
||||||
$user = q("SELECT `nickname`, `blockwall` FROM `user` WHERE `uid` = %d AND `account_expired` = 0 LIMIT 1",
|
$user = q("SELECT * FROM `user` WHERE `uid` = %d AND `account_expired` = 0 LIMIT 1",
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
if(! count($user))
|
if(! count($user))
|
||||||
|
@ -1201,7 +1244,7 @@ function fb_consume_stream($uid,$j,$wall = false) {
|
||||||
|
|
||||||
if($entry->privacy && $entry->privacy->value !== 'EVERYONE') {
|
if($entry->privacy && $entry->privacy->value !== 'EVERYONE') {
|
||||||
$datarray['private'] = 1;
|
$datarray['private'] = 1;
|
||||||
$datarray['allow_cid'] = '<' . $uid . '>';
|
$datarray['allow_cid'] = '<' . $self[0]['id'] . '>';
|
||||||
}
|
}
|
||||||
|
|
||||||
if(trim($datarray['body']) == '') {
|
if(trim($datarray['body']) == '') {
|
||||||
|
@ -1340,6 +1383,47 @@ function fb_consume_stream($uid,$j,$wall = false) {
|
||||||
$cmntdata['author-avatar'] = 'https://graph.facebook.com/' . $cmnt->from->id . '/picture';
|
$cmntdata['author-avatar'] = 'https://graph.facebook.com/' . $cmnt->from->id . '/picture';
|
||||||
$cmntdata['body'] = $cmnt->message;
|
$cmntdata['body'] = $cmnt->message;
|
||||||
$item = item_store($cmntdata);
|
$item = item_store($cmntdata);
|
||||||
|
|
||||||
|
$myconv = q("SELECT `author-link`, `author-avatar`, `parent` FROM `item` WHERE `parent-uri` = '%s' AND `uid` = %d AND `parent` != 0 ",
|
||||||
|
dbesc($orig_post['uri']),
|
||||||
|
intval($uid)
|
||||||
|
);
|
||||||
|
|
||||||
|
if(count($myconv)) {
|
||||||
|
$importer_url = $a->get_baseurl() . '/profile/' . $user[0]['nickname'];
|
||||||
|
|
||||||
|
foreach($myconv as $conv) {
|
||||||
|
|
||||||
|
// now if we find a match, it means we're in this conversation
|
||||||
|
|
||||||
|
if(! link_compare($conv['author-link'],$importer_url))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
require_once('include/enotify.php');
|
||||||
|
|
||||||
|
$conv_parent = $conv['parent'];
|
||||||
|
|
||||||
|
notification(array(
|
||||||
|
'type' => NOTIFY_COMMENT,
|
||||||
|
'notify_flags' => $user[0]['notify-flags'],
|
||||||
|
'language' => $user[0]['language'],
|
||||||
|
'to_name' => $user[0]['username'],
|
||||||
|
'to_email' => $user[0]['email'],
|
||||||
|
'uid' => $user[0]['uid'],
|
||||||
|
'item' => $cmntdata,
|
||||||
|
'link' => $a->get_baseurl() . '/display/' . $importer['nickname'] . '/' . $item,
|
||||||
|
'source_name' => $cmntdata['author-name'],
|
||||||
|
'source_link' => $cmntdata['author-link'],
|
||||||
|
'source_photo' => $cmntdata['author-avatar'],
|
||||||
|
'verb' => ACTIVITY_POST,
|
||||||
|
'otype' => 'item',
|
||||||
|
'parent' => $conv_parent,
|
||||||
|
));
|
||||||
|
|
||||||
|
// only send one notification
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,14 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#frown-enable-label {
|
||||||
|
float: left;
|
||||||
|
width: 200px;
|
||||||
|
margin-bottom: 25px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#frown-checkbox {
|
||||||
|
float: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,86 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Name: Frown
|
||||||
|
* Description: Disable graphical smilies
|
||||||
|
* Version: 1.0
|
||||||
|
* Author: Mike Macgirvin <http://macgirvin.com/profile/mike>
|
||||||
|
*
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
function frown_install() {
|
||||||
|
|
||||||
|
register_hook('plugin_settings', 'addon/frown/frown.php', 'frown_settings');
|
||||||
|
register_hook('plugin_settings_post', 'addon/frown/frown.php', 'frown_settings_post');
|
||||||
|
|
||||||
|
logger("installed frown");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function frown_uninstall() {
|
||||||
|
|
||||||
|
unregister_hook('plugin_settings', 'addon/frown/frown.php', 'frown_settings');
|
||||||
|
unregister_hook('plugin_settings_post', 'addon/frown/frown.php', 'frown_settings_post');
|
||||||
|
|
||||||
|
|
||||||
|
logger("removed frown");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* Callback from the settings post function.
|
||||||
|
* $post contains the $_POST array.
|
||||||
|
* We will make sure we've got a valid user account
|
||||||
|
* and if so set our configuration setting for this person.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
function frown_settings_post($a,$post) {
|
||||||
|
if(! local_user() || (! x($_POST,'frown-submit')))
|
||||||
|
return;
|
||||||
|
set_pconfig(local_user(),'system','no_smilies',intval($_POST['frown']));
|
||||||
|
|
||||||
|
info( t('Frown settings updated.') . EOL);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* Called from the Plugin Setting form.
|
||||||
|
* Add our own settings info to the page.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
function frown_settings(&$a,&$s) {
|
||||||
|
|
||||||
|
if(! local_user())
|
||||||
|
return;
|
||||||
|
|
||||||
|
/* 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/frown/frown.css' . '" media="all" />' . "\r\n";
|
||||||
|
|
||||||
|
/* Get the current state of our config variable */
|
||||||
|
|
||||||
|
$enabled = get_pconfig(local_user(),'system','no_smilies');
|
||||||
|
$checked = (($enabled) ? ' checked="checked" ' : '');
|
||||||
|
|
||||||
|
/* Add some HTML to the existing form */
|
||||||
|
|
||||||
|
$s .= '<div class="settings-block">';
|
||||||
|
$s .= '<h3>' . t('Frown Settings') . '</h3>';
|
||||||
|
$s .= '<div id="frown-enable-wrapper">';
|
||||||
|
$s .= '<label id="frown-enable-label" for="frown-checkbox">' . t('Disable graphical smilies') . '</label>';
|
||||||
|
$s .= '<input id="frown-checkbox" type="checkbox" name="frown" value="1" ' . $checked . '/>';
|
||||||
|
$s .= '</div><div class="clear"></div>';
|
||||||
|
|
||||||
|
/* provide a submit button */
|
||||||
|
|
||||||
|
$s .= '<div class="settings-submit-wrapper" ><input type="submit" name="frown-submit" class="settings-submit" value="' . t('Submit') . '" /></div></div>';
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,15 @@
|
||||||
|
|
||||||
|
#ijpost-enable-label, #ijpost-username-label, #ijpost-password-label, #ijpost-bydefault-label {
|
||||||
|
float: left;
|
||||||
|
width: 200px;
|
||||||
|
margin-top: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ijpost-checkbox, #ijpost-username, #ijpost-password, #ijpost-bydefault {
|
||||||
|
float: left;
|
||||||
|
margin-top: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ijpost-submit {
|
||||||
|
margin-top: 15px;
|
||||||
|
}
|
|
@ -0,0 +1,227 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Name: Insanejournal Post Connector
|
||||||
|
* Description: Post to Insanejournal
|
||||||
|
* Version: 1.0
|
||||||
|
* Author: Tony Baldwin <https://free-haven.org/profile/tony>
|
||||||
|
* Author: Michael Johnston
|
||||||
|
* Author: Cat Gray <https://free-haven.org/profile/catness>
|
||||||
|
*/
|
||||||
|
|
||||||
|
function ijpost_install() {
|
||||||
|
register_hook('post_local', 'addon/ijpost/ijpost.php', 'ijpost_post_local');
|
||||||
|
register_hook('notifier_normal', 'addon/ijpost/ijpost.php', 'ijpost_send');
|
||||||
|
register_hook('jot_networks', 'addon/ijpost/ijpost.php', 'ijpost_jot_nets');
|
||||||
|
register_hook('connector_settings', 'addon/ijpost/ijpost.php', 'ijpost_settings');
|
||||||
|
register_hook('connector_settings_post', 'addon/ijpost/ijpost.php', 'ijpost_settings_post');
|
||||||
|
|
||||||
|
}
|
||||||
|
function ijpost_uninstall() {
|
||||||
|
unregister_hook('post_local', 'addon/ijpost/ijpost.php', 'ijpost_post_local');
|
||||||
|
unregister_hook('notifier_normal', 'addon/ijpost/ijpost.php', 'ijpost_send');
|
||||||
|
unregister_hook('jot_networks', 'addon/ijpost/ijpost.php', 'ijpost_jot_nets');
|
||||||
|
unregister_hook('connector_settings', 'addon/ijpost/ijpost.php', 'ijpost_settings');
|
||||||
|
unregister_hook('connector_settings_post', 'addon/ijpost/ijpost.php', 'ijpost_settings_post');
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function ijpost_jot_nets(&$a,&$b) {
|
||||||
|
if(! local_user())
|
||||||
|
return;
|
||||||
|
|
||||||
|
$ij_post = get_pconfig(local_user(),'ijpost','post');
|
||||||
|
if(intval($ij_post) == 1) {
|
||||||
|
$ij_defpost = get_pconfig(local_user(),'ijpost','post_by_default');
|
||||||
|
$selected = ((intval($ij_defpost) == 1) ? ' checked="checked" ' : '');
|
||||||
|
$b .= '<div class="profile-jot-net"><input type="checkbox" name="ijpost_enable" ' . $selected . ' value="1" /> '
|
||||||
|
. t('Post to Insanejournal') . '</div>';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function ijpost_settings(&$a,&$s) {
|
||||||
|
|
||||||
|
if(! local_user())
|
||||||
|
return;
|
||||||
|
|
||||||
|
/* 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/ijpost/ijpost.css' . '" media="all" />' . "\r\n";
|
||||||
|
|
||||||
|
/* Get the current state of our config variables */
|
||||||
|
|
||||||
|
$enabled = get_pconfig(local_user(),'ijpost','post');
|
||||||
|
|
||||||
|
$checked = (($enabled) ? ' checked="checked" ' : '');
|
||||||
|
|
||||||
|
$def_enabled = get_pconfig(local_user(),'ijpost','post_by_default');
|
||||||
|
|
||||||
|
$def_checked = (($def_enabled) ? ' checked="checked" ' : '');
|
||||||
|
|
||||||
|
$ij_username = get_pconfig(local_user(), 'ijpost', 'ij_username');
|
||||||
|
$ij_password = get_pconfig(local_user(), 'ijpost', 'ij_password');
|
||||||
|
|
||||||
|
|
||||||
|
/* Add some HTML to the existing form */
|
||||||
|
|
||||||
|
$s .= '<div class="settings-block">';
|
||||||
|
$s .= '<h3>' . t('InsaneJournal Post Settings') . '</h3>';
|
||||||
|
$s .= '<div id="ijpost-enable-wrapper">';
|
||||||
|
$s .= '<label id="ijpost-enable-label" for="ijpost-checkbox">' . t('Enable InsaneJournal Post Plugin') . '</label>';
|
||||||
|
$s .= '<input id="ijpost-checkbox" type="checkbox" name="ijpost" value="1" ' . $checked . '/>';
|
||||||
|
$s .= '</div><div class="clear"></div>';
|
||||||
|
|
||||||
|
$s .= '<div id="ijpost-username-wrapper">';
|
||||||
|
$s .= '<label id="ijpost-username-label" for="ijpost-username">' . t('InsaneJournal username') . '</label>';
|
||||||
|
$s .= '<input id="ijpost-username" type="text" name="ij_username" value="' . $ij_username . '" />';
|
||||||
|
$s .= '</div><div class="clear"></div>';
|
||||||
|
|
||||||
|
$s .= '<div id="ijpost-password-wrapper">';
|
||||||
|
$s .= '<label id="ijpost-password-label" for="ijpost-password">' . t('InsaneJournal password') . '</label>';
|
||||||
|
$s .= '<input id="ijpost-password" type="password" name="ij_password" value="' . $ij_password . '" />';
|
||||||
|
$s .= '</div><div class="clear"></div>';
|
||||||
|
|
||||||
|
$s .= '<div id="ijpost-bydefault-wrapper">';
|
||||||
|
$s .= '<label id="ijpost-bydefault-label" for="ijpost-bydefault">' . t('Post to InsaneJournal by default') . '</label>';
|
||||||
|
$s .= '<input id="ijpost-bydefault" type="checkbox" name="ij_bydefault" value="1" ' . $def_checked . '/>';
|
||||||
|
$s .= '</div><div class="clear"></div>';
|
||||||
|
|
||||||
|
/* provide a submit button */
|
||||||
|
|
||||||
|
$s .= '<div class="settings-submit-wrapper" ><input type="submit" id="ijpost-submit" name="ijpost-submit" class="settings-submit" value="' . t('Submit') . '" /></div></div>';
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function ijpost_settings_post(&$a,&$b) {
|
||||||
|
|
||||||
|
if(x($_POST,'ijpost-submit')) {
|
||||||
|
|
||||||
|
set_pconfig(local_user(),'ijpost','post',intval($_POST['ijpost']));
|
||||||
|
set_pconfig(local_user(),'ijpost','post_by_default',intval($_POST['ij_bydefault']));
|
||||||
|
set_pconfig(local_user(),'ijpost','ij_username',trim($_POST['ij_username']));
|
||||||
|
set_pconfig(local_user(),'ijpost','ij_password',trim($_POST['ij_password']));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function ijpost_post_local(&$a,&$b) {
|
||||||
|
|
||||||
|
// This can probably be changed to allow editing by pointing to a different API endpoint
|
||||||
|
|
||||||
|
if($b['edit'])
|
||||||
|
return;
|
||||||
|
|
||||||
|
if((! local_user()) || (local_user() != $b['uid']))
|
||||||
|
return;
|
||||||
|
|
||||||
|
if($b['private'] || $b['parent'])
|
||||||
|
return;
|
||||||
|
|
||||||
|
$ij_post = intval(get_pconfig(local_user(),'ijpost','post'));
|
||||||
|
|
||||||
|
$ij_enable = (($ij_post && x($_REQUEST,'ijpost_enable')) ? intval($_REQUEST['ijpost_enable']) : 0);
|
||||||
|
|
||||||
|
if($_REQUEST['api_source'] && intval(get_pconfig(local_user(),'ijpost','post_by_default')))
|
||||||
|
$ij_enable = 1;
|
||||||
|
|
||||||
|
if(! $ij_enable)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if(strlen($b['postopts']))
|
||||||
|
$b['postopts'] .= ',';
|
||||||
|
$b['postopts'] .= 'ijpost';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
function ijpost_send(&$a,&$b) {
|
||||||
|
|
||||||
|
if($b['deleted'] || $b['private'] || ($b['created'] !== $b['edited']))
|
||||||
|
return;
|
||||||
|
|
||||||
|
if(! strstr($b['postopts'],'ijpost'))
|
||||||
|
return;
|
||||||
|
|
||||||
|
if($b['parent'] != $b['id'])
|
||||||
|
return;
|
||||||
|
|
||||||
|
// insanejournal post in the LJ user's timezone.
|
||||||
|
// Hopefully the person's Friendica account
|
||||||
|
// will be set to the same thing.
|
||||||
|
|
||||||
|
$tz = 'UTC';
|
||||||
|
|
||||||
|
$x = q("select timezone from user where uid = %d limit 1",
|
||||||
|
intval($b['uid'])
|
||||||
|
);
|
||||||
|
if($x && strlen($x[0]['timezone']))
|
||||||
|
$tz = $x[0]['timezone'];
|
||||||
|
|
||||||
|
$ij_username = get_pconfig($b['uid'],'ijpost','ij_username');
|
||||||
|
$ij_password = get_pconfig($b['uid'],'ijpost','ij_password');
|
||||||
|
$ij_blog = 'http://www.insanejournal.com/interface/xmlrpc';
|
||||||
|
|
||||||
|
if($ij_username && $ij_password && $ij_blog) {
|
||||||
|
|
||||||
|
require_once('include/bbcode.php');
|
||||||
|
require_once('include/datetime.php');
|
||||||
|
|
||||||
|
$title = $b['title'];
|
||||||
|
$post = bbcode($b['body']);
|
||||||
|
$post = xmlify($post);
|
||||||
|
$tags = ijpost_get_tags($b['tag']);
|
||||||
|
|
||||||
|
$date = datetime_convert('UTC',$tz,$b['created'],'Y-m-d H:i:s');
|
||||||
|
$year = intval(substr($date,0,4));
|
||||||
|
$mon = intval(substr($date,5,2));
|
||||||
|
$day = intval(substr($date,8,2));
|
||||||
|
$hour = intval(substr($date,11,2));
|
||||||
|
$min = intval(substr($date,14,2));
|
||||||
|
|
||||||
|
$xml = <<< EOT
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<methodCall><methodName>LJ.XMLRPC.postevent</methodName>
|
||||||
|
<params><param>
|
||||||
|
<value><struct>
|
||||||
|
<member><name>year</name><value><int>$year</int></value></member>
|
||||||
|
<member><name>mon</name><value><int>$mon</int></value></member>
|
||||||
|
<member><name>day</name><value><int>$day</int></value></member>
|
||||||
|
<member><name>hour</name><value><int>$hour</int></value></member>
|
||||||
|
<member><name>min</name><value><int>$min</int></value></member>
|
||||||
|
<member><name>event</name><value><string>$post</string></value></member>
|
||||||
|
<member><name>username</name><value><string>$ij_username</string></value></member>
|
||||||
|
<member><name>password</name><value><string>$ij_password</string></value></member>
|
||||||
|
<member><name>subject</name><value><string>$title</string></value></member>
|
||||||
|
<member><name>lineendings</name><value><string>unix</string></value></member>
|
||||||
|
<member><name>ver</name><value><int>1</int></value></member>
|
||||||
|
<member><name>props</name>
|
||||||
|
<value><struct>
|
||||||
|
<member><name>useragent</name><value><string>Friendica</string></value></member>
|
||||||
|
<member><name>taglist</name><value><string>$tags</string></value></member>
|
||||||
|
</struct></value></member>
|
||||||
|
</struct></value>
|
||||||
|
</param></params>
|
||||||
|
</methodCall>
|
||||||
|
|
||||||
|
EOT;
|
||||||
|
|
||||||
|
logger('ijpost: data: ' . $xml, LOGGER_DATA);
|
||||||
|
|
||||||
|
if($ij_blog !== 'test')
|
||||||
|
$x = post_url($ij_blog,$xml,array("Content-Type: text/xml"));
|
||||||
|
logger('posted to insanejournal: ' . ($x) ? $x : '', LOGGER_DEBUG);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function ijpost_get_tags($post)
|
||||||
|
{
|
||||||
|
preg_match_all("/\]([^\[#]+)\[/",$post,$matches);
|
||||||
|
$tags = implode(', ',$matches[1]);
|
||||||
|
return $tags;
|
||||||
|
}
|
13
irc/irc.php
|
@ -3,9 +3,14 @@
|
||||||
* Name: IRC Chat Plugin
|
* Name: IRC Chat Plugin
|
||||||
* Description: add an Internet Relay Chat chatroom
|
* Description: add an Internet Relay Chat chatroom
|
||||||
* Version: 1.0
|
* Version: 1.0
|
||||||
* Author: tony baldwin <http://tonybaldwin.me>
|
* Author: tony baldwin <https://free-haven.org/profile/tony>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* enable in admin->plugins
|
||||||
|
* you will then have "irc chatroom" listed at yoursite/apps
|
||||||
|
* and the app will run at yoursite/irc
|
||||||
|
* documentation at http://tonybaldwin.me/hax/doku.php?id=friendica:irc
|
||||||
|
*/
|
||||||
|
|
||||||
function irc_install() {
|
function irc_install() {
|
||||||
register_hook('app_menu', 'addon/irc/irc.php', 'irc_app_menu');
|
register_hook('app_menu', 'addon/irc/irc.php', 'irc_app_menu');
|
||||||
|
@ -32,9 +37,13 @@ $baseurl = $a->get_baseurl() . '/addon/irc';
|
||||||
$o = '';
|
$o = '';
|
||||||
|
|
||||||
|
|
||||||
// add the chatroom frame and some html
|
/* add the chatroom frame and some html
|
||||||
|
* by altering the "channels=friendica" part of the URL, you can add/remove channels.
|
||||||
|
* At free-haven.org, I have "?channels=friendica,free-haven", for instance, to open #friendica and #free-haven
|
||||||
|
*/
|
||||||
$o .= <<< EOT
|
$o .= <<< EOT
|
||||||
<h2>IRC chat</h2>
|
<h2>IRC chat</h2>
|
||||||
|
<p><a href="http://tldp.org/HOWTO/IRC/beginners.html" target="_blank">a beginner's guide to using IRC.</a></p>
|
||||||
<iframe src="http://webchat.freenode.net?channels=friendica" width="600" height="600"></iframe>
|
<iframe src="http://webchat.freenode.net?channels=friendica" width="600" height="600"></iframe>
|
||||||
EOT;
|
EOT;
|
||||||
|
|
||||||
|
|
BIN
ljpost.tgz
|
@ -4,7 +4,7 @@
|
||||||
* Name: LiveJournal Post Connector
|
* Name: LiveJournal Post Connector
|
||||||
* Description: Post to LiveJournal
|
* Description: Post to LiveJournal
|
||||||
* Version: 1.0
|
* Version: 1.0
|
||||||
* Author: Tony Baldwin <http://tonybaldwin.me/friendica/profile/tony>
|
* Author: Tony Baldwin <https://free-haven.org/profile/tony>
|
||||||
* Author: Michael Johnston
|
* Author: Michael Johnston
|
||||||
* Author: Cat Gray <https://free-haven.org/profile/catness>
|
* Author: Cat Gray <https://free-haven.org/profile/catness>
|
||||||
*/
|
*/
|
||||||
|
@ -232,7 +232,7 @@ EOT;
|
||||||
logger('ljpost: data: ' . $xml, LOGGER_DATA);
|
logger('ljpost: data: ' . $xml, LOGGER_DATA);
|
||||||
|
|
||||||
if($lj_blog !== 'test')
|
if($lj_blog !== 'test')
|
||||||
$x = post_url($lj_blog,$xml);
|
$x = post_url($lj_blog,$xml,array("Content-Type: text/xml"));
|
||||||
logger('posted to livejournal: ' . ($x) ? $x : '', LOGGER_DEBUG);
|
logger('posted to livejournal: ' . ($x) ? $x : '', LOGGER_DEBUG);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,60 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Name: Page
|
||||||
|
* Description: Shows lists of community pages (improved performance over 'pages')
|
||||||
|
* Version: 1.0
|
||||||
|
* Author: Mike Macgirvin <mike@macgirvin.com>
|
||||||
|
* based on pages plugin by
|
||||||
|
* Author: Michael Vogel <ike@piratenpartei.de>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
function page_install() {
|
||||||
|
register_hook('page_end', 'addon/page/page.php', 'page_page_end');
|
||||||
|
}
|
||||||
|
|
||||||
|
function page_uninstall() {
|
||||||
|
unregister_hook('page_end', 'addon/page/page.php', 'page_page_end');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function page_getpage($uid) {
|
||||||
|
|
||||||
|
|
||||||
|
$pagelist = array();
|
||||||
|
|
||||||
|
$contacts = q("SELECT `id`, `url`, `name`, `micro`FROM `contact`
|
||||||
|
WHERE `network`= 'dfrn' AND `forum` = 1 AND `uid` = %d",
|
||||||
|
intval($uid)
|
||||||
|
);
|
||||||
|
|
||||||
|
$page = array();
|
||||||
|
|
||||||
|
// Look if the profile is a community page
|
||||||
|
foreach($contacts as $contact) {
|
||||||
|
$page[] = array("url"=>$contact["url"], "name"=>$contact["name"], "id"=>$contact["id"], "micro"=>$contact['micro']);
|
||||||
|
}
|
||||||
|
return($page);
|
||||||
|
}
|
||||||
|
|
||||||
|
function page_page_end($a,&$b) {
|
||||||
|
// Only move on if if it's the "network" module and there is a logged on user
|
||||||
|
if (($a->module != "network") OR ($a->user['uid'] == 0))
|
||||||
|
return;
|
||||||
|
|
||||||
|
$page = '<div id="page-sidebar" class="widget">
|
||||||
|
<div class="title tool">
|
||||||
|
<h3>'.t("Community Pages").'</h3></div>
|
||||||
|
<div id="sidebar-page-list"><ul>';
|
||||||
|
|
||||||
|
$contacts = page_getpage($a->user['uid']);
|
||||||
|
|
||||||
|
foreach($contacts as $contact) {
|
||||||
|
$page .= '<li style="list-style-type: none;" class="tool"><img height="20" width="20" src="' . $contact['micro'] .'" alt="' . $contact['url'] . '" /> <a href="'.$a->get_baseurl().'/redir/'.$contact["id"].'" title="' . $contact['url'] . '" class="label" target="external-link">'.
|
||||||
|
$contact["name"]."</a></li>";
|
||||||
|
}
|
||||||
|
$page .= "</ul></div></div>";
|
||||||
|
if (sizeof($contacts) > 0)
|
||||||
|
$a->page['aside'] = $page . $a->page['aside'];
|
||||||
|
}
|
||||||
|
?>
|
|
@ -0,0 +1,44 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Name: Remember OpenID Login
|
||||||
|
* Description: Autologin with last openid used
|
||||||
|
* Version: 1.0
|
||||||
|
* Author: Fabio Comuni <http://kirgroup.com/profile/fabrixxm>
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
function rememberoid_install(){
|
||||||
|
register_hook('init_1','addon/rememberoid/rememberoid.php','rememberoid_init');
|
||||||
|
register_hook('logging_out','addon/rememberoid/rememberoid.php','rememberoid_logout');
|
||||||
|
register_hook('login_hook','addon/rememberoid/rememberoid.php','rememberoid_form');
|
||||||
|
}
|
||||||
|
|
||||||
|
function rememberoid_uninstall(){
|
||||||
|
unregister_hook('init_1','addon/rememberoid/rememberoid.php','rememberoid_init');
|
||||||
|
unregister_hook('logging_out','addon/rememberoid/rememberoid.php','rememberoid_logout');
|
||||||
|
unregister_hook('login_hook','addon/rememberoid/rememberoid.php','rememberoid_form');
|
||||||
|
}
|
||||||
|
|
||||||
|
function rememberoid_init(&$a) {
|
||||||
|
if (x($_COOKIE, "remember_oid") && !x($_SESSION['openid']) && !x($_SESSION,'authenticated') && !x($_POST,'auth-params') && $a->module === 'home' ){
|
||||||
|
$_POST['openid_url'] = $_COOKIE["remember_oid"];
|
||||||
|
$_POST['auth-params'] = 1;
|
||||||
|
}
|
||||||
|
if (x($_POST,'auth-params') && $_POST['openid_url'] && $_POST['openid_url']!="" && $_POST['remember_oid']){
|
||||||
|
setcookie('remember_oid', $_POST['openid_url'], time()+60*60*24*30, "/");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function rememberoid_logout(&$a) {
|
||||||
|
setcookie("rembember_oid", "", time()-3600);
|
||||||
|
}
|
||||||
|
|
||||||
|
function rememberoid_form(&$a, &$o){
|
||||||
|
$tpl = get_markup_template("field_checkbox.tpl");
|
||||||
|
$html = replace_macros($tpl, array(
|
||||||
|
'$field' => array('remember_oid', t("Autologin with this OpenId"), false,''),
|
||||||
|
));
|
||||||
|
|
||||||
|
$o = preg_replace("|<div *id=[\"']login_openid[\"']>|", "<div id='login_openid'>".$html, $o);
|
||||||
|
|
||||||
|
}
|
After Width: | Height: | Size: 4.4 KiB |
After Width: | Height: | Size: 25 KiB |
After Width: | Height: | Size: 1.4 KiB |
After Width: | Height: | Size: 6.5 KiB |
After Width: | Height: | Size: 2.3 KiB |
After Width: | Height: | Size: 3.6 KiB |
After Width: | Height: | Size: 780 B |
After Width: | Height: | Size: 2.7 KiB |
After Width: | Height: | Size: 5.2 KiB |
After Width: | Height: | Size: 1.5 KiB |
After Width: | Height: | Size: 2.5 KiB |
After Width: | Height: | Size: 951 B |
After Width: | Height: | Size: 4.4 KiB |
After Width: | Height: | Size: 1.5 KiB |
After Width: | Height: | Size: 4.8 KiB |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 2.4 KiB |
After Width: | Height: | Size: 990 B |
After Width: | Height: | Size: 4.8 KiB |
After Width: | Height: | Size: 1.7 KiB |
After Width: | Height: | Size: 925 B |
After Width: | Height: | Size: 7.5 KiB |
After Width: | Height: | Size: 645 B |
After Width: | Height: | Size: 1.5 KiB |
After Width: | Height: | Size: 334 B |
After Width: | Height: | Size: 3.4 KiB |
After Width: | Height: | Size: 1.5 KiB |
After Width: | Height: | Size: 18 KiB |
After Width: | Height: | Size: 594 B |
After Width: | Height: | Size: 1.6 KiB |
After Width: | Height: | Size: 184 B |
After Width: | Height: | Size: 10 KiB |
After Width: | Height: | Size: 158 B |
After Width: | Height: | Size: 5.0 KiB |
After Width: | Height: | Size: 312 B |
After Width: | Height: | Size: 2.9 KiB |
After Width: | Height: | Size: 1.9 KiB |
After Width: | Height: | Size: 1.6 KiB |
After Width: | Height: | Size: 6.6 KiB |
After Width: | Height: | Size: 1.9 KiB |
After Width: | Height: | Size: 8.0 KiB |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 636 B |
After Width: | Height: | Size: 29 KiB |
After Width: | Height: | Size: 29 KiB |
After Width: | Height: | Size: 23 KiB |
After Width: | Height: | Size: 8.7 KiB |
After Width: | Height: | Size: 2.7 KiB |
After Width: | Height: | Size: 9.7 KiB |
After Width: | Height: | Size: 1.3 KiB |
After Width: | Height: | Size: 7.5 KiB |
After Width: | Height: | Size: 454 B |
After Width: | Height: | Size: 2.8 KiB |
After Width: | Height: | Size: 3.4 KiB |
After Width: | Height: | Size: 2.3 KiB |
After Width: | Height: | Size: 1.0 KiB |
After Width: | Height: | Size: 6.4 KiB |
After Width: | Height: | Size: 810 B |
After Width: | Height: | Size: 69 KiB |
After Width: | Height: | Size: 26 KiB |
After Width: | Height: | Size: 3.0 KiB |
After Width: | Height: | Size: 174 B |
After Width: | Height: | Size: 2.2 KiB |
After Width: | Height: | Size: 1.3 KiB |
After Width: | Height: | Size: 20 KiB |
After Width: | Height: | Size: 891 B |
After Width: | Height: | Size: 403 B |
After Width: | Height: | Size: 167 B |
After Width: | Height: | Size: 1.7 KiB |
After Width: | Height: | Size: 16 KiB |
After Width: | Height: | Size: 2.0 KiB |
After Width: | Height: | Size: 1.7 KiB |
After Width: | Height: | Size: 5.7 KiB |
After Width: | Height: | Size: 664 B |
After Width: | Height: | Size: 3.2 KiB |
After Width: | Height: | Size: 11 KiB |