views.py 35 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831
  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. # Django REST Framework
  14. from rest_framework import viewsets, mixins
  15. # Scripts
  16. from scripts.steam import gamespulling, steamidpulling
  17. from scripts.github import *
  18. from scripts.tumblr import TumblrOauthClient
  19. from scripts.twilioapi import *
  20. from scripts.instagram import *
  21. from scripts.scraper import steamDiscounts
  22. from scripts.quandl import *
  23. from scripts.twitter import TwitterOauthClient
  24. from scripts.nytimes import *
  25. from scripts.meetup import *
  26. from scripts.linkedin import LinkedinOauthClient
  27. from scripts.yelp import requestData
  28. from scripts.facebook import *
  29. from scripts.googlePlus import *
  30. from scripts.dropbox import *
  31. from scripts.foursquare import *
  32. # Python
  33. import oauth2 as oauth
  34. import simplejson as json
  35. import requests
  36. # Models
  37. from hackathon.models import *
  38. from hackathon.serializers import SnippetSerializer
  39. from hackathon.forms import UserForm
  40. profile_track = None
  41. getTumblr = TumblrOauthClient(settings.TUMBLR_CONSUMER_KEY, settings.TUMBLR_CONSUMER_SECRET)
  42. getInstagram = InstagramOauthClient(settings.INSTAGRAM_CLIENT_ID, settings.INSTAGRAM_CLIENT_SECRET)
  43. getTwitter = TwitterOauthClient(settings.TWITTER_CONSUMER_KEY, settings.TWITTER_CONSUMER_SECRET, settings.TWITTER_ACCESS_TOKEN, settings.TWITTER_ACCESS_TOKEN_SECRET)
  44. getGithub = GithubOauthClient('2a11ce63ea7952d21f02', '7e20f82a34698fb33fc837186e96b12aaca2618d')
  45. getLinkedIn = LinkedinOauthClient(settings.LINKEDIN_CLIENT_ID, settings.LINKEDIN_CLIENT_SECRET)
  46. getFacebook = FacebookOauthClient(settings.FACEBOOK_APP_ID, settings.FACEBOOK_APP_SECRET)
  47. getGoogle = GooglePlus(settings.GOOGLE_PLUS_APP_ID, settings.GOOGLE_PLUS_APP_SECRET)
  48. getDropbox = DropboxOauthClient(settings.DROPBOX_APP_ID, settings.DROPBOX_APP_SECRET)
  49. getFoursquare = FoursquareOauthClient(settings.FOURSQUARE_APP_ID, settings.FOURSQUARE_APP_SECRET)
  50. def index(request):
  51. print "index: " + str(request.user)
  52. if not request.user.is_active:
  53. if request.GET.items():
  54. if profile_track == 'github':
  55. code = request.GET['code']
  56. getGithub.get_access_token(code)
  57. getGithub.getUserInfo()
  58. print getGithub.access_token
  59. try:
  60. user = User.objects.get(username = getGithub.username + '_github')
  61. except User.DoesNotExist:
  62. username = getGithub.username + '_github'
  63. new_user = User.objects.create_user(username, username+'@madewithgithub.com', 'password')
  64. new_user.save()
  65. try:
  66. profile = GithubProfile.objects.get(user = new_user.id)
  67. profile.access_token = getGithub.access_token
  68. except GithubProfile.DoesNotExist:
  69. profile = GithubProfile(user=new_user, access_token=getGithub.access_token, scopes=getGithub.scopes ,github_user=getGithub.username)
  70. profile.save()
  71. user = authenticate(username=getGithub.username+'_github', password='password')
  72. login(request, user)
  73. elif profile_track == 'twitter':
  74. oauth_verifier = request.GET['oauth_verifier']
  75. getTwitter.get_access_token_url(oauth_verifier)
  76. try:
  77. user = User.objects.get(username = getTwitter.username + '_twitter')#(username=getTwitter.username)
  78. except User.DoesNotExist:
  79. username = getTwitter.username + '_twitter'
  80. new_user = User.objects.create_user(username, username+'@madewithtwitter.com', 'password')
  81. new_user.save()
  82. profile = TwitterProfile(user = new_user,oauth_token = getTwitter.oauth_token, oauth_token_secret= getTwitter.oauth_token_secret, twitter_user=getTwitter.username)
  83. profile.save()
  84. user = authenticate(username=getTwitter.username+'_twitter', password='password')
  85. login(request, user)
  86. elif profile_track == 'instagram':
  87. code = request.GET['code']
  88. getInstagram.get_access_token(code)
  89. try:
  90. user = User.objects.get(username=getInstagram.user_data['username']+'_instagram')
  91. except User.DoesNotExist:
  92. username = getInstagram.user_data['username']+'_instagram'
  93. new_user = User.objects.create_user(username, username+'@madewithinstagram.com', 'password')
  94. new_user.save()
  95. profile = InstagramProfile(user = new_user, access_token = getInstagram.access_token, instagram_user=getInstagram.user_data['username'])
  96. profile.save()
  97. user = authenticate(username=getInstagram.user_data['username']+'_instagram' , password='password')
  98. login(request, user)
  99. elif profile_track == 'linkedin':
  100. code = request.GET['code']
  101. getLinkedIn.get_access_token(code)
  102. getLinkedIn.getUserInfo()
  103. try:
  104. user = User.objects.get(username=getLinkedIn.user_id+'_linkedin')
  105. except User.DoesNotExist:
  106. username = getLinkedIn.user_id+'_linkedin'
  107. new_user = User.objects.create_user(username, username+'@madwithlinkedin.com', 'password')
  108. new_user.save()
  109. try:
  110. profile =LinkedinProfile.objects.get(user = new_user.id)
  111. profile.access_token = LinkedinProfile.access_token
  112. except LinkedinProfile.DoesNotExist:
  113. profile = LinkedinProfile(user=new_user, access_token=getLinkedIn.access_token, linkedin_user=getLinkedIn.user_id)
  114. profile.save()
  115. user = authenticate(username=getLinkedIn.user_id+'_linkedin', password='password')
  116. login(request, user)
  117. elif profile_track == 'facebook':
  118. code = request.GET['code']
  119. getFacebook.get_access_token(code)
  120. userInfo = getFacebook.get_user_info()
  121. username = userInfo['first_name'] + userInfo['last_name']
  122. try:
  123. user = User.objects.get(username=username+'_facebook')
  124. except User.DoesNotExist:
  125. new_user = User.objects.create_user(username+'_facebook', username+'@madewithfacbook', 'password')
  126. new_user.save()
  127. try:
  128. profile = FacebookProfile.objects.get(user=new_user.id)
  129. profile.access_token = getFacebook.access_token
  130. except:
  131. profile = FacebookProfile()
  132. profile.user = new_user
  133. profile.fb_user_id = userInfo['id']
  134. profile.profile_url = userInfo['link']
  135. profile.access_token = getFacebook.access_token
  136. profile.save()
  137. user = authenticate(username=username+'_facebook', password='password')
  138. login(request, user)
  139. elif profile_track == 'tumblr':
  140. if not getTumblr.is_authorized:
  141. oauth_verifier = request.GET['oauth_verifier']
  142. getTumblr.access_token_url(oauth_verifier)
  143. getTumblr.getUserInfo()
  144. try:
  145. user = User.objects.get(username = getTumblr.username + '_tumblr')
  146. except User.DoesNotExist:
  147. username = getTumblr.username + '_tumblr'
  148. new_user = User.objects.create_user(username, username+'@madewithtumblr.com', 'password')
  149. new_user.save()
  150. try:
  151. profile =TumblrProfile.objects.get(user = new_user.id)
  152. profile.access_token = getTumblr.access_token['oauth_token']
  153. profile.access_token_secret = getTumblr.access_token['oauth_token_secret']
  154. except TumblrProfile.DoesNotExist:
  155. profile = TumblrProfile(user=new_user, access_token=getTumblr.access_token['oauth_token'], access_token_secret= getTumblr.access_token['oauth_token_secret'], tumblr_user=getTumblr.username)
  156. profile.save()
  157. user = authenticate(username=getTumblr.username+'_tumblr', password='password')
  158. login(request, user)
  159. elif profile_track == 'google':
  160. code = request.GET['code']
  161. state = request.GET['state']
  162. getGoogle.get_access_token(code, state)
  163. userInfo = getGoogle.get_user_info()
  164. username = userInfo['given_name'] + userInfo['family_name']
  165. try:
  166. user = User.objects.get(username=username+'_google')
  167. except User.DoesNotExist:
  168. new_user = User.objects.create_user(username+'_google', username+'@madewithgoogleplus', 'password')
  169. new_user.save()
  170. try:
  171. profle = GoogleProfile.objects.get(user = new_user.id)
  172. profile.access_token = getGoogle.access_token
  173. except:
  174. profile = GoogleProfile()
  175. profile.user = new_user
  176. profile.google_user_id = userInfo['id']
  177. profile.access_token = getGoogle.access_token
  178. profile.profile_url = userInfo['link']
  179. profile.save()
  180. user = authenticate(username=username+'_google', password='password')
  181. login(request, user)
  182. elif profile_track == 'dropbox':
  183. code = request.GET['code']
  184. state = request.GET['state']
  185. getDropbox.get_access_token(code, state)
  186. userInfo = getDropbox.get_user_info()
  187. username = userInfo['name_details']['given_name'] + userInfo['name_details']['surname']
  188. try:
  189. user = User.objects.get(username=username+'_dropbox')
  190. except User.DoesNotExist:
  191. new_user = User.objects.create_user(username+'_dropbox', username+'@madewithdropbox', 'password')
  192. new_user.save()
  193. try:
  194. profile = DropboxProfile.objects.get(user=new_user.id)
  195. profile.access_token = getDropbox.access_token
  196. except:
  197. profile = DropboxProfile()
  198. profile.user = new_user
  199. profile.access_token = getDropbox.access_token
  200. profile.dropbox_user_id = userInfo['uid']
  201. profile.save()
  202. user = authenticate(username=username+'_dropbox', password='password')
  203. login(request, user)
  204. elif profile_track == 'foursquare':
  205. code = request.GET['code']
  206. getFoursquare.get_access_token(code)
  207. userInfo = getFoursquare.get_user_info()
  208. username = userInfo['firstName'] + userInfo['lastName']
  209. try:
  210. user = User.objects.get(username=username+'_foursquare')
  211. except User.DoesNotExist:
  212. new_user = User.objects.create_user(username+'_foursquare', username+'@madewithfoursquare', 'password')
  213. new_user.save()
  214. try:
  215. profile = FoursquareProfile.object.get(user=new_user.id)
  216. profile.access_token = getFoursquare.access_token
  217. except:
  218. profile = FoursquareProfile()
  219. profile.user = new_user
  220. profile.foursquare_id = userInfo['id']
  221. profile.access_token = getFoursquare.access_token
  222. profile.save()
  223. user = authenticate(username=username+'_foursquare', password='password')
  224. login(request, user)
  225. else:
  226. if request.GET.items():
  227. user = User.objects.get(username = request.user.username)
  228. if profile_track == 'github':
  229. code = request.GET['code']
  230. getGithub.get_access_token(code)
  231. getGithub.getUserInfo()
  232. try:
  233. githubUser = GithubProfile.objects.get(user=user.id)
  234. except GithubProfile.DoesNotExist:
  235. profile = GithubProfile(user=new_user, access_token=getGithub.access_token, scopes=getGithub.scopes ,github_user=getGithub.username)
  236. profile.save()
  237. elif profile_track == 'twitter':
  238. oauth_verifier = request.GET['oauth_verifier']
  239. getTwitter.get_access_token_url(oauth_verifier)
  240. try:
  241. twitterUser = TwitterProfile.objects.get(user = user.id)
  242. except TwitterProfile.DoesNotExist:
  243. profile = TwitterProfile(user = user, oauth_token = getTwitter.oauth_token, oauth_token_secret= getTwitter.oauth_token_secret, twitter_user=getTwitter.username)
  244. profile.save()
  245. elif profile_track == 'instagram':
  246. code = request.GET['code']
  247. getInstagram.get_access_token(code)
  248. try:
  249. instagramUser = InstagramProfile.objects.get(user= user.id)
  250. except InstagramProfile.DoesNotExist:
  251. profile = InstagramProfile(user = user, access_token = getInstagram.access_token, instagram_user=getInstagram.user_data['username'])
  252. profile.save()
  253. elif profile_track == 'linkedin':
  254. code = request.GET['code']
  255. getLinkedIn.get_access_token(code)
  256. getLinkedIn.getUserInfo()
  257. try:
  258. linkedinUser = LinkedinProfile.objects.get(user=user.id)
  259. except LinkedinProfile.DoesNotExist:
  260. profile = LinkedinProfile(user = user, access_token = getLinkedIn.access_token, linkedin_user=getLinkedIn.user_id)
  261. profile.save()
  262. elif profile_track == 'tumblr':
  263. if not getTumblr.is_authorized:
  264. oauth_verifier = request.GET['oauth_verifier']
  265. getTumblr.access_token_url(oauth_verifier)
  266. getTumblr.getUserInfo()
  267. try:
  268. tumblrUser = TumblrProfile.objects.get(user=user.id)
  269. except TumblrProfile.DoesNotExist:
  270. profile = TumblrProfile(user=user, access_token=getTumblr.access_token['oauth_token'], access_token_secret= getTumblr.access_token['oauth_token_secret'], tumblr_user=getTumblr.username)
  271. profile.save()
  272. context = {'hello': 'world'}
  273. return render(request, 'hackathon/index.html', context)
  274. ##################
  275. # API Examples #
  276. ##################
  277. def api_examples(request):
  278. context = {'title': 'API Examples Page'}
  279. return render(request, 'hackathon/api_examples.html', context)
  280. #################
  281. # STEAM API #
  282. #################
  283. def steam(request):
  284. key = '231E98D442E52B87110816C3D5114A1D'
  285. SteamUN = "Marorin"
  286. steamID = steamidpulling(SteamUN, key)
  287. game = gamespulling(steamID, key)
  288. return render(request,'hackathon/steam.html', {"game": game })
  289. def steamDiscountedGames(request):
  290. data = steamDiscounts()
  291. return JsonResponse({ 'data': data })
  292. #################
  293. # FACEBOOK API #
  294. #################
  295. def facebook(request):
  296. '''
  297. This is an example of getting basic user info and display it
  298. '''
  299. userInfo = getFacebook.get_user_info()
  300. return render(request, 'hackathon/facebookAPIExample.html', { 'userInfo' : userInfo})
  301. #################
  302. # GOOGLE API #
  303. #################
  304. def googlePlus(request):
  305. userInfo = getGoogle.get_user_info()
  306. return render(request, 'hackathon/googlePlus.html', {'userInfo' : userInfo})
  307. #################
  308. # DROPBOX API #
  309. #################
  310. def dropbox(request):
  311. userInfo = getDropbox.get_user_info()
  312. return render(request, 'hackathon/dropbox.html', {'userInfo' : userInfo})
  313. def dropboxSearchFile(request):
  314. if request.method == 'POST':
  315. SEARCH_FILE_URL = 'https://api.dropbox.com/1/search/auto/'
  316. requestParams = {'query': request.POST['filename'],
  317. 'file_limit': '1000',
  318. 'include_deleted': True,
  319. 'access_token': getDropbox.access_token}
  320. response = requests.post(SEARCH_FILE_URL, data=requestParams)
  321. if response.status_code!=200:
  322. raise(Exception('Invalid response, response code {c}'.format(c=response.status_code)))
  323. return render(request, 'hackathon/dropboxSearchFile.html', {'data': response.json()})
  324. #######################
  325. # FOURSQUARE API #
  326. #######################
  327. def foursquare(request):
  328. userInfo = getFoursquare.get_user_info()
  329. return render(request, 'hackathon/foursquare.html', {'data' : userInfo})
  330. #################
  331. # YELP API #
  332. #################
  333. def yelp(request):
  334. data = {}
  335. if request.method == 'POST':
  336. location = request.POST.get('location')
  337. data = requestData(location)
  338. return render(request, 'hackathon/yelp.html', { 'data': data })
  339. #################
  340. # MEETUP API #
  341. #################
  342. def meetup(request):
  343. REDIRECT_URI = 'http://127.0.0.1:8000/hackathon/meetupToken'
  344. AUTHORIZE_URL = 'https://secure.meetup.com/oauth2/authorize?client_id=' + settings.MEETUP_CONSUMER_KEY + '&response_type=code' + '&redirect_uri=' + REDIRECT_URI
  345. return HttpResponseRedirect(AUTHORIZE_URL)
  346. def meetupToken(request):
  347. access_token_url = 'https://secure.meetup.com/oauth2/access?'
  348. REDIRECT_URI = 'http://127.0.0.1:8000/hackathon/meetupToken'
  349. 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')
  350. response = requests.post(url)
  351. access_token = json.loads(response.content)['access_token']
  352. if not MeetupToken.objects.all().exists():
  353. meetupToken = MeetupToken(access_token = access_token)
  354. meetupToken.save()
  355. else:
  356. meetupToken = MeetupToken(access_token = access_token)
  357. MeetupToken.objects.all()[0] = meetupToken
  358. return HttpResponseRedirect('http://127.0.0.1:8000/hackathon/meetupUser/')
  359. def meetupUser(request):
  360. if not MeetupToken.objects.all().exists():
  361. return HttpResponseRedirect('http://127.0.0.1:8000/hackathon/meetup')
  362. access_token = MeetupToken.objects.all()[0]
  363. meetupData = {}
  364. userData = retrieveUserData('https://api.meetup.com/2/member/self/?access_token=' + str(access_token))
  365. meetupData['userData'] = userData
  366. return render(request, 'hackathon/meetup.html', { 'data': meetupData })
  367. #################
  368. # QUANDL API #
  369. #################
  370. def quandlDowJones(request):
  371. '''Returns JSON response about the latest dowjones index.'''
  372. dowjonesdata = fetchData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/BCB/UDJIAD1.json?')
  373. print dowjonesdata
  374. return JsonResponse({'data': dowjonesdata})
  375. def quandlSnp500(request):
  376. '''Returns JSON response about the latest SNP 500 index.'''
  377. snpdata = fetchData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/YAHOO/INDEX_GSPC.json?')
  378. return JsonResponse({'data': snpdata})
  379. def quandlNasdaq(request):
  380. '''Returns JSON response about the latest nasdaq index.'''
  381. nasdaqdata = fetchData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/NASDAQOMX/COMP.json?')
  382. return JsonResponse({'data': nasdaqdata})
  383. def quandlapple(request):
  384. '''Returns JSON response about the latest apple stock.'''
  385. appledata = fetchstockData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/GOOG/NASDAQ_AAPL.json')
  386. return JsonResponse({'data': appledata})
  387. def quandlNasdaqdiff(request):
  388. '''Returns JSON response about the latest nasdaq index.'''
  389. nasdaqdata = rdiffData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/NASDAQOMX/COMP.json?')
  390. return JsonResponse({'data': nasdaqdata})
  391. def quandlSnp500diff(request):
  392. '''Returns JSON response about the latest SNP 500 index.'''
  393. snpdata = rdiffData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/YAHOO/INDEX_GSPC.json?')
  394. return JsonResponse({'data': snpdata})
  395. def quandlDowJonesdiff(request):
  396. '''Returns JSON response about the latest dowjones index.'''
  397. dowjonesdata = rdiffData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/BCB/UDJIAD1.json?')
  398. return JsonResponse({'data': dowjonesdata})
  399. def quandlapplediff(request):
  400. '''Returns JSON response about the latest apple stock.'''
  401. appledata = rdiffData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/GOOG/NASDAQ_AAPL.json')
  402. return JsonResponse({'data': appledata})
  403. def quandlstocks(request):
  404. everyData = {}
  405. dowjonesdata = fetchData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/BCB/UDJIAD1.json?')
  406. everyData['dow'] = dowjonesdata
  407. everyData['dowdiff'] = rdiffData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/BCB/UDJIAD1.json?')
  408. snpdata = fetchData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/YAHOO/INDEX_GSPC.json?')
  409. everyData['snp'] = snpdata
  410. everyData['snpdiff'] = rdiffData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/YAHOO/INDEX_GSPC.json?')
  411. nasdaqdata = fetchData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/NASDAQOMX/COMP.json?')
  412. everyData['nasdaq'] = nasdaqdata
  413. everyData['nasdaqdiff'] = rdiffData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/NASDAQOMX/COMP.json?')
  414. everyData['apple'] = fetchstockData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/GOOG/NASDAQ_AAPL.json')
  415. everyData['applediff'] = rdiffData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/GOOG/NASDAQ_AAPL.json')
  416. return render(request, 'hackathon/quandl.html', { 'everyData': everyData })
  417. #################
  418. # NYTIMES API #
  419. #################
  420. def nytimespop(request):
  421. '''Returns JSON response about the most viewed articles for the last 24 hours.'''
  422. popdata = fetcharticle(settings.POPAPIKEY, 'http://api.nytimes.com/svc/mostpopular/v2/mostviewed/all-sections/1.json?')
  423. return JSONResponse({'data': popdata})
  424. def nytimestop(request):
  425. '''Returns JSON response about the articles located in the homepage'''
  426. topdata = fetcharticle(settings.TOPAPIKEY, 'http://api.nytimes.com/svc/topstories/v1/home.json?')
  427. return JSONResponse({'data': topdata})
  428. def nytimesarticles(request):
  429. everyData = {}
  430. popdata = fetcharticle(settings.POPAPIKEY, 'http://api.nytimes.com/svc/mostpopular/v2/mostviewed/all-sections/1.json?')
  431. topdata = topdata = fetcharticle(settings.TOPAPIKEY, 'http://api.nytimes.com/svc/topstories/v1/home.json?')
  432. everyData['top'] = topdata
  433. everyData['pop'] = popdata
  434. return render(request, 'hackathon/nytimes.html', { 'everyData': everyData })
  435. #################
  436. # GITHUB API #
  437. #################
  438. def githubUser(request):
  439. '''Returns Github Profile data for a specific user.'''
  440. parsedData = {}
  441. if request.method == 'POST':
  442. user = request.POST.get('user')
  443. parsedData['userData'] = getUserData(user, settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  444. return render(request, 'hackathon/github.html', {'data': parsedData})
  445. def githubTopRepositories(request):
  446. '''Returns Top Commited Repositories for a specific Github User'''
  447. parsedData = {}
  448. if request.method == 'POST':
  449. user = request.POST.get('user')
  450. repositories = getUserRepositories(user, settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  451. list = getTopContributedRepositories(user, repositories, settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  452. filtered = filterCommits(list)
  453. parsedData['committed'] = filtered
  454. print parsedData
  455. return render(request, 'hackathon/githubTopRepositories.html', {'data': parsedData})
  456. def githubResume(request):
  457. '''A sample application which pulls various Github data to form a Resume of sorts'''
  458. allData = {}
  459. userData = getUserData('DrkSephy', settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  460. repositories = getUserRepositories('DrkSephy', settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  461. list = getTopContributedRepositories('DrkSephy', repositories, settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  462. filtered = filterCommits(list)
  463. stargazers = getStarGazerCount('DrkSephy', settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  464. filteredStargazers = filterStarGazerCount(stargazers)
  465. forkedRepos = getForkedRepositories('DrkSephy', settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  466. allData['userData'] = userData
  467. allData['filteredData'] = filtered
  468. allData['filteredStargazers'] = filteredStargazers
  469. allData['forkedRepos'] = forkedRepos
  470. return render(request, 'hackathon/githubResume.html', { 'data': allData })
  471. #################
  472. # TUMBLR API #
  473. #################
  474. def tumblr(request):
  475. ''' Tumblr api calls '''
  476. if getTumblr.is_authorized:
  477. #get blogger twitterthecomic's blog information
  478. blog = getTumblr.getBlogInfo('twitterthecomic')
  479. #get tags that was tagged along starbucks
  480. tagged_blog = getTumblr.getTaggedInfo("starbucks")
  481. #get blog information tagged with starbucks
  482. blogontag = getTumblr.getTaggedBlog("starbucks")
  483. else:
  484. blog, tagged_blog, blogontag = '', '',''
  485. global profile_track
  486. profile_track = 'tumblr'
  487. tumblr_url = getTumblr.authorize_url()
  488. return HttpResponseRedirect(tumblr_url)
  489. context = {'title': "What's up Starbucks?", 'blogData': blog, 'blogTag': tagged_blog, 'blogontag': blogontag}
  490. return render(request, 'hackathon/tumblr.html', context)
  491. ####################
  492. # INSTAGRAM API #
  493. ####################
  494. def instagram(request):
  495. print getInstagram.is_authorized
  496. if getInstagram.is_authorized:
  497. if request.method == 'GET':
  498. if request.GET.items():
  499. instagram_tag = request.GET.get('instagram_tag')
  500. instagramUser = InstagramProfile.objects.get(user = request.user)
  501. tagged_media = getTaggedMedia(instagram_tag, instagramUser.access_token)
  502. else:
  503. instagram_tag, tagged_media = '', ''
  504. else:
  505. global profile_track
  506. profile_track = 'instagram'
  507. instagram_url =getInstagram.get_authorize_url()
  508. return HttpResponseRedirect(instagram_url)
  509. context = {'title': 'Instagram', 'tagged_media': tagged_media, 'search_tag': instagram_tag}
  510. return render(request, 'hackathon/instagram.html', context)
  511. def instagramUser(request):
  512. ''' Returns JSON response about a specific Instagram User. '''
  513. access_token = InstagramProfile.objects.get(instagram_user='mk200789').access_token
  514. parsedData = getUserInfo(access_token)
  515. return JsonResponse({ 'data': parsedData })
  516. def instagramUserMedia(request):
  517. ''' Returns JSON response about a specific Instagram User's Media. '''
  518. access_token = InstagramProfile.objects.get(instagram_user='mk200789').access_token
  519. parsedData = getUserMedia(32833691, access_token)
  520. return JsonResponse({'data': parsedData })
  521. def instagramMediaByLocation(request):
  522. print request.user
  523. if request.method == 'GET':
  524. if request.GET.items():
  525. #check if user has a User profile
  526. if request.user in User.objects.all():
  527. #check if user has an Instagram profile
  528. user = User.objects.get(username=request.user)
  529. #if user has an Instagram profile, query the search
  530. if InstagramProfile.objects.all().filter(user=user.id):
  531. address = request.GET.get('address_field')
  532. access_token = InstagramProfile.objects.get(user=user.id).access_token
  533. geocode_result = searchForLocation(address)
  534. if geocode_result:
  535. location_ids = searchLocationIds(geocode_result['lat'], geocode_result['lng'], access_token)
  536. media = searchLocationMedia(location_ids, access_token)
  537. title = address
  538. err_msg = ''
  539. else:
  540. title, media, err_msg, location_ids, geocode_result = 'Media by location','', str(request.user)+ ' does not have an InstagramProfile','', ''
  541. else:
  542. title, media, err_msg, location_ids, geocode_result = 'Media by location', '','', '', ''
  543. context = {'title': title, 'geocode_result':geocode_result, 'media':media, 'list_id':location_ids, 'err_msg': err_msg}
  544. return render(request, 'hackathon/instagram_q.html', context)
  545. ####################
  546. # TWITTER API #
  547. ####################
  548. def twitter(request):
  549. if getTwitter.is_authorized:
  550. value = getTwitter.get_trends_available(settings.YAHOO_CONSUMER_KEY)
  551. else:
  552. global profile_track
  553. profile_track = 'twitter'
  554. twitter_url = getTwitter.get_authorize_url()
  555. return HttpResponseRedirect(twitter_url)
  556. context ={'title': 'twitter', 'value': value}
  557. return render(request, 'hackathon/twitter.html', context)
  558. def twitterTweets(request):
  559. print getTwitter.is_authorized
  560. if getTwitter.is_authorized:
  561. if request.method == 'GET':
  562. if request.GET.items():
  563. tweets = request.GET.get('tweets')
  564. content, jsonlist = getTwitter.get_tweets(tweets)
  565. else:
  566. content, jsonlist = '', ''
  567. else:
  568. global profile_track
  569. profile_track = 'twitter'
  570. twitter_url = getTwitter.get_authorize_url()
  571. return HttpResponseRedirect(twitter_url)
  572. context ={'title': 'twitter tweet', 'content': content, 'data': jsonlist}
  573. return render(request, 'hackathon/twitter_tweet.html', context)
  574. ##################
  575. # LINKEDIN API #
  576. ##################
  577. def linkedin(request):
  578. if getLinkedIn.is_authorized:
  579. content = getLinkedIn.getUserInfo()
  580. else:
  581. global profile_track
  582. profile_track = 'linkedin'
  583. linkedin_url = getLinkedIn.get_authorize_url()
  584. return HttpResponseRedirect(linkedin_url)
  585. context = {'title': 'linkedin example', 'content': content}
  586. return render(request, 'hackathon/linkedin.html', context)
  587. #########################
  588. # Snippet RESTful Model #
  589. #########################
  590. class CRUDBaseView(mixins.ListModelMixin,
  591. mixins.CreateModelMixin,
  592. mixins.RetrieveModelMixin,
  593. mixins.UpdateModelMixin,
  594. mixins.DestroyModelMixin,
  595. viewsets.GenericViewSet):
  596. pass
  597. class SnippetView(CRUDBaseView):
  598. serializer_class = SnippetSerializer
  599. queryset = Snippet.objects.all()
  600. ##################
  601. # Twilio API #
  602. ##################
  603. def twilio(request):
  604. if request.method == 'POST':
  605. number = request.POST.get('number')
  606. message = request.POST.get('message')
  607. sendSMS(str(message), str(number), '+13473781813')
  608. context = {'message': 'Your message has been sent successfully!'}
  609. return HttpResponseRedirect('/hackathon/api/')
  610. return render(request, 'hackathon/twilio.html')
  611. ######################
  612. # Registration Views #
  613. ######################
  614. def register(request):
  615. registered = False
  616. if request.method == 'POST':
  617. user_form = UserForm(data=request.POST)
  618. if user_form.is_valid():
  619. user = user_form.save()
  620. user.set_password(user.password)
  621. user.save()
  622. registered = True
  623. else:
  624. print user_form.errors
  625. else:
  626. user_form = UserForm()
  627. return render(request,
  628. 'hackathon/register.html',
  629. {'user_form': user_form, 'registered': registered} )
  630. def user_login(request):
  631. if request.method == 'POST':
  632. username = request.POST.get('username')
  633. password = request.POST.get('password')
  634. user = authenticate(username=username, password=password)
  635. if user:
  636. if user.is_active:
  637. login(request, user)
  638. return HttpResponseRedirect('/hackathon/')
  639. else:
  640. return HttpResponse("Your Django Hackathon account is disabled.")
  641. else:
  642. print "Invalid login details: {0}, {1}".format(username, password)
  643. return HttpResponse("Invalid login details supplied.")
  644. else:
  645. return render(request, 'hackathon/login.html', {})
  646. def user_logout(request):
  647. logout(request)
  648. return HttpResponseRedirect('/hackathon/')
  649. def instagram_login(request):
  650. global profile_track
  651. profile_track = 'instagram'
  652. instagram_url = getInstagram.get_authorize_url()
  653. return HttpResponseRedirect(instagram_url)
  654. def tumblr_login(request):
  655. global profile_track
  656. profile_track = 'tumblr'
  657. tumblr_url = getTumblr.authorize_url()
  658. return HttpResponseRedirect(tumblr_url)
  659. def twitter_login(request):
  660. global profile_track
  661. profile_track = 'twitter'
  662. twitter_url = getTwitter.get_authorize_url()
  663. return HttpResponseRedirect(twitter_url)
  664. def github_login(request):
  665. global profile_track
  666. profile_track = 'github'
  667. github_url = getGithub.get_authorize_url()
  668. return HttpResponseRedirect(github_url)
  669. def linkedin_login(request):
  670. global profile_track
  671. profile_track = 'linkedin'
  672. linkedin_url = getLinkedIn.get_authorize_url()
  673. return HttpResponseRedirect(linkedin_url)
  674. def facebook_login(request):
  675. global profile_track
  676. profile_track = 'facebook'
  677. facebook_url = getFacebook.get_authorize_url()
  678. return HttpResponseRedirect(facebook_url)
  679. def google_login(request):
  680. global profile_track
  681. profile_track = 'google'
  682. google_url = getGoogle.get_authorize_url()
  683. return HttpResponseRedirect(google_url)
  684. def dropbox_login(request):
  685. global profile_track
  686. profile_track = 'dropbox'
  687. dropbox_url = getDropbox.get_authorize_url()
  688. return HttpResponseRedirect(dropbox_url)
  689. def foursquare_login(request):
  690. global profile_track
  691. profile_track = 'foursquare'
  692. forsquare_url = getFoursquare.get_authorize_url()
  693. return HttpResponseRedirect(forsquare_url)