forked from mikeknapp/AppEngine-OAuth-Library
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathsample.py
executable file
·80 lines (63 loc) · 2.93 KB
/
sample.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#!/usr/bin/env python
#
# This is an sample AppEngine application that shows how to 1) log in a user
# using the Twitter OAuth API and 2) extract their timeline.
#
# INSTRUCTIONS:
#
# 1. Set up a new AppEngine application using this file, let's say on port
# 8080. Rename this file to main.py, or alternatively modify your app.yaml
# file.)
# 2. Fill in the application ("consumer") key and secret lines below.
# 3. Visit http://localhost:8080 and click the "login" link to be redirected
# to Twitter.com.
# 4. Once verified, you'll be redirected back to your app on localhost and
# you'll see some of your Twitter user info printed in the browser.
# 5. Copy and paste the token and secret info into this file, replacing the
# default values for user_token and user_secret. You'll need the user's token
# & secret info to interact with the Twitter API on their behalf from now on.
# 6. Finally, visit http://localhost:8080/timeline to see your twitter
# timeline.
#
__author__ = "Mike Knapp"
import oauth
from google.appengine.ext import webapp
from google.appengine.ext.webapp import util
class MainHandler(webapp.RequestHandler):
def get(self, mode=""):
# Your application Twitter application ("consumer") key and secret.
# You'll need to register an application on Twitter first to get this
# information: http://www.twitter.com/oauth
application_key = "FILL_IN"
application_secret = "FILL_IN"
# Fill in the next 2 lines after you have successfully logged in to
# Twitter per the instructions above. This is the *user's* token and
# secret. You need these values to call the API on their behalf after
# they have logged in to your app.
user_token = "FILL_IN"
user_secret = "FILL_IN"
# In the real world, you'd want to edit this callback URL to point to your
# production server. This is where the user is sent to after they have
# authenticated with Twitter.
callback_url = "%s/verify" % self.request.host_url
client = oauth.TwitterClient(application_key, application_secret,
callback_url)
if mode == "login":
return self.redirect(client.get_authorization_url())
if mode == "verify":
auth_token = self.request.get("oauth_token")
auth_verifier = self.request.get("oauth_verifier")
user_info = client.get_user_info(auth_token, auth_verifier=auth_verifier)
return self.response.out.write(user_info)
if mode == "timeline":
timeline_url = "http://twitter.com/statuses/user_timeline.xml"
result = client.make_request(url=timeline_url, token=user_token,
secret=user_secret)
return self.response.out.write(result.content)
self.response.out.write("<a href='/login'>Login via Twitter</a>")
def main():
application = webapp.WSGIApplication([('/(.*)', MainHandler)],
debug=True)
util.run_wsgi_app(application)
if __name__ == '__main__':
main()