Added PuSH capability
This commit is contained in:
parent
0ab21f981a
commit
5b1a7bae3c
@ -50,6 +50,9 @@ allow_attachments = boolean(default=False)
|
|||||||
# Cookie stuff
|
# Cookie stuff
|
||||||
csrf_cookie_name = string(default='mediagoblin_csrftoken')
|
csrf_cookie_name = string(default='mediagoblin_csrftoken')
|
||||||
|
|
||||||
|
# Push stuff
|
||||||
|
push_enabled = boolean(default=True)
|
||||||
|
push_url = string(default='https://pubsubhubbub.appspot.com/')
|
||||||
|
|
||||||
[storage:publicstore]
|
[storage:publicstore]
|
||||||
storage_class = string(default="mediagoblin.storage.filestorage:BasicFileStorage")
|
storage_class = string(default="mediagoblin.storage.filestorage:BasicFileStorage")
|
||||||
|
@ -20,6 +20,7 @@ from os.path import splitext
|
|||||||
from cgi import FieldStorage
|
from cgi import FieldStorage
|
||||||
|
|
||||||
from celery import registry
|
from celery import registry
|
||||||
|
import urllib,urllib2
|
||||||
|
|
||||||
from werkzeug.utils import secure_filename
|
from werkzeug.utils import secure_filename
|
||||||
|
|
||||||
@ -125,6 +126,19 @@ def submit_start(request):
|
|||||||
# re-raise the exception
|
# re-raise the exception
|
||||||
raise
|
raise
|
||||||
|
|
||||||
|
if mg_globals.app_config["push_enabled"]:
|
||||||
|
feed_url=request.urlgen(
|
||||||
|
'mediagoblin.user_pages.atom_feed',
|
||||||
|
qualified=True,user=request.user.username)
|
||||||
|
hubparameters = {
|
||||||
|
'hub.mode': 'publish',
|
||||||
|
'hub.url': feed_url}
|
||||||
|
huburl = mg_globals.app_config["push_url"]
|
||||||
|
hubdata = urllib.urlencode(hubparameters)
|
||||||
|
hubheaders = {"Content-type": "application/x-www-form-urlencoded"}
|
||||||
|
hubrequest = urllib2.Request(huburl, hubdata,hubheaders)
|
||||||
|
hubresponse = urllib2.urlopen(hubrequest)
|
||||||
|
|
||||||
add_message(request, SUCCESS, _('Woohoo! Submitted!'))
|
add_message(request, SUCCESS, _('Woohoo! Submitted!'))
|
||||||
|
|
||||||
return redirect(request, "mediagoblin.user_pages.user_home",
|
return redirect(request, "mediagoblin.user_pages.user_home",
|
||||||
|
@ -228,16 +228,24 @@ def atom_feed(request):
|
|||||||
"""
|
"""
|
||||||
ATOM feed id is a tag URI (see http://en.wikipedia.org/wiki/Tag_URI)
|
ATOM feed id is a tag URI (see http://en.wikipedia.org/wiki/Tag_URI)
|
||||||
"""
|
"""
|
||||||
|
atomlinks = [{
|
||||||
|
'href': request.urlgen(
|
||||||
|
'mediagoblin.user_pages.user_home',
|
||||||
|
qualified=True,user=request.matchdict['user']),
|
||||||
|
'rel': 'alternate',
|
||||||
|
'type': 'text/html'
|
||||||
|
}];
|
||||||
|
if mg_globals.app_config["push_enabled"]:
|
||||||
|
atomlinks.append({
|
||||||
|
'rel': 'hub',
|
||||||
|
'href': mg_globals.app_config["push_url"]})
|
||||||
|
|
||||||
feed = AtomFeed(
|
feed = AtomFeed(
|
||||||
"MediaGoblin: Feed for user '%s'" % request.matchdict['user'],
|
"MediaGoblin: Feed for user '%s'" % request.matchdict['user'],
|
||||||
feed_url=request.url,
|
feed_url=request.url,
|
||||||
id='tag:'+request.host+',2011:gallery.user-'+request.matchdict['user'],
|
id='tag:'+request.host+',2011:gallery.user-'+request.matchdict['user'],
|
||||||
links=[{
|
links=atomlinks)
|
||||||
'href': request.urlgen(
|
|
||||||
'mediagoblin.user_pages.user_home',
|
|
||||||
qualified=True,user=request.matchdict['user']),
|
|
||||||
'rel': 'alternate',
|
|
||||||
'type': 'text/html'}])
|
|
||||||
|
|
||||||
for entry in cursor:
|
for entry in cursor:
|
||||||
feed.add(entry.get('title'),
|
feed.add(entry.get('title'),
|
||||||
|
Loading…
x
Reference in New Issue
Block a user