views.py 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546
  1. # Django
  2. from django.shortcuts import render
  3. from django.contrib.auth import logout
  4. from django.template import RequestContext, loader
  5. from django.contrib.auth import authenticate, login
  6. from django.http import HttpResponse, HttpResponseRedirect
  7. from django.conf import settings
  8. from django.contrib.auth import authenticate, login, logout
  9. from django.contrib.auth.models import User
  10. from django.contrib.auth.decorators import login_required
  11. from django.views.decorators.csrf import csrf_exempt
  12. from django.http import JsonResponse
  13. # Scripts
  14. from scripts.steam import gamespulling, steamidpulling
  15. from scripts.github import *
  16. from scripts.tumblr import TumblrOauthClient
  17. from scripts.twilioapi import *
  18. from scripts.instagram import *
  19. from scripts.scraper import steamDiscounts
  20. from scripts.quandl import *
  21. from scripts.twitter import TwitterOauthClient
  22. from scripts.nytimes import *
  23. from scripts.meetup import *
  24. from scripts.linkedin import LinkedInAPI
  25. from scripts.yelp import requestData
  26. # Python
  27. import oauth2 as oauth
  28. import simplejson as json
  29. from rest_framework.renderers import JSONRenderer
  30. from rest_framework.parsers import JSONParser
  31. # Models
  32. from hackathon.models import Snippet, Profile, InstagramProfile, TwitterProfile, MeetupToken
  33. from hackathon.serializers import SnippetSerializer
  34. from hackathon.forms import UserForm
  35. profile_track = None
  36. getTumblr = TumblrOauthClient(settings.TUMBLR_CONSUMER_KEY, settings.TUMBLR_CONSUMER_SECRET)
  37. getInstagram = InstagramOauthClient(settings.INSTAGRAM_CLIENT_ID, settings.INSTAGRAM_CLIENT_SECRET)
  38. getTwitter = TwitterOauthClient(settings.TWITTER_CONSUMER_KEY, settings.TWITTER_CONSUMER_SECRET, settings.TWITTER_ACCESS_TOKEN, settings.TWITTER_ACCESS_TOKEN_SECRET)
  39. getLinkedIn= LinkedInAPI(settings.LINKEDIN_API_KEY,settings.LINKEDIN_SECRET_KEY,settings.LINKEDIN_USER_TOKEN,settings.LINKEDIN_USER_SECRET)
  40. getGithub = GithubOauthClient('2a11ce63ea7952d21f02', '7e20f82a34698fb33fc837186e96b12aaca2618d')
  41. def index(request):
  42. print "index: " + str(request.user)
  43. if not request.user.is_active:
  44. if request.GET.items():
  45. if profile_track == 'github':
  46. code = request.GET['code']
  47. getGithub.get_access_token(code)
  48. print getGithub.access_token
  49. elif 'oauth_verifier' in request.GET.keys():
  50. oauth_verifier = request.GET['oauth_verifier']
  51. getTwitter.get_access_token_url(oauth_verifier)
  52. try:
  53. user = User.objects.get(username = getTwitter.username + '_twitter')#(username=getTwitter.username)
  54. except User.DoesNotExist:
  55. username = getTwitter.username + '_twitter'
  56. new_user = User.objects.create_user(username, username+'@madewithtwitter.com', 'password')
  57. new_user.save()
  58. profile = TwitterProfile(user = new_user,oauth_token = getTwitter.oauth_token, oauth_token_secret= getTwitter.oauth_token_secret, twitter_user=getTwitter.username)
  59. profile.save()
  60. user = authenticate(username=getTwitter.username+'_twitter', password='password')
  61. login(request, user)
  62. elif 'code' in request.GET.keys():
  63. code = request.GET['code']
  64. getInstagram.get_access_token(code)
  65. try:
  66. user = User.objects.get(username=getInstagram.user_data['username']+'_instagram')
  67. except User.DoesNotExist:
  68. username = getInstagram.user_data['username']+'_instagram'
  69. new_user = User.objects.create_user(username, username+'@madewithinstagram.com', 'password')
  70. new_user.save()
  71. profile = InstagramProfile(user = new_user, access_token = getInstagram.access_token, instagram_user=getInstagram.user_data['username'])
  72. profile.save()
  73. user = authenticate(username=getInstagram.user_data['username']+'_instagram' , password='password')
  74. login(request, user)
  75. else:
  76. if request.GET.items():
  77. if 'oauth_verifier' in request.GET.keys():
  78. oauth_verifier = request.GET['oauth_verifier']
  79. getTwitter.get_access_token_url(oauth_verifier)
  80. user = User.objects.get(username = request.user.username)
  81. try:
  82. twitterUser = TwitterProfile.objects.get(user = user.id)
  83. except TwitterProfile.DoesNotExist:
  84. profile = TwitterProfile(user = user, oauth_token = getTwitter.oauth_token, oauth_token_secret= getTwitter.oauth_token_secret, twitter_user=getTwitter.username)
  85. profile.save()
  86. elif 'code' in request.GET.keys():
  87. code = request.GET['code']
  88. getInstagram.get_access_token(code)
  89. user = User.objects.get(username = request.user.username)
  90. try:
  91. instagramUser = InstagramProfile.objects.get(user= user.id)
  92. except InstagramProfile.DoesNotExist:
  93. profile = InstagramProfile(user = user, access_token = getInstagram.access_token, instagram_user=getInstagram.user_data['username'])
  94. profile.save()
  95. context = {'hello': 'world'}
  96. return render(request, 'hackathon/index.html', context)
  97. ##################
  98. # API Examples #
  99. ##################
  100. def api_examples(request):
  101. instagram_url =getInstagram.get_authorize_url()
  102. if not getTumblr.accessed:
  103. obtain_oauth_verifier = getTumblr.authorize_url()
  104. else:
  105. obtain_oauth_verifier = '/hackathon/tumblr'
  106. #obtain_oauth_verifier = getTumblr.authorize_url()
  107. context = {'title': 'API Examples Page', 'tumblr_url': obtain_oauth_verifier, 'instagram_url':instagram_url}
  108. return render(request, 'hackathon/api_examples.html', context)
  109. #################
  110. # STEAM API #
  111. #################
  112. def steam(request):
  113. #Should link to test of Steam API example.
  114. key = '231E98D442E52B87110816C3D5114A1D'
  115. SteamUN = "Marorin"
  116. steamID = steamidpulling(SteamUN, key)
  117. game = gamespulling(steamID, key)
  118. return render(request,'hackathon/steam.html', {"game": game })
  119. def steamDiscountedGames(request):
  120. data = steamDiscounts()
  121. return JsonResponse({ 'data': data })
  122. #################
  123. # FACEBOOK API #
  124. #################
  125. def facebook(request):
  126. '''A sample application that will publish a status update after going into the login process using the Javascript SDK '''
  127. yourappid = '364831617044713'
  128. return render(request, 'hackathon/facebook.html', { 'yourappid' : yourappid })
  129. #################
  130. # YELP API #
  131. #################
  132. def yelp(request):
  133. data = {}
  134. if request.method == 'POST':
  135. location = request.POST.get('location')
  136. data = requestData(location)
  137. return render(request, 'hackathon/yelp.html', { 'data': data })
  138. #################
  139. # MEETUP API #
  140. #################
  141. def meetup(request):
  142. REDIRECT_URI = 'http://127.0.0.1:8000/hackathon/meetupToken'
  143. AUTHORIZE_URL = 'https://secure.meetup.com/oauth2/authorize?client_id=' + settings.MEETUP_CONSUMER_KEY + '&response_type=code' + '&redirect_uri=' + REDIRECT_URI
  144. return HttpResponseRedirect(AUTHORIZE_URL)
  145. def meetupToken(request):
  146. # print request.GET.get('code')
  147. access_token_url = 'https://secure.meetup.com/oauth2/access?'
  148. REDIRECT_URI = 'http://127.0.0.1:8000/hackathon/meetupToken'
  149. url = access_token_url + 'client_id=' + settings.MEETUP_CONSUMER_KEY + '&client_secret=' + settings.MEETUP_CONSUMER_SECRET + '&grant_type=authorization_code' + '&redirect_uri=' + REDIRECT_URI + '&code=' + request.GET.get('code')
  150. response = requests.post(url)
  151. access_token = json.loads(response.content)['access_token']
  152. # print access_token
  153. #if not MeetupToken.objects.all()[0]:
  154. if not MeetupToken.objects.all().exists():
  155. meetupToken = MeetupToken(access_token = access_token)
  156. meetupToken.save()
  157. else:
  158. meetupToken = MeetupToken(access_token = access_token)
  159. MeetupToken.objects.all()[0] = meetupToken
  160. return HttpResponseRedirect('http://127.0.0.1:8000/hackathon/meetupUser/')
  161. def meetupUser(request):
  162. if not MeetupToken.objects.all().exists():
  163. return HttpResponseRedirect('http://127.0.0.1:8000/hackathon/meetup')
  164. access_token = MeetupToken.objects.all()[0]
  165. #access_token = MeetupToken.objects.all()[-1]
  166. #print access_token
  167. meetupData = {}
  168. userData = retrieveUserData('https://api.meetup.com/2/member/self/?access_token=' + str(access_token))
  169. meetupData['userData'] = userData
  170. # print 'https://api.meetup.com/dashboard?access_token=' + str(access_token)
  171. #dashboardData = retrieveDashboard('https://api.meetup.com/dashboard?access_token=' + str(access_token))
  172. #meetupData['dashboardData'] = dashboardData
  173. return render(request, 'hackathon/meetup.html', { 'data': meetupData })
  174. #################
  175. # QUANDL API #
  176. #################
  177. def quandlDowJones(request):
  178. '''Returns JSON response about the latest dowjones index.'''
  179. APIKEY = 'fANs6ykrCdAxas7zpMz7'
  180. dowjonesdata = fetchData(APIKEY, 'https://www.quandl.com/api/v1/datasets/BCB/UDJIAD1.json?')
  181. print dowjonesdata
  182. return JsonResponse({'data': dowjonesdata})
  183. def quandlSnp500(request):
  184. '''Returns JSON response about the latest SNP 500 index.'''
  185. APIKEY = 'fANs6ykrCdAxas7zpMz7'
  186. snpdata = fetchData(APIKEY, 'https://www.quandl.com/api/v1/datasets/YAHOO/INDEX_GSPC.json?')
  187. return JsonResponse({'data': snpdata})
  188. def quandlNasdaq(request):
  189. '''Returns JSON response about the latest nasdaq index.'''
  190. APIKEY = 'fANs6ykrCdAxas7zpMz7'
  191. nasdaqdata = fetchData(APIKEY, 'https://www.quandl.com/api/v1/datasets/NASDAQOMX/COMP.json?')
  192. return JsonResponse({'data': nasdaqdata})
  193. def quandlstocks(request):
  194. APIKEY = 'fANs6ykrCdAxas7zpMz7'
  195. everyData = {}
  196. dowjonesdata = fetchData(APIKEY, 'https://www.quandl.com/api/v1/datasets/BCB/UDJIAD1.json?')
  197. everyData['dow'] = dowjonesdata
  198. snpdata = fetchData(APIKEY, 'https://www.quandl.com/api/v1/datasets/YAHOO/INDEX_GSPC.json?')
  199. everyData['snp'] = snpdata
  200. nasdaqdata = fetchData(APIKEY, 'https://www.quandl.com/api/v1/datasets/NASDAQOMX/COMP.json?')
  201. everyData['nasdaq'] = nasdaqdata
  202. return render(request, 'hackathon/quandl.html', { 'everyData': everyData })
  203. #################
  204. # NYTIMES API #
  205. #################
  206. def nytimespop(request):
  207. '''Returns JSON response about the most viewed articles for the last 24 hours.'''
  208. POPAPIKEY = 'be4cd251d8a4f1a3362689088bdb0255:0:71947444'
  209. popdata = fetcharticle(POPAPIKEY, 'http://api.nytimes.com/svc/mostpopular/v2/mostviewed/all-sections/1.json?')
  210. return JSONResponse({'data': popdata})
  211. def nytimestop(request):
  212. '''Returns JSON response about the articles located in the homepage'''
  213. TOPAPIKEY = 'c9655598e1fd4ff591f6d46f2321260e:17:71947444'
  214. topdata = fetcharticle(TOPAPIKEY, 'http://api.nytimes.com/svc/topstories/v1/home.json?')
  215. return JSONResponse({'data': topdata})
  216. def nytimesarticles(request):
  217. POPAPIKEY = 'be4cd251d8a4f1a3362689088bdb0255:0:71947444'
  218. TOPAPIKEY = 'c9655598e1fd4ff591f6d46f2321260e:17:71947444'
  219. everyData = {}
  220. popdata = fetcharticle(POPAPIKEY, 'http://api.nytimes.com/svc/mostpopular/v2/mostviewed/all-sections/1.json?')
  221. topdata = topdata = fetcharticle(TOPAPIKEY, 'http://api.nytimes.com/svc/topstories/v1/home.json?')
  222. everyData['top'] = topdata
  223. everyData['pop'] = popdata
  224. return render(request, 'hackathon/nytimes.html', { 'everyData': everyData })
  225. #################
  226. # GITHUB API #
  227. #################
  228. def githubUser(request):
  229. '''Returns JSON response about a specific Github User'''
  230. parsedData = {}
  231. parsedData['userData'] = getUserData(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  232. return JsonResponse({ 'data': parsedData })
  233. def githubTopRepositories(request):
  234. '''Returns JSON response of a User's Top Committed repositories'''
  235. parsedData = {}
  236. repositories = getUserRepositories(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  237. list = getTopContributedRepositories(repositories, settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  238. filtered = filterCommits(list)
  239. parsedData['committed'] = filtered
  240. return JsonResponse({ 'data': parsedData })
  241. def githubResume(request):
  242. '''A sample application which pulls various Github data to form a Resume of sorts'''
  243. allData = {}
  244. userData = getUserData(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  245. repositories = getUserRepositories(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  246. list = getTopContributedRepositories(repositories, settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  247. filtered = filterCommits(list)
  248. stargazers = getStarGazerCount(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  249. filteredStargazers = filterStarGazerCount(stargazers)
  250. forkedRepos = getForkedRepositories(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  251. allData['userData'] = userData
  252. allData['filteredData'] = filtered
  253. allData['filteredStargazers'] = filteredStargazers
  254. allData['forkedRepos'] = forkedRepos
  255. return render(request, 'hackathon/github.html', { 'data': allData })
  256. #################
  257. # TUMBLR API #
  258. #################
  259. def tumblr(request):
  260. ''' Tumblr api calls '''
  261. if not getTumblr.accessed:
  262. oauth_verifier = request.GET.get('oauth_verifier')
  263. getTumblr.access_token_url(oauth_verifier)
  264. if request.user not in User.objects.all():
  265. try:
  266. user_info, total_blog = getTumblr.getUserInfo()
  267. username = str(user_info['name'])+ "2"
  268. user = User.objects.get(username=username)
  269. except User.DoesNotExist:
  270. user_info, total_blog = getTumblr.getUserInfo()
  271. username = str(user_info['name'])+ "2"
  272. new_user = User.objects.create_user(username, username+'@tumblr.com','password')
  273. new_user.save()
  274. profile =Profile()
  275. profile.user = new_user
  276. profile.oauth_token = getTumblr.oauth_token
  277. profile.oauth_secret = getTumblr.oauth_token_secret
  278. profile.save()
  279. user = authenticate(username=username, password='password')
  280. login(request, user)
  281. #get blogger twitterthecomic's blog information
  282. blog = getTumblr.getBlogInfo('twitterthecomic')
  283. #get tags that was tagged along starbucks
  284. tagged_blog = getTumblr.getTaggedInfo("starbucks")
  285. #get blog information tagged with starbucks
  286. blogontag = getTumblr.getTaggedBlog("starbucks")
  287. context = {'title': "What's up Starbucks?", 'blogData': blog, 'blogTag': tagged_blog, 'blogontag': blogontag}
  288. return render(request, 'hackathon/tumblr.html', context)
  289. ####################
  290. # INSTAGRAM API #
  291. ####################
  292. def instagram(request):
  293. #print getInstagram.is_authorized
  294. if getInstagram.is_authorized:
  295. search_tag = 'kitten'
  296. #return tagged objects
  297. instagramUser = InstagramProfile.objects.get(user=request.user)
  298. tagged_media = getTaggedMedia(search_tag, instagramUser.access_token)
  299. else:
  300. instagram_url =getInstagram.get_authorize_url()
  301. return HttpResponseRedirect(instagram_url)
  302. context = {'title': 'Instagram', 'tagged_media': tagged_media, 'search_tag': search_tag}
  303. return render(request, 'hackathon/instagram.html', context)
  304. def instagramUser(request):
  305. ''' Returns JSON response about a specific Instagram User. '''
  306. access_token = InstagramProfile.objects.get(instagram_user='mk200789').access_token
  307. parsedData = getUserInfo(access_token)
  308. return JsonResponse({ 'data': parsedData })
  309. def instagramUserMedia(request):
  310. ''' Returns JSON response about a specific Instagram User's Media. '''
  311. access_token = InstagramProfile.objects.get(instagram_user='mk200789').access_token
  312. parsedData = getUserMedia(32833691, access_token)
  313. return JsonResponse({'data': parsedData })
  314. def instagramMediaByLocation(request):
  315. print request.user
  316. if request.method == 'GET':
  317. if request.GET.items():
  318. #check if user has a User profile
  319. if request.user in User.objects.all():
  320. #check if user has an Instagram profile
  321. user = User.objects.get(username=request.user)
  322. #if user has an Instagram profile, query the search
  323. if InstagramProfile.objects.all().filter(user=user.id):
  324. address = request.GET.get('address_field')
  325. access_token = InstagramProfile.objects.get(user=user.id).access_token
  326. geocode_result = searchForLocation(address)
  327. if geocode_result:
  328. location_ids = searchLocationIds(geocode_result['lat'], geocode_result['lng'], access_token)
  329. media = searchLocationMedia(location_ids, access_token)
  330. title = address
  331. err_msg = ''
  332. else:
  333. title, media, err_msg, location_ids, geocode_result = 'Media by location','', str(request.user)+ ' does not have an InstagramProfile','', ''
  334. else:
  335. title, media, err_msg, location_ids, geocode_result = 'Media by location', '','', '', ''
  336. context = {'title': title, 'geocode_result':geocode_result, 'media':media, 'list_id':location_ids, 'err_msg': err_msg}
  337. return render(request, 'hackathon/instagram_q.html', context)
  338. ####################
  339. # TWITTER API #
  340. ####################
  341. def twitter(request):
  342. if getTwitter.is_authorized:
  343. value = getTwitter.get_trends_available(settings.YAHOO_CONSUMER_KEY)
  344. else:
  345. tumblr_url = getTwitter.get_authorize_url()
  346. return HttpResponseRedirect(tumblr_url)
  347. context ={'title': 'twitter', 'value': value}
  348. return render(request, 'hackathon/twitter.html', context)
  349. def twitterTweets(request):
  350. print getTwitter.is_authorized
  351. if getTwitter.is_authorized:
  352. content = getTwitter.get_tweets()
  353. else:
  354. twitter_url = getTwitter.get_authorize_url()
  355. return HttpResponseRedirect(twitter_url)
  356. context ={'title': 'twitter tweet', 'content': content}
  357. return render(request, 'hackathon/twitter_tweet.html', context)
  358. ##################
  359. # LINKED IN API #
  360. ##################
  361. def linkedin(request):
  362. linkedin_url = getLinkedIn.get_authorize_url()
  363. return HttpResponseRedirect(linkedin_url)
  364. context = {'title': 'linkedin Example','userdata': userinfo}
  365. return render(request, 'hackathon/linkedin.html', context)
  366. #########################
  367. # Snippet RESTful Model #
  368. #########################
  369. class JSONResponse(HttpResponse):
  370. """
  371. An HttpResponse that renders its content into JSON.
  372. """
  373. def __init__(self, data, **kwargs):
  374. content = JSONRenderer().render(data)
  375. kwargs['content_type'] = 'application/json'
  376. super(JSONResponse, self).__init__(content, **kwargs)
  377. @csrf_exempt
  378. def snippet_list(request):
  379. """
  380. List all code snippets, or create a new snippet.
  381. """
  382. if request.method == 'GET':
  383. snippets = Snippet.objects.all()
  384. serializer = SnippetSerializer(snippets, many=True)
  385. return JSONResponse(serializer.data)
  386. ##################
  387. # Twilio API #
  388. ##################
  389. def twilio(request):
  390. # Test credentials
  391. # sendSMS('Meow', '+13473282978', '+13473781813')
  392. if request.method == 'POST':
  393. number = request.POST.get('number')
  394. message = request.POST.get('message')
  395. sendSMS(str(message), str(number), '+13473781813')
  396. context = {'message': 'Your message has been sent successfully!'}
  397. return HttpResponseRedirect('/hackathon/api/')
  398. return render(request, 'hackathon/twilio.html')
  399. ######################
  400. # Registration Views #
  401. ######################
  402. def register(request):
  403. registered = False
  404. if request.method == 'POST':
  405. user_form = UserForm(data=request.POST)
  406. if user_form.is_valid():
  407. user = user_form.save()
  408. user.set_password(user.password)
  409. user.save()
  410. registered = True
  411. else:
  412. print user_form.errors
  413. else:
  414. user_form = UserForm()
  415. return render(request,
  416. 'hackathon/register.html',
  417. {'user_form': user_form, 'registered': registered} )
  418. def user_login(request):
  419. if request.method == 'POST':
  420. username = request.POST.get('username')
  421. password = request.POST.get('password')
  422. user = authenticate(username=username, password=password)
  423. if user:
  424. if user.is_active:
  425. login(request, user)
  426. return HttpResponseRedirect('/hackathon/')
  427. else:
  428. return HttpResponse("Your Django Hackathon account is disabled.")
  429. else:
  430. print "Invalid login details: {0}, {1}".format(username, password)
  431. return HttpResponse("Invalid login details supplied.")
  432. else:
  433. return render(request, 'hackathon/login.html', {})
  434. def user_logout(request):
  435. logout(request)
  436. return HttpResponseRedirect('/hackathon/')
  437. def instagram_login(request):
  438. instagram_url = getInstagram.get_authorize_url()
  439. return HttpResponseRedirect(instagram_url)
  440. def tumblr_login(request):
  441. tumblr_url = getTumblr.authorize_url()
  442. return HttpResponseRedirect(tumblr_url)
  443. def twitter_login(request):
  444. twitter_url = getTwitter.get_authorize_url()
  445. return HttpResponseRedirect(twitter_url)
  446. def github_login(request):
  447. github_url = getGithub.get_authorize_url()
  448. global profile_track
  449. profile_track = 'github'
  450. return HttpResponseRedirect(github_url)