aboutsummaryrefslogtreecommitdiff
path: root/controller/apicontroller.php
diff options
context:
space:
mode:
authorChristian Weiske <cweiske@cweiske.de>2014-09-29 21:42:55 +0200
committerChristian Weiske <cweiske@cweiske.de>2014-09-29 21:42:55 +0200
commit35be0ae011c70e766417b1e640a8dac03644a3b6 (patch)
treea1a19eaa48fc1f1b60bee373ffb4c54dfb173c31 /controller/apicontroller.php
parent01aae57048be789c8102106833f734b382aafc2e (diff)
downloadgrauphel-35be0ae011c70e766417b1e640a8dac03644a3b6.tar.gz
grauphel-35be0ae011c70e766417b1e640a8dac03644a3b6.zip
Show client name in oauth authorization (works for tomdroid only)
Diffstat (limited to 'controller/apicontroller.php')
-rw-r--r--controller/apicontroller.php31
1 files changed, 31 insertions, 0 deletions
diff --git a/controller/apicontroller.php b/controller/apicontroller.php
index 691d8ab..ee16f80 100644
--- a/controller/apicontroller.php
+++ b/controller/apicontroller.php
@@ -105,6 +105,12 @@ class ApiController extends Controller
'api-version' => '1.0',
);
+ $client = $this->getClient();
+ if ($client !== false) {
+ $data['oauth_authorize_url'] .= '?client='
+ . urlencode($this->getNiceClientName($client));
+ }
+
if ($authenticated) {
$data['user-ref'] = array(
'api-ref' => $urlGen->getAbsoluteURL(
@@ -327,6 +333,31 @@ class ApiController extends Controller
return new JSONResponse($note);
}
+ protected function getClient()
+ {
+ if (isset($_SERVER['HTTP_X_TOMBOY_CLIENT'])) {
+ $client = $_SERVER['HTTP_X_TOMBOY_CLIENT'];
+ $doublepos = strpos($client, ', org.tomdroid');
+ if ($doublepos !== false) {
+ //https://bugs.launchpad.net/tomdroid/+bug/1375436
+ //X-Tomboy-Client header is sent twice
+ $client = substr($client, 0, $doublepos);
+ }
+ return $client;
+ }
+
+ return false;
+ }
+
+ protected function getNiceClientName($client)
+ {
+ if (substr($client, 0, 12) == 'org.tomdroid') {
+ //org.tomdroid v0.7.5, build 14, Android v4.4.2, innotek GmbH/VirtualBox
+ return 'Tomdroid';
+ }
+ return $client;
+ }
+
/**
* Checks if the given user is authorized (by oauth token or normal login)
*