mirror of
https://github.com/YunoHost-Apps/hubzilla_ynh.git
synced 2024-09-03 19:26:21 +02:00
129 lines
3.1 KiB
PHP
129 lines
3.1 KiB
PHP
|
<?php
|
||
|
|
||
|
if (($_POST["friendika_acct_name"] != '') && ($_POST["friendika_password"] != '')) {
|
||
|
setcookie("username", $_POST["friendika_acct_name"], time()+60*60*24*300);
|
||
|
setcookie("password", $_POST["friendika_password"], time()+60*60*24*300);
|
||
|
}
|
||
|
|
||
|
?>
|
||
|
<html>
|
||
|
<head>
|
||
|
<style>
|
||
|
body {
|
||
|
font-family: arial, Helvetica,sans-serif;
|
||
|
margin: 0px;
|
||
|
}
|
||
|
.wrap1 {
|
||
|
padding: 2px 5px;
|
||
|
background-color: #729FCF;
|
||
|
margin-bottom: 10px;
|
||
|
}
|
||
|
.wrap2 {
|
||
|
margin-left: 10px;
|
||
|
font-size: 12px;
|
||
|
}
|
||
|
.logo {
|
||
|
margin-left: 3px;
|
||
|
margin-right: 5px;
|
||
|
float: left;
|
||
|
}
|
||
|
h2 {
|
||
|
color: #ffffff;
|
||
|
}
|
||
|
.error {
|
||
|
background-color: #FFFF66;
|
||
|
font-size: 12px;
|
||
|
margin-left: 10px;
|
||
|
}
|
||
|
</style>
|
||
|
</head>
|
||
|
|
||
|
<body>
|
||
|
<?php
|
||
|
|
||
|
if (isset($_GET['title'])) {
|
||
|
$title = $_GET['title'];
|
||
|
}
|
||
|
if (isset($_GET['text'])) {
|
||
|
$text = $_GET['text'];
|
||
|
}
|
||
|
if (isset($_GET['url'])) {
|
||
|
$url = $_GET['url'];
|
||
|
}
|
||
|
|
||
|
if ((isset($title)) && (isset($text)) && (isset($url))) {
|
||
|
$content = "$title\nsource:$url\n\n$text";
|
||
|
} else {
|
||
|
$content = $_POST['content'];
|
||
|
}
|
||
|
|
||
|
if (isset($_POST['submit'])) {
|
||
|
|
||
|
if (($_POST["friendika_acct_name"] != '') && ($_POST["friendika_password"] != '')) {
|
||
|
$acctname = $_POST["friendika_acct_name"];
|
||
|
$tmp_account_array = explode("@", $acctname);
|
||
|
if (isset($tmp_account_array[1])) {
|
||
|
$username = $tmp_account_array[0];
|
||
|
$hostname = $tmp_account_array[1];
|
||
|
}
|
||
|
$password = $_POST["friendika_password"];
|
||
|
$content = $_POST["content"];
|
||
|
|
||
|
$url = "http://" . $hostname . '/api/statuses/update';
|
||
|
$data = array('status' => $content);
|
||
|
|
||
|
// echo "posting to: $url<br/>";
|
||
|
|
||
|
$c = curl_init();
|
||
|
curl_setopt($c, CURLOPT_URL, $url);
|
||
|
curl_setopt($c, CURLOPT_USERPWD, "$username:$password");
|
||
|
curl_setopt($c, CURLOPT_POSTFIELDS, $data);
|
||
|
curl_setopt($c, CURLOPT_RETURNTRANSFER, true);
|
||
|
curl_setopt($c, CURLOPT_FOLLOWLOCATION, true);
|
||
|
$c_result = curl_exec($c);
|
||
|
if(curl_errno($c)){
|
||
|
$error = curl_error($c);
|
||
|
showForm($error, $content);
|
||
|
}
|
||
|
|
||
|
curl_close($c);
|
||
|
if (!isset($error)) {
|
||
|
echo '<script language="javascript" type="text/javascript">window.close();</script>';
|
||
|
}
|
||
|
|
||
|
} else {
|
||
|
$error = "Missing account name and/or password...try again please";
|
||
|
showForm($error, $content);
|
||
|
}
|
||
|
|
||
|
} else {
|
||
|
showForm(null, $content);
|
||
|
}
|
||
|
|
||
|
function showForm($error, $content) {
|
||
|
$username_cookie = $_COOKIE['username'];
|
||
|
$password_cookie = $_COOKIE['password'];
|
||
|
|
||
|
echo <<<EOF
|
||
|
<div class='wrap1'>
|
||
|
<h2><img class='logo' src='friendika-32.png' align='middle';/>
|
||
|
Friendika Bookmarklet</h2>
|
||
|
</div>
|
||
|
|
||
|
<div class="wrap2">
|
||
|
<form method="post" action="{$_SERVER['PHP_SELF']}">
|
||
|
Enter the email address of the Friendika Account that you want to cross-post to:(example: user@friendika.org)<br /><br />
|
||
|
Account ID: <input type="text" name="friendika_acct_name" value="{$username_cookie}" size="50"/><br />
|
||
|
Password: <input type="password" name="friendika_password" value="{$password_cookie}" size="50"/><br />
|
||
|
<textarea name="content" id="content" rows="6" cols="70">{$content}</textarea><br />
|
||
|
<input type="submit" value="PostIt!" name="submit" /> <span class='error'>$error</span>
|
||
|
</form>
|
||
|
<p></p>
|
||
|
</div>
|
||
|
EOF;
|
||
|
|
||
|
}
|
||
|
?>
|
||
|
|
||
|
</body>
|
||
|
</html>
|