*/ require_once 'mod/item.php'; use Friendica\App; use Friendica\Content\PageInfo; use Friendica\Core\Hook; use Friendica\Core\Logger; use Friendica\Core\Protocol; use Friendica\Database\DBA; use Friendica\DI; use Friendica\Model\Item; use Friendica\Util\Strings; function ifttt_install() { Hook::register('connector_settings', 'addon/ifttt/ifttt.php', 'ifttt_settings'); Hook::register('connector_settings_post', 'addon/ifttt/ifttt.php', 'ifttt_settings_post'); } function ifttt_module() { } function ifttt_content() { } function ifttt_settings(App $a, &$s) { if (!local_user()) { return; } $key = DI::pConfig()->get(local_user(), 'ifttt', 'key'); if (!$key) { $key = Strings::getRandomHex(20); DI::pConfig()->set(local_user(), 'ifttt', 'key', $key); } $s .= ''; $s .= '

' . DI::l10n()->t('IFTTT Mirror') . '

'; $s .= '
'; $s .= ''; } function ifttt_settings_post() { if (!empty($_POST['ifttt-submit']) && isset($_POST['ifttt-rekey'])) { DI::pConfig()->delete(local_user(), 'ifttt', 'key'); } } function ifttt_post(App $a) { if ($a->argc != 2) { return; } $nickname = $a->argv[1]; $user = DBA::selectFirst('user', ['uid'], ['nickname' => $nickname]); if (!DBA::isResult($user)) { Logger::log('User ' . $nickname . ' not found.', Logger::DEBUG); return; } $uid = $user['uid']; Logger::log('Received a post for user ' . $uid . ' from ifttt ' . print_r($_REQUEST, true), Logger::DEBUG); if (!isset($_REQUEST['key'])) { Logger::log('No key found.'); return; } $key = $_REQUEST['key']; // Check the key if ($key != DI::pConfig()->get($uid, 'ifttt', 'key')) { Logger::log('Invalid key for user ' . $uid, Logger::DEBUG); return; } $item = []; if (isset($_REQUEST['type'])) { $item['type'] = $_REQUEST['type']; } if (!in_array($item['type'], ['status', 'link', 'photo'])) { Logger::log('Unknown item type ' . $item['type'], Logger::DEBUG); return; } if (isset($_REQUEST['link'])) { $item['link'] = trim($_REQUEST['link']); } if (isset($_REQUEST['image'])) { $item['image'] = trim($_REQUEST['image']); } if (isset($_REQUEST['title'])) { $item['title'] = trim($_REQUEST['title']); } if (isset($_REQUEST['msg'])) { $item['msg'] = trim($_REQUEST['msg']); } if (isset($_REQUEST['description'])) { $item['description'] = trim($_REQUEST['description']); } if (isset($_REQUEST['date'])) { $item['date'] = date('c', strtotime($date = str_replace(' at ', ', ', $_REQUEST['date']))); } if (isset($_REQUEST['url'])) { $item['url'] = trim($_REQUEST['url']); } if ((substr($item['msg'], 0, 3) == '<<<') && (substr($item['msg'], -3, 3) == '>>>')) { $item['msg'] = substr($item['msg'], 3, -3); } ifttt_message($uid, $item); } function ifttt_message($uid, $item) { $a = DI::app(); $_SESSION['authenticated'] = true; $_SESSION['uid'] = $uid; unset($_REQUEST); $_REQUEST['api_source'] = true; $_REQUEST['profile_uid'] = $uid; $_REQUEST['source'] = 'IFTTT'; $_REQUEST['title'] = ''; $_REQUEST['body'] = $item['msg']; //$_REQUEST['date'] = $item['date']; //$_REQUEST['uri'] = $item['url']; if (!empty($item['url']) && strstr($item['url'], 'facebook.com')) { $hash = hash('ripemd128', $item['url']); $_REQUEST['extid'] = Protocol::FACEBOOK; $_REQUEST['message_id'] = Item::newURI($uid, Protocol::FACEBOOK . ':' . $hash); } if ($item['type'] == 'link') { $data = PageInfo::queryUrl($item['link']); if (isset($item['title']) && (trim($item['title']) != '')) { $data['title'] = $item['title']; } if (isset($item['description']) && (trim($item['description']) != '')) { $data['text'] = $item['description']; } $_REQUEST['body'] .= "\n" . PageInfo::getFooterFromData($data); } elseif (($item['type'] == 'photo') && ($item['image'] != '')) { $_REQUEST['body'] .= "\n\n[img]" . $item['image'] . "[/img]\n"; } item_post($a); }