aboutsummaryrefslogtreecommitdiffstats
path: root/util/fpostit/fpostit.php
blob: 491d81f6d6ffd38cf7ce28bac16785017e02e51d (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
<?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" />&nbsp;&nbsp;<span class='error'>$error</span>
		</form>
		<p></p>
	</div>
EOF;
	
}
?>

</body>
</html>