aboutsummaryrefslogtreecommitdiffstats
path: root/mediagoblin/federation
diff options
context:
space:
mode:
authorJessica Tallon <xray7224@googlemail.com>2013-07-29 21:53:08 +0100
committerJessica Tallon <jessica@megworld.co.uk>2014-07-22 23:13:13 +0100
commitd7b3805f2dde435e211560ba6500cc30780739eb (patch)
tree058a7a256eb695caec23b939c51f68ea8e83f5b4 /mediagoblin/federation
parent637b966ac20e448d17b310ccbf29389410d7cdf2 (diff)
downloadmediagoblin-d7b3805f2dde435e211560ba6500cc30780739eb.tar.lz
mediagoblin-d7b3805f2dde435e211560ba6500cc30780739eb.tar.xz
mediagoblin-d7b3805f2dde435e211560ba6500cc30780739eb.zip
Starts the user (profile) endpoint and lays groundwork for inbox and feed endpoint
Diffstat (limited to 'mediagoblin/federation')
-rw-r--r--mediagoblin/federation/__init__.py0
-rw-r--r--mediagoblin/federation/routing.py43
-rw-r--r--mediagoblin/federation/views.py42
3 files changed, 85 insertions, 0 deletions
diff --git a/mediagoblin/federation/__init__.py b/mediagoblin/federation/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/mediagoblin/federation/__init__.py
diff --git a/mediagoblin/federation/routing.py b/mediagoblin/federation/routing.py
new file mode 100644
index 00000000..9c3e0dff
--- /dev/null
+++ b/mediagoblin/federation/routing.py
@@ -0,0 +1,43 @@
+# GNU MediaGoblin -- federated, autonomous media hosting
+# Copyright (C) 2011, 2012 MediaGoblin contributors. See AUTHORS.
+#
+# 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/>.
+
+from mediagoblin.tools.routing import add_route
+
+# Add user profile
+add_route(
+ "mediagoblin.federation.user",
+ "/api/user/<string:username>/",
+ "mediagoblin.federation.views:user"
+ )
+
+add_route(
+ "mediagoblin.federation.profile",
+ "/api/user/<string:username>/profile",
+ "mediagoblin.federation.views:user"
+ )
+
+# Inbox and Outbox (feed)
+add_route(
+ "mediagoblin.federation.feed",
+ "/api/user/<string:username>/feed",
+ "mediagoblin.federation.views:feed"
+ )
+
+add_route(
+ "mediagoblin.federation.inbox",
+ "/api/user/<string:username>/inbox",
+ "mediagoblin.federation.views:inbox"
+ )
diff --git a/mediagoblin/federation/views.py b/mediagoblin/federation/views.py
new file mode 100644
index 00000000..337f28ed
--- /dev/null
+++ b/mediagoblin/federation/views.py
@@ -0,0 +1,42 @@
+from mediagoblin.decorators import oauth_required
+from mediagoblin.db.models import User
+from mediagoblin.tools.response import json_response
+
+@oauth_required
+def user(request):
+ """ Handles user response at /api/user/<username>/ """
+ user = request.matchdict["username"]
+ requested_user = User.query.filter_by(username=user)
+
+ # check if the user exists
+ if requested_user is None:
+ error = "No such 'user' with id '{0}'".format(user)
+ return json_response({"error": error}, status=404)
+
+ user = requested_user[0]
+
+ # user profiles are public so return information
+ return json_response(user.serialize(request))
+
+@oauth_required
+def feed(request):
+ """ Handles the user's outbox - /api/user/<username>/feed """
+ user = request.matchdict["username"]
+ requested_user = User.query.filter_by(username=user)
+
+ # check if the user exists
+ if requested_user is None:
+ error = "No such 'user' with id '{0}'".format(user)
+ return json_response({"error": error}, status=404)
+
+ user = request_user[0]
+
+ # Now lookup the user's feed.
+ raise NotImplemented("Yet to implement looking up user's feed")
+
+@oauth_required
+def inbox(request):
+ """ Handles the user's inbox - /api/user/<username>/inbox """
+ pass
+
+ raise NotImplemented("Yet to implement looking up user's inbox")