]> git.mxchange.org Git - quix0rs-gnu-social.git/blob - scripts/enjitqueuehandler.php
Merge branch '0.8.x' into cmdline
[quix0rs-gnu-social.git] / scripts / enjitqueuehandler.php
1 #!/usr/bin/env php
2 <?php
3 /*
4  * Laconica - a distributed open-source microblogging tool
5  * Copyright (C) 2008, 2009, Control Yourself, Inc.
6  *
7  * This program is free software: you can redistribute it and/or modify
8  * it under the terms of the GNU Affero General Public License as published by
9  * the Free Software Foundation, either version 3 of the License, or
10  * (at your option) any later version.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU Affero General Public License for more details.
16  *
17  * You should have received a copy of the GNU Affero General Public License
18  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
19  */
20
21 # Abort if called from a web server
22 if (isset($_SERVER) && array_key_exists('REQUEST_METHOD', $_SERVER)) {
23     print "This script must be run from the command line\n";
24     exit();
25 }
26
27 define('INSTALLDIR', realpath(dirname(__FILE__) . '/..'));
28 define('LACONICA', true);
29
30 // Preset the server at the command line
31
32 $server = ($argc > 2) ? $argv[2] : null;
33 $path   = ($argc > 3) ? $argv[3] : null;
34
35 require_once(INSTALLDIR . '/lib/common.php');
36 require_once(INSTALLDIR . '/lib/mail.php');
37 require_once(INSTALLDIR . '/lib/queuehandler.php');
38
39 set_error_handler('common_error_handler');
40
41 class EnjitQueueHandler extends QueueHandler
42 {
43     function transport()
44     {
45         return 'enjit';
46     }
47
48     function start()
49     {
50                 $this->log(LOG_INFO, "Starting EnjitQueueHandler");
51                 $this->log(LOG_INFO, "Broadcasting to ".common_config('enjit', 'apiurl'));
52         return true;
53     }
54
55     function handle_notice($notice)
56     {
57
58         $profile = Profile::staticGet($notice->profile_id);
59
60                 $this->log(LOG_INFO, "Posting Notice ".$notice->id." from ".$profile->nickname);
61
62                 if ( ! $notice->is_local ) {
63                     $this->log(LOG_INFO, "Skipping remote notice");
64                     return "skipped";
65                 }
66
67                 #
68                 # Build an Atom message from the notice
69                 #
70         $noticeurl = common_local_url('shownotice', array('notice' => $notice->id));
71         $msg = $profile->nickname . ': ' . $notice->content;
72
73         $atom  = "<entry xmlns='http://www.w3.org/2005/Atom'>\n";
74         $atom .= "<apisource>".common_config('enjit','source')."</apisource>\n";
75         $atom .= "<source>\n";
76         $atom .= "<title>" . $profile->nickname . " - " . common_config('site', 'name') . "</title>\n";
77         $atom .= "<link href='" . $profile->profileurl . "'/>\n";
78         $atom .= "<link rel='self' type='application/rss+xml' href='" . common_local_url('userrss', array('nickname' => $profile->nickname)) . "'/>\n";
79         $atom .= "<author><name>" . $profile->nickname . "</name></author>\n";
80         $atom .= "<icon>" . $profile->avatarUrl(AVATAR_PROFILE_SIZE) . "</icon>\n";
81         $atom .= "</source>\n";
82         $atom .= "<title>" . htmlspecialchars($msg) . "</title>\n";
83         $atom .= "<summary>" . htmlspecialchars($msg) . "</summary>\n";
84         $atom .= "<link rel='alternate' href='" . $noticeurl . "' />\n";
85         $atom .= "<id>". $notice->uri . "</id>\n";
86         $atom .= "<published>".common_date_w3dtf($notice->created)."</published>\n";
87         $atom .= "<updated>".common_date_w3dtf($notice->modified)."</updated>\n";
88         $atom .= "</entry>\n";
89
90                 $url  = common_config('enjit', 'apiurl') . "/submit/". common_config('enjit','apikey');
91                 $data = "msg=$atom";
92
93                 #
94                 # POST the message to $config['enjit']['apiurl']
95                 #
96         $ch   = curl_init();
97
98         curl_setopt($ch, CURLOPT_URL, $url);
99
100                 curl_setopt($ch, CURLOPT_HEADER, 1);
101         curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
102         curl_setopt($ch, CURLOPT_POST, 1) ;
103         curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
104
105                 # SSL and Debugging options
106                 #
107         # curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
108         # curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
109                 # curl_setopt($ch, CURLOPT_VERBOSE, 1);
110
111         $result = curl_exec($ch);
112
113         $code = curl_getinfo($ch, CURLINFO_HTTP_CODE );
114
115                 $this->log(LOG_INFO, "Response Code: $code");
116
117         curl_close($ch);
118
119                 return $code;
120     }
121
122 }
123
124 mb_internal_encoding('UTF-8');
125
126 $id = ($argc > 1) ? $argv[1] : null;
127
128 $handler = new EnjitQueueHandler($id);
129
130 if ($handler->start()) {
131     $handler->handle_queue();
132 }
133
134 $handler->finish();