views.py 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689
  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. import requests
  14. import pdb
  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. # Python
  30. import oauth2 as oauth
  31. import simplejson as json
  32. from rest_framework.renderers import JSONRenderer
  33. from rest_framework.parsers import JSONParser
  34. # Models
  35. from hackathon.models import Snippet, Profile, InstagramProfile, TwitterProfile, MeetupToken, GithubProfile, LinkedinProfile, FacebookProfile
  36. from hackathon.serializers import SnippetSerializer
  37. from hackathon.forms import UserForm
  38. profile_track = None
  39. getTumblr = TumblrOauthClient(settings.TUMBLR_CONSUMER_KEY, settings.TUMBLR_CONSUMER_SECRET)
  40. getInstagram = InstagramOauthClient(settings.INSTAGRAM_CLIENT_ID, settings.INSTAGRAM_CLIENT_SECRET)
  41. getTwitter = TwitterOauthClient(settings.TWITTER_CONSUMER_KEY, settings.TWITTER_CONSUMER_SECRET, settings.TWITTER_ACCESS_TOKEN, settings.TWITTER_ACCESS_TOKEN_SECRET)
  42. getGithub = GithubOauthClient('2a11ce63ea7952d21f02', '7e20f82a34698fb33fc837186e96b12aaca2618d')
  43. getLinkedIn = LinkedinOauthClient(settings.LINKEDIN_CLIENT_ID, settings.LINKEDIN_CLIENT_SECRET)
  44. getFacebook = FacebookOauthClient(settings.FACEBOOK_APP_ID, settings.FACEBOOK_APP_SECRET)
  45. def index(request):
  46. print "index: " + str(request.user)
  47. if not request.user.is_active:
  48. if request.GET.items():
  49. if profile_track == 'github':
  50. code = request.GET['code']
  51. getGithub.get_access_token(code)
  52. getGithub.getUserInfo()
  53. print getGithub.access_token
  54. try:
  55. user = User.objects.get(username = getGithub.username + '_github')
  56. except User.DoesNotExist:
  57. username = getGithub.username + '_github'
  58. new_user = User.objects.create_user(username, username+'@madewithgithub.com', 'password')
  59. new_user.save()
  60. try:
  61. profile = GithubProfile.objects.get(user = new_user.id)
  62. profile.access_token = getGithub.access_token
  63. except GithubProfile.DoesNotExist:
  64. profile = GithubProfile(user=new_user, access_token=getGithub.access_token, scopes=getGithub.scopes ,github_user=getGithub.username)
  65. profile.save()
  66. #profile = GithubProfile(user=new_user, access_token=getGithub.access_token, scopes=getGithub.scopes ,github_user=getGithub.username)
  67. #profile.save()
  68. user = authenticate(username=getGithub.username+'_github', password='password')
  69. login(request, user)
  70. elif profile_track == 'twitter':
  71. oauth_verifier = request.GET['oauth_verifier']
  72. getTwitter.get_access_token_url(oauth_verifier)
  73. try:
  74. user = User.objects.get(username = getTwitter.username + '_twitter')#(username=getTwitter.username)
  75. except User.DoesNotExist:
  76. username = getTwitter.username + '_twitter'
  77. new_user = User.objects.create_user(username, username+'@madewithtwitter.com', 'password')
  78. new_user.save()
  79. profile = TwitterProfile(user = new_user,oauth_token = getTwitter.oauth_token, oauth_token_secret= getTwitter.oauth_token_secret, twitter_user=getTwitter.username)
  80. profile.save()
  81. user = authenticate(username=getTwitter.username+'_twitter', password='password')
  82. login(request, user)
  83. elif profile_track == 'instagram':
  84. code = request.GET['code']
  85. getInstagram.get_access_token(code)
  86. try:
  87. user = User.objects.get(username=getInstagram.user_data['username']+'_instagram')
  88. except User.DoesNotExist:
  89. username = getInstagram.user_data['username']+'_instagram'
  90. new_user = User.objects.create_user(username, username+'@madewithinstagram.com', 'password')
  91. new_user.save()
  92. profile = InstagramProfile(user = new_user, access_token = getInstagram.access_token, instagram_user=getInstagram.user_data['username'])
  93. profile.save()
  94. user = authenticate(username=getInstagram.user_data['username']+'_instagram' , password='password')
  95. login(request, user)
  96. elif profile_track == 'linkedin':
  97. code = request.GET['code']
  98. getLinkedIn.get_access_token(code)
  99. getLinkedIn.getUserInfo()
  100. try:
  101. user = User.objects.get(username=getLinkedIn.user_id+'_linkedin')
  102. except User.DoesNotExist:
  103. username = getLinkedIn.user_id+'_linkedin'
  104. new_user = User.objects.create_user(username, username+'@madwithlinkedin.com', 'password')
  105. new_user.save()
  106. try:
  107. profile =LinkedinProfile.objects.get(user = new_user.id)
  108. profile.access_token = LinkedinProfile.access_token
  109. except LinkedinProfile.DoesNotExist:
  110. profile = LinkedinProfile(user=new_user, access_token=getLinkedIn.access_token, linkedin_user=getLinkedIn.user_id)
  111. profile.save()
  112. user = authenticate(username=getLinkedIn.user_id+'_linkedin', password='password')
  113. login(request, user)
  114. elif profile_track == 'facebook':
  115. code = request.GET['code']
  116. getFacebook.get_access_token(code)
  117. userInfo = getFacebook.get_user_info()
  118. username = userInfo['first_name'] + userInfo['last_name']
  119. try:
  120. user = User.objects.get(username=username+'_facebook')
  121. except User.DoesNotExist:
  122. new_user = User.objects.create_user(username+'_facebook', username+'@madewithfacbook', 'password')
  123. new_user.save()
  124. try:
  125. profile = FacebookProfile.objects.get(user=new_user.id)
  126. profile.access_token = getFacebook.access_token
  127. except:
  128. profile = FacebookProfile()
  129. profile.user = new_user
  130. profile.fb_user_id = userInfo['id']
  131. profile.profile_url = userInfo['link']
  132. profile.access_token = getFacebook.access_token
  133. profile.save()
  134. user = authenticate(username=username+'_facebook', password='password')
  135. login(request, user)
  136. else:
  137. if request.GET.items():
  138. user = User.objects.get(username = request.user.username)
  139. if profile_track == 'github':
  140. code = request.GET['code']
  141. getGithub.get_access_token(code)
  142. getGithub.getUserInfo()
  143. try:
  144. githubUser = GithubProfile.objects.get(user=user.id)
  145. except GithubProfile.DoesNotExist:
  146. profile = GithubProfile(user=new_user, access_token=getGithub.access_token, scopes=getGithub.scopes ,github_user=getGithub.username)
  147. profile.save()
  148. elif profile_track == 'twitter':
  149. oauth_verifier = request.GET['oauth_verifier']
  150. getTwitter.get_access_token_url(oauth_verifier)
  151. try:
  152. twitterUser = TwitterProfile.objects.get(user = user.id)
  153. except TwitterProfile.DoesNotExist:
  154. profile = TwitterProfile(user = user, oauth_token = getTwitter.oauth_token, oauth_token_secret= getTwitter.oauth_token_secret, twitter_user=getTwitter.username)
  155. profile.save()
  156. elif profile_track == 'instagram':
  157. code = request.GET['code']
  158. getInstagram.get_access_token(code)
  159. try:
  160. instagramUser = InstagramProfile.objects.get(user= user.id)
  161. except InstagramProfile.DoesNotExist:
  162. profile = InstagramProfile(user = user, access_token = getInstagram.access_token, instagram_user=getInstagram.user_data['username'])
  163. profile.save()
  164. elif profile_track == 'linkedin':
  165. code = request.GET['code']
  166. getLinkedIn.get_access_token(code)
  167. getLinkedIn.getUserInfo()
  168. try:
  169. linkedinUser = LinkedinProfile.objects.get(user=user.id)
  170. except LinkedinProfile.DoesNotExist:
  171. profile = LinkedinProfile(user = user, access_token = getLinkedIn.access_token, linkedin_user=getLinkedIn.user_id)
  172. profile.save()
  173. context = {'hello': 'world'}
  174. return render(request, 'hackathon/index.html', context)
  175. ##################
  176. # API Examples #
  177. ##################
  178. def api_examples(request):
  179. context = {'title': 'API Examples Page'}
  180. return render(request, 'hackathon/api_examples.html', context)
  181. #################
  182. # STEAM API #
  183. #################
  184. def steam(request):
  185. #Should link to test of Steam API example.
  186. key = '231E98D442E52B87110816C3D5114A1D'
  187. SteamUN = "Marorin"
  188. steamID = steamidpulling(SteamUN, key)
  189. game = gamespulling(steamID, key)
  190. return render(request,'hackathon/steam.html', {"game": game })
  191. def steamDiscountedGames(request):
  192. data = steamDiscounts()
  193. return JsonResponse({ 'data': data })
  194. #################
  195. # FACEBOOK API #
  196. #################
  197. def facebook(request):
  198. '''A sample application that will publish a status update after going into the login process using the Javascript SDK '''
  199. yourappid = '364831617044713'
  200. return render(request, 'hackathon/facebook.html', { 'yourappid' : yourappid })
  201. #################
  202. # YELP API #
  203. #################
  204. def yelp(request):
  205. data = {}
  206. if request.method == 'POST':
  207. location = request.POST.get('location')
  208. data = requestData(location)
  209. return render(request, 'hackathon/yelp.html', { 'data': data })
  210. #################
  211. # MEETUP API #
  212. #################
  213. def meetup(request):
  214. REDIRECT_URI = 'http://127.0.0.1:8000/hackathon/meetupToken'
  215. AUTHORIZE_URL = 'https://secure.meetup.com/oauth2/authorize?client_id=' + settings.MEETUP_CONSUMER_KEY + '&response_type=code' + '&redirect_uri=' + REDIRECT_URI
  216. return HttpResponseRedirect(AUTHORIZE_URL)
  217. def meetupToken(request):
  218. # print request.GET.get('code')
  219. access_token_url = 'https://secure.meetup.com/oauth2/access?'
  220. REDIRECT_URI = 'http://127.0.0.1:8000/hackathon/meetupToken'
  221. 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')
  222. response = requests.post(url)
  223. access_token = json.loads(response.content)['access_token']
  224. # print access_token
  225. #if not MeetupToken.objects.all()[0]:
  226. if not MeetupToken.objects.all().exists():
  227. meetupToken = MeetupToken(access_token = access_token)
  228. meetupToken.save()
  229. else:
  230. meetupToken = MeetupToken(access_token = access_token)
  231. MeetupToken.objects.all()[0] = meetupToken
  232. return HttpResponseRedirect('http://127.0.0.1:8000/hackathon/meetupUser/')
  233. def meetupUser(request):
  234. if not MeetupToken.objects.all().exists():
  235. return HttpResponseRedirect('http://127.0.0.1:8000/hackathon/meetup')
  236. access_token = MeetupToken.objects.all()[0]
  237. meetupData = {}
  238. userData = retrieveUserData('https://api.meetup.com/2/member/self/?access_token=' + str(access_token))
  239. meetupData['userData'] = userData
  240. return render(request, 'hackathon/meetup.html', { 'data': meetupData })
  241. #################
  242. # QUANDL API #
  243. #################
  244. def quandlDowJones(request):
  245. '''Returns JSON response about the latest dowjones index.'''
  246. dowjonesdata = fetchData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/BCB/UDJIAD1.json?')
  247. print dowjonesdata
  248. return JsonResponse({'data': dowjonesdata})
  249. def quandlSnp500(request):
  250. '''Returns JSON response about the latest SNP 500 index.'''
  251. snpdata = fetchData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/YAHOO/INDEX_GSPC.json?')
  252. return JsonResponse({'data': snpdata})
  253. def quandlNasdaq(request):
  254. '''Returns JSON response about the latest nasdaq index.'''
  255. nasdaqdata = fetchData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/NASDAQOMX/COMP.json?')
  256. return JsonResponse({'data': nasdaqdata})
  257. def quandlapple(request):
  258. '''Returns JSON response about the latest apple stock.'''
  259. appledata = fetchstockData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/GOOG/NASDAQ_AAPL.json')
  260. return JsonResponse({'data': appledata})
  261. def quandlNasdaqdiff(request):
  262. '''Returns JSON response about the latest nasdaq index.'''
  263. nasdaqdata = rdiffData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/NASDAQOMX/COMP.json?')
  264. return JsonResponse({'data': nasdaqdata})
  265. def quandlSnp500diff(request):
  266. '''Returns JSON response about the latest SNP 500 index.'''
  267. snpdata = rdiffData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/YAHOO/INDEX_GSPC.json?')
  268. return JsonResponse({'data': snpdata})
  269. def quandlDowJonesdiff(request):
  270. '''Returns JSON response about the latest dowjones index.'''
  271. dowjonesdata = rdiffData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/BCB/UDJIAD1.json?')
  272. return JsonResponse({'data': dowjonesdata})
  273. def quandlapplediff(request):
  274. '''Returns JSON response about the latest apple stock.'''
  275. appledata = rdiffData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/GOOG/NASDAQ_AAPL.json')
  276. return JsonResponse({'data': appledata})
  277. def quandlstocks(request):
  278. everyData = {}
  279. dowjonesdata = fetchData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/BCB/UDJIAD1.json?')
  280. everyData['dow'] = dowjonesdata
  281. everyData['dowdiff'] = rdiffData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/BCB/UDJIAD1.json?')
  282. snpdata = fetchData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/YAHOO/INDEX_GSPC.json?')
  283. everyData['snp'] = snpdata
  284. everyData['snpdiff'] = rdiffData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/YAHOO/INDEX_GSPC.json?')
  285. nasdaqdata = fetchData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/NASDAQOMX/COMP.json?')
  286. everyData['nasdaq'] = nasdaqdata
  287. everyData['nasdaqdiff'] = rdiffData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/NASDAQOMX/COMP.json?')
  288. everyData['apple'] = fetchstockData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/GOOG/NASDAQ_AAPL.json')
  289. everyData['applediff'] = rdiffData(settings.QUANDLAPIKEY, 'https://www.quandl.com/api/v1/datasets/GOOG/NASDAQ_AAPL.json')
  290. return render(request, 'hackathon/quandl.html', { 'everyData': everyData })
  291. #################
  292. # NYTIMES API #
  293. #################
  294. def nytimespop(request):
  295. '''Returns JSON response about the most viewed articles for the last 24 hours.'''
  296. popdata = fetcharticle(settings.POPAPIKEY, 'http://api.nytimes.com/svc/mostpopular/v2/mostviewed/all-sections/1.json?')
  297. return JSONResponse({'data': popdata})
  298. def nytimestop(request):
  299. '''Returns JSON response about the articles located in the homepage'''
  300. topdata = fetcharticle(settings.TOPAPIKEY, 'http://api.nytimes.com/svc/topstories/v1/home.json?')
  301. return JSONResponse({'data': topdata})
  302. def nytimesarticles(request):
  303. everyData = {}
  304. popdata = fetcharticle(settings.POPAPIKEY, 'http://api.nytimes.com/svc/mostpopular/v2/mostviewed/all-sections/1.json?')
  305. topdata = topdata = fetcharticle(settings.TOPAPIKEY, 'http://api.nytimes.com/svc/topstories/v1/home.json?')
  306. everyData['top'] = topdata
  307. everyData['pop'] = popdata
  308. return render(request, 'hackathon/nytimes.html', { 'everyData': everyData })
  309. #################
  310. # GITHUB API #
  311. #################
  312. def githubUser(request):
  313. '''Returns Github Profile data for a specific user.'''
  314. parsedData = {}
  315. if request.method == 'POST':
  316. user = request.POST.get('user')
  317. parsedData['userData'] = getUserData(user, settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  318. return render(request, 'hackathon/github.html', {'data': parsedData})
  319. # return JsonResponse({ 'data': parsedData })
  320. def githubTopRepositories(request):
  321. '''Returns Top Commited Repositories for a specific Github User'''
  322. parsedData = {}
  323. if request.method == 'POST':
  324. user = request.POST.get('user')
  325. repositories = getUserRepositories(user, settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  326. list = getTopContributedRepositories(user, repositories, settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  327. filtered = filterCommits(list)
  328. parsedData['committed'] = filtered
  329. print parsedData
  330. return render(request, 'hackathon/githubTopRepositories.html', {'data': parsedData})
  331. # return JsonResponse({ 'data': parsedData })
  332. def githubResume(request):
  333. '''A sample application which pulls various Github data to form a Resume of sorts'''
  334. allData = {}
  335. userData = getUserData('DrkSephy', settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  336. repositories = getUserRepositories('DrkSephy', settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  337. list = getTopContributedRepositories('DrkSephy', repositories, settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  338. filtered = filterCommits(list)
  339. stargazers = getStarGazerCount('DrkSephy', settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  340. filteredStargazers = filterStarGazerCount(stargazers)
  341. forkedRepos = getForkedRepositories('DrkSephy', settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  342. allData['userData'] = userData
  343. allData['filteredData'] = filtered
  344. allData['filteredStargazers'] = filteredStargazers
  345. allData['forkedRepos'] = forkedRepos
  346. return render(request, 'hackathon/githubResume.html', { 'data': allData })
  347. #################
  348. # TUMBLR API #
  349. #################
  350. def tumblr(request):
  351. ''' Tumblr api calls '''
  352. if not getTumblr.accessed:
  353. oauth_verifier = request.GET.get('oauth_verifier')
  354. getTumblr.access_token_url(oauth_verifier)
  355. if request.user not in User.objects.all():
  356. try:
  357. user_info, total_blog = getTumblr.getUserInfo()
  358. username = str(user_info['name'])+ "2"
  359. user = User.objects.get(username=username)
  360. except User.DoesNotExist:
  361. user_info, total_blog = getTumblr.getUserInfo()
  362. username = str(user_info['name'])+ "2"
  363. new_user = User.objects.create_user(username, username+'@tumblr.com','password')
  364. new_user.save()
  365. profile =Profile()
  366. profile.user = new_user
  367. profile.oauth_token = getTumblr.oauth_token
  368. profile.oauth_secret = getTumblr.oauth_token_secret
  369. profile.save()
  370. user = authenticate(username=username, password='password')
  371. login(request, user)
  372. #get blogger twitterthecomic's blog information
  373. blog = getTumblr.getBlogInfo('twitterthecomic')
  374. #get tags that was tagged along starbucks
  375. tagged_blog = getTumblr.getTaggedInfo("starbucks")
  376. #get blog information tagged with starbucks
  377. blogontag = getTumblr.getTaggedBlog("starbucks")
  378. context = {'title': "What's up Starbucks?", 'blogData': blog, 'blogTag': tagged_blog, 'blogontag': blogontag}
  379. return render(request, 'hackathon/tumblr.html', context)
  380. ####################
  381. # INSTAGRAM API #
  382. ####################
  383. def instagram(request):
  384. print getInstagram.is_authorized
  385. if getInstagram.is_authorized:
  386. if request.method == 'GET':
  387. if request.GET.items():
  388. instagram_tag = request.GET.get('instagram_tag')
  389. instagramUser = InstagramProfile.objects.get(user = request.user)
  390. tagged_media = getTaggedMedia(instagram_tag, instagramUser.access_token)
  391. else:
  392. instagram_tag, tagged_media = '', ''
  393. else:
  394. global profile_track
  395. profile_track = 'instagram'
  396. instagram_url =getInstagram.get_authorize_url()
  397. return HttpResponseRedirect(instagram_url)
  398. context = {'title': 'Instagram', 'tagged_media': tagged_media, 'search_tag': instagram_tag}
  399. return render(request, 'hackathon/instagram.html', context)
  400. def instagramUser(request):
  401. ''' Returns JSON response about a specific Instagram User. '''
  402. access_token = InstagramProfile.objects.get(instagram_user='mk200789').access_token
  403. parsedData = getUserInfo(access_token)
  404. return JsonResponse({ 'data': parsedData })
  405. def instagramUserMedia(request):
  406. ''' Returns JSON response about a specific Instagram User's Media. '''
  407. access_token = InstagramProfile.objects.get(instagram_user='mk200789').access_token
  408. parsedData = getUserMedia(32833691, access_token)
  409. return JsonResponse({'data': parsedData })
  410. def instagramMediaByLocation(request):
  411. print request.user
  412. if request.method == 'GET':
  413. if request.GET.items():
  414. #check if user has a User profile
  415. if request.user in User.objects.all():
  416. #check if user has an Instagram profile
  417. user = User.objects.get(username=request.user)
  418. #if user has an Instagram profile, query the search
  419. if InstagramProfile.objects.all().filter(user=user.id):
  420. address = request.GET.get('address_field')
  421. access_token = InstagramProfile.objects.get(user=user.id).access_token
  422. geocode_result = searchForLocation(address)
  423. if geocode_result:
  424. location_ids = searchLocationIds(geocode_result['lat'], geocode_result['lng'], access_token)
  425. media = searchLocationMedia(location_ids, access_token)
  426. title = address
  427. err_msg = ''
  428. else:
  429. title, media, err_msg, location_ids, geocode_result = 'Media by location','', str(request.user)+ ' does not have an InstagramProfile','', ''
  430. else:
  431. title, media, err_msg, location_ids, geocode_result = 'Media by location', '','', '', ''
  432. context = {'title': title, 'geocode_result':geocode_result, 'media':media, 'list_id':location_ids, 'err_msg': err_msg}
  433. return render(request, 'hackathon/instagram_q.html', context)
  434. ####################
  435. # TWITTER API #
  436. ####################
  437. def twitter(request):
  438. if getTwitter.is_authorized:
  439. value = getTwitter.get_trends_available(settings.YAHOO_CONSUMER_KEY)
  440. else:
  441. global profile_track
  442. profile_track = 'twitter'
  443. twitter_url = getTwitter.get_authorize_url()
  444. return HttpResponseRedirect(twitter_url)
  445. context ={'title': 'twitter', 'value': value}
  446. return render(request, 'hackathon/twitter.html', context)
  447. def twitterTweets(request):
  448. print getTwitter.is_authorized
  449. if getTwitter.is_authorized:
  450. #content = getTwitter.get_tweets()
  451. if request.method == 'GET':
  452. if request.GET.items():
  453. tweets = request.GET.get('tweets')
  454. content, jsonlist = getTwitter.get_tweets(tweets)
  455. else:
  456. content, jsonlist = '', ''
  457. else:
  458. global profile_track
  459. profile_track = 'twitter'
  460. twitter_url = getTwitter.get_authorize_url()
  461. return HttpResponseRedirect(twitter_url)
  462. context ={'title': 'twitter tweet', 'content': content, 'data': jsonlist}
  463. return render(request, 'hackathon/twitter_tweet.html', context)
  464. ##################
  465. # LINKEDIN API #
  466. ##################
  467. def linkedin(request):
  468. if getLinkedIn.is_authorized:
  469. content = getLinkedIn.getUserInfo()
  470. else:
  471. global profile_track
  472. profile_track = 'linkedin'
  473. linkedin_url = getLinkedIn.get_authorize_url()
  474. return HttpResponseRedirect(linkedin_url)
  475. context = {'title': 'linkedin example', 'content': content}
  476. return render(request, 'hackathon/linkedin.html', context)
  477. #########################
  478. # Snippet RESTful Model #
  479. #########################
  480. class JSONResponse(HttpResponse):
  481. """
  482. An HttpResponse that renders its content into JSON.
  483. """
  484. def __init__(self, data, **kwargs):
  485. content = JSONRenderer().render(data)
  486. kwargs['content_type'] = 'application/json'
  487. super(JSONResponse, self).__init__(content, **kwargs)
  488. @csrf_exempt
  489. def snippet_list(request):
  490. """
  491. List all code snippets, or create a new snippet.
  492. """
  493. if request.method == 'GET':
  494. snippets = Snippet.objects.all()
  495. serializer = SnippetSerializer(snippets, many=True)
  496. return JSONResponse(serializer.data)
  497. ##################
  498. # Twilio API #
  499. ##################
  500. def twilio(request):
  501. if request.method == 'POST':
  502. number = request.POST.get('number')
  503. message = request.POST.get('message')
  504. sendSMS(str(message), str(number), '+13473781813')
  505. context = {'message': 'Your message has been sent successfully!'}
  506. return HttpResponseRedirect('/hackathon/api/')
  507. return render(request, 'hackathon/twilio.html')
  508. ######################
  509. # Registration Views #
  510. ######################
  511. def register(request):
  512. registered = False
  513. if request.method == 'POST':
  514. user_form = UserForm(data=request.POST)
  515. if user_form.is_valid():
  516. user = user_form.save()
  517. user.set_password(user.password)
  518. user.save()
  519. registered = True
  520. else:
  521. print user_form.errors
  522. else:
  523. user_form = UserForm()
  524. return render(request,
  525. 'hackathon/register.html',
  526. {'user_form': user_form, 'registered': registered} )
  527. def user_login(request):
  528. if request.method == 'POST':
  529. username = request.POST.get('username')
  530. password = request.POST.get('password')
  531. user = authenticate(username=username, password=password)
  532. if user:
  533. if user.is_active:
  534. login(request, user)
  535. return HttpResponseRedirect('/hackathon/')
  536. else:
  537. return HttpResponse("Your Django Hackathon account is disabled.")
  538. else:
  539. print "Invalid login details: {0}, {1}".format(username, password)
  540. return HttpResponse("Invalid login details supplied.")
  541. else:
  542. return render(request, 'hackathon/login.html', {})
  543. def user_logout(request):
  544. logout(request)
  545. return HttpResponseRedirect('/hackathon/')
  546. def instagram_login(request):
  547. global profile_track
  548. profile_track = 'instagram'
  549. instagram_url = getInstagram.get_authorize_url()
  550. return HttpResponseRedirect(instagram_url)
  551. def tumblr_login(request):
  552. global profile_track
  553. profile_track = 'tumblr'
  554. tumblr_url = getTumblr.authorize_url()
  555. return HttpResponseRedirect(tumblr_url)
  556. def twitter_login(request):
  557. global profile_track
  558. profile_track = 'twitter'
  559. twitter_url = getTwitter.get_authorize_url()
  560. return HttpResponseRedirect(twitter_url)
  561. def github_login(request):
  562. global profile_track
  563. profile_track = 'github'
  564. github_url = getGithub.get_authorize_url()
  565. return HttpResponseRedirect(github_url)
  566. def linkedin_login(request):
  567. global profile_track
  568. profile_track = 'linkedin'
  569. linkedin_url = getLinkedIn.get_authorize_url()
  570. return HttpResponseRedirect(linkedin_url)
  571. def facebook_login(request):
  572. global profile_track
  573. profile_track = 'facebook'
  574. facebook_url = getFacebook.get_authorize_url()
  575. return HttpResponseRedirect(facebook_url)