*/ require_once 'mod/item.php'; require_once 'include/items.php'; require_once 'include/text.php'; use Friendica\App; use Friendica\Core\Addon; use Friendica\Core\L10n; use Friendica\Core\PConfig; use Friendica\Database\DBM; use Friendica\Model\Item; function ifttt_install() { Addon::registerHook('connector_settings', 'addon/ifttt/ifttt.php', 'ifttt_settings'); Addon::registerHook('connector_settings_post', 'addon/ifttt/ifttt.php', 'ifttt_settings_post'); } function ifttt_uninstall() { Addon::unregisterHook('connector_settings', 'addon/ifttt/ifttt.php', 'ifttt_settings'); Addon::unregisterHook('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 = PConfig::get(local_user(), 'ifttt', 'key'); if (!$key) { $key = random_string(20); PConfig::set(local_user(), 'ifttt', 'key', $key); } $s .= ''; $s .= '

' . L10n::t('IFTTT Mirror') . '

'; $s .= '
'; $s .= ''; } function ifttt_settings_post() { if (x($_POST, 'ifttt-submit') && isset($_POST['ifttt-rekey'])) { 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 (!DBM::is_result($user)) { logger('User ' . $nickname . ' not found.', LOGGER_DEBUG); return; } $uid = $user['uid']; logger('Received a post for user ' . $uid . ' from ifttt ' . print_r($_REQUEST, true), LOGGER_DEBUG); if (!isset($_REQUEST['key'])) { logger('No key found.'); return; } $key = $_REQUEST['key']; // Check the key if ($key != PConfig::get($uid, 'ifttt', 'key')) { logger('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('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 = get_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 (strstr($item['url'], 'facebook.com')) { $hash = hash('ripemd128', item['url']); $_REQUEST['extid'] = NETWORK_FACEBOOK; $_REQUEST['message_id'] = Item::newURI($uid, NETWORK_FACEBOOK . ':' . $hash); } if ($item['type'] == 'link') { $data = query_page_info($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'] .= add_page_info_data($data); } elseif (($item['type'] == 'photo') && ($item['image'] != '')) { $_REQUEST['body'] .= "\n\n[img]" . $item['image'] . "[/img]\n"; } item_post($a); }