summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCraig Andrews <candrews@integralblue.com>2010-10-12 23:36:33 -0400
committerCraig Andrews <candrews@integralblue.com>2010-10-12 23:38:16 -0400
commitf79dbaf9a76c10969dbc45fd43a0bb26f5f64ed4 (patch)
tree86cd49113d42a381825afe902383bc4568dd46d7
parent5f81f6119be8ec0a100cefcaa6f886d16f3be5c5 (diff)
Add a doc page that links to the StatusNet wiki API page
Add a redirect action that merely redirects to another action Redirect /api to /doc/api so users don't get the "lame" "No such user" error message
-rw-r--r--actions/redirect.php71
-rw-r--r--doc-src/api6
-rw-r--r--doc-src/help1
-rw-r--r--lib/router.php5
4 files changed, 83 insertions, 0 deletions
diff --git a/actions/redirect.php b/actions/redirect.php
new file mode 100644
index 000000000..9cb03708d
--- /dev/null
+++ b/actions/redirect.php
@@ -0,0 +1,71 @@
+<?php
+/**
+ * StatusNet, the distributed open-source microblogging tool
+ *
+ * Site access administration panel
+ *
+ * PHP version 5
+ *
+ * LICENCE: This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ * @category Action
+ * @package StatusNet
+ * @author Craig Andrews <candrews@integralblue.com>
+ * @copyright 2010 StatusNet, Inc.
+ * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
+ * @link http://status.net/
+ */
+
+if (!defined('STATUSNET')) {
+ exit(1);
+}
+
+/**
+ * Administer site access settings
+ *
+ * @category Action
+ * @package StatusNet
+ * @author Craig Andrews <candrews@integralblue.com>
+ * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
+ * @link http://status.net/
+ */
+
+class RedirectAction extends Action
+{
+ /**
+ * These pages are read-only.
+ *
+ * @param array $args unused.
+ *
+ * @return boolean read-only flag (false)
+ */
+
+ function isReadOnly($args)
+ {
+ return true;
+ }
+
+ /**
+ * Handle a request
+ *
+ * @param array $args array of arguments
+ *
+ * @return nothing
+ */
+ function handle($args)
+ {
+ common_redirect(common_local_url($this->arg('nextAction'), $this->arg('args')));
+ }
+}
+
diff --git a/doc-src/api b/doc-src/api
new file mode 100644
index 000000000..5c8815bdd
--- /dev/null
+++ b/doc-src/api
@@ -0,0 +1,6 @@
+<!-- Copyright 2008-2010 StatusNet Inc. and contributors. -->
+<!-- Document licensed under Creative Commons Attribution 3.0 Unported. See -->
+<!-- http://creativecommons.org/licenses/by/3.0/ for details. -->
+
+%%site.name%% provides an API that applications can use to interact with it.
+More information about this API can be found on the [StatusNet Wiki](http://status.net/wiki/API).
diff --git a/doc-src/help b/doc-src/help
index 024d47378..6d12b4cd7 100644
--- a/doc-src/help
+++ b/doc-src/help
@@ -35,3 +35,4 @@ Here are some documents that you might find helpful in understanding
* [Source](%%doc.source%%) - How to get the StatusNet source code
* [Badge](%%doc.badge%%) - How to put a StatusNet badge on your blog or homepage
* [Bookmarklet](%%doc.bookmarklet%%) - Bookmarklet for posting Web pages
+* [API](%%doc.api%%) - API for use by external clients
diff --git a/lib/router.php b/lib/router.php
index eebe2beea..54d3d0f68 100644
--- a/lib/router.php
+++ b/lib/router.php
@@ -322,6 +322,11 @@ class Router
// statuses API
+ $m->connect('api',
+ array('action' => 'Redirect',
+ 'nextAction' => 'doc',
+ 'args' => array('title' => 'api')));
+
$m->connect('api/statuses/public_timeline.:format',
array('action' => 'ApiTimelinePublic',
'format' => '(xml|json|rss|atom)'));