]> git.mxchange.org Git - friendica.git/blobdiff - mod/poke.php
consistent use of terms in heading in the admin panel
[friendica.git] / mod / poke.php
index 93167472cfd975dfc02b29b192467548a6bf436c..3148896bc27a8fa624bd4732bdfdf692d9b8f324 100644 (file)
@@ -1,31 +1,54 @@
 <?php
-
-require_once('include/security.php');
-require_once('include/bbcode.php');
-require_once('include/items.php');
-
-
-function poke_init(&$a) {
-
-       if(! local_user())
+/**
+ * Poke, prod, finger, or otherwise do unspeakable things to somebody - who must be a connection in your address book
+ * This function can be invoked with the required arguments (verb and cid and private and possibly parent) silently via ajax or
+ * other web request. You must be logged in and connected to a profile.
+ * If the required arguments aren't present, we'll display a simple form to choose a recipient and a verb.
+ * parent is a special argument which let's you attach this activity as a comment to an existing conversation, which
+ * may have started with somebody else poking (etc.) somebody, but this isn't necessary. This can be used in the more pokes
+ * addon version to have entire conversations where Alice poked Bob, Bob fingered Alice, Alice hugged Bob, etc.
+ *
+ * private creates a private conversation with the recipient. Otherwise your profile's default post privacy is used.
+ *
+ * @file mod/poke.php
+ */
+
+use Friendica\App;
+use Friendica\Core\Addon;
+use Friendica\Core\L10n;
+use Friendica\Core\System;
+use Friendica\Core\Worker;
+use Friendica\Database\DBM;
+use Friendica\Model\Item;
+
+require_once 'include/security.php';
+require_once 'include/items.php';
+
+function poke_init(App $a) {
+
+       if (! local_user()) {
                return;
+       }
 
        $uid = local_user();
        $verb = notags(trim($_GET['verb']));
-       
-       if(! $verb) 
+
+       if (! $verb) {
                return;
+       }
 
        $verbs = get_poke_verbs();
 
-       if(! array_key_exists($verb,$verbs))
+       if (! array_key_exists($verb,$verbs)) {
                return;
+       }
 
        $activity = ACTIVITY_POKE . '#' . urlencode($verbs[$verb][0]);
 
        $contact_id = intval($_GET['cid']);
-       if(! $contact_id)
+       if (! $contact_id) {
                return;
+       }
 
        $parent = ((x($_GET,'parent')) ? intval($_GET['parent']) : 0);
 
@@ -33,12 +56,12 @@ function poke_init(&$a) {
        logger('poke: verb ' . $verb . ' contact ' . $contact_id, LOGGER_DEBUG);
 
 
-       $r = q("SELECT * FROM `contact` WHERE `id` = %d and  `uid` = %d LIMIT 1",
+       $r = q("SELECT * FROM `contact` WHERE `id` = %d AND `uid` = %d LIMIT 1",
                intval($contact_id),
                intval($uid)
        );
 
-       if(! count($r)) {
+       if (! DBM::is_result($r)) {
                logger('poke: no contact ' . $contact_id);
                return;
        }
@@ -46,13 +69,13 @@ function poke_init(&$a) {
        $target = $r[0];
 
        if($parent) {
-               $r = q("select uri, private, allow_cid, allow_gid, deny_cid, deny_gid 
-                       from item where id = %d and parent = %d and uid = %d limit 1",
+               $r = q("SELECT `uri`, `private`, `allow_cid`, `allow_gid`, `deny_cid`, `deny_gid`
+                       FROM `item` WHERE `id` = %d AND `parent` = %d AND `uid` = %d LIMIT 1",
                        intval($parent),
                        intval($parent),
                        intval($uid)
                );
-               if(! count($r)) {
+               if (DBM::is_result($r)) {
                        $parent_uri = $r[0]['uri'];
                        $private    = $r[0]['private'];
                        $allow_cid  = $r[0]['allow_cid'];
@@ -71,15 +94,13 @@ function poke_init(&$a) {
                $deny_gid      = (($private) ? '' : $a->user['deny_gid']);
        }
 
-
-
-
        $poster = $a->contact;
 
-       $uri = item_new_uri($a->get_hostname(),$owner_uid);
+       $uri = item_new_uri($a->get_hostname(),$uid);
 
-       $arr = array();
+       $arr = [];
 
+       $arr['guid']          = get_guid(32);
        $arr['uid']           = $uid;
        $arr['uri']           = $uri;
        $arr['parent-uri']    = (($parent_uri) ? $parent_uri : $uri);
@@ -97,45 +118,36 @@ function poke_init(&$a) {
        $arr['allow_gid']     = $allow_gid;
        $arr['deny_cid']      = $deny_cid;
        $arr['deny_gid']      = $deny_gid;
-       $arr['last-child']    = 1;
        $arr['visible']       = 1;
        $arr['verb']          = $activity;
        $arr['private']       = $private;
        $arr['object-type']   = ACTIVITY_OBJ_PERSON;
 
        $arr['origin']        = 1;
-       $arr['body']          = '[url=' . $poster['url'] . ']' . $poster['name'] . '[/url]' . ' ' . t($verbs[$verb][0]) . ' ' . '[url=' . $target['url'] . ']' . $target['name'] . '[/url]';
+       $arr['body']          = '[url=' . $poster['url'] . ']' . $poster['name'] . '[/url]' . ' ' . L10n::t($verbs[$verb][0]) . ' ' . '[url=' . $target['url'] . ']' . $target['name'] . '[/url]';
 
-       $arr['object'] = '<object><type>' . ACTIVITY_OBJ_PERSON . '</type><title>' . $target['name'] . '</title><id>' . $a->get_baseurl() . '/contact/' . $target['id'] . '</id>';
+       $arr['object'] = '<object><type>' . ACTIVITY_OBJ_PERSON . '</type><title>' . $target['name'] . '</title><id>' . System::baseUrl() . '/contact/' . $target['id'] . '</id>';
        $arr['object'] .= '<link>' . xmlify('<link rel="alternate" type="text/html" href="' . $target['url'] . '" />' . "\n");
 
        $arr['object'] .= xmlify('<link rel="photo" type="image/jpeg" href="' . $target['photo'] . '" />' . "\n");
        $arr['object'] .= '</link></object>' . "\n";
 
-       $item_id = item_store($arr);
+       $item_id = Item::insert($arr);
        if($item_id) {
-               q("UPDATE `item` SET `plink` = '%s' WHERE `uid` = %d AND `id` = %d LIMIT 1",
-                       dbesc($a->get_baseurl() . '/display/' . $poster['nickname'] . '/' . $item_id),
-                       intval($uid),
-                       intval($item_id)
-               );
-               proc_run('php',"include/notifier.php","tag","$item_id");
+               Worker::add(PRIORITY_HIGH, "Notifier", "tag", $item_id);
        }
 
-
-       call_hooks('post_local_end', $arr);
-
-       proc_run('php',"include/notifier.php","like","$post_id");
+       Addon::callHooks('post_local_end', $arr);
 
        return;
 }
 
 
 
-function poke_content(&$a) {
+function poke_content(App $a) {
 
-       if(! local_user()) {
-               notice( t('Permission denied.') . EOL);
+       if (! local_user()) {
+               notice(L10n::t('Permission denied.') . EOL);
                return;
        }
 
@@ -143,67 +155,52 @@ function poke_content(&$a) {
        $id = '';
 
        if(intval($_GET['c'])) {
-               $r = q("select id,name from contact where id = %d and uid = %d limit 1",
+               $r = q("SELECT `id`,`name` FROM `contact` WHERE `id` = %d AND `uid` = %d LIMIT 1",
                        intval($_GET['c']),
                        intval(local_user())
                );
-               if(count($r)) {
+               if (DBM::is_result($r)) {
                        $name = $r[0]['name'];
                        $id = $r[0]['id'];
                }
        }
 
 
-       $base = $a->get_baseurl();
+       $base = System::baseUrl();
 
-       $a->page['htmlhead'] .= '<script src="' . $a->get_baseurl(true) . '/library/jquery_ac/friendica.complete.js" ></script>';
-       $a->page['htmlhead'] .= <<< EOT
+       $head_tpl = get_markup_template('poke_head.tpl');
+       $a->page['htmlhead'] .= replace_macros($head_tpl,[
+               '$baseurl' => System::baseUrl(true),
+               '$base' => $base
+       ]);
 
-<script>$(document).ready(function() { 
-       var a; 
-       a = $("#poke-recip").autocomplete({ 
-               serviceUrl: '$base/acl',
-               minChars: 2,
-               width: 350,
-               onSelect: function(value,data) {
-                       $("#poke-recip-complete").val(data);
-               }                       
-       });
-       a.setOptions({ params: { type: 'a' }});
-
-
-}); 
-
-</script>
-EOT;
 
        $parent = ((x($_GET,'parent')) ? intval($_GET['parent']) : '0');
 
 
-
        $verbs = get_poke_verbs();
 
-       $shortlist = array();
+       $shortlist = [];
        foreach($verbs as $k => $v)
                if($v[1] !== 'NOTRANSLATION')
-                       $shortlist[] = array($k,$v[1]);
+                       $shortlist[] = [$k,$v[1]];
 
 
        $tpl = get_markup_template('poke_content.tpl');
 
-       $o = replace_macros($tpl,array(
-               '$title' => t('Poke/Prod'),
-               '$desc' => t('poke, prod or do other things to somebody'),
-               '$clabel' => t('Recipient'),
-               '$choice' => t('Choose what you wish to do to recipient'),
+       $o = replace_macros($tpl,[
+               '$title' => L10n::t('Poke/Prod'),
+               '$desc' => L10n::t('poke, prod or do other things to somebody'),
+               '$clabel' => L10n::t('Recipient'),
+               '$choice' => L10n::t('Choose what you wish to do to recipient'),
                '$verbs' => $shortlist,
                '$parent' => $parent,
-               '$prv_desc' => t('Make this post private'),
-               '$submit' => t('Submit'),
+               '$prv_desc' => L10n::t('Make this post private'),
+               '$submit' => L10n::t('Submit'),
                '$name' => $name,
                '$id' => $id
-       ));
+       ]);
 
        return $o;
 
-}
\ No newline at end of file
+}