Starts the user (profile) endpoint and lays groundwork for inbox and feed endpoint

This commit is contained in:
Jessica Tallon
2013-07-29 21:53:08 +01:00
committed by Jessica Tallon
parent 637b966ac2
commit d7b3805f2d
5 changed files with 111 additions and 2 deletions

View File

View File

@@ -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"
)

View File

@@ -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")