views.py 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422
  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 InstagramOauthClient
  19. from scripts.scraper import steamDiscounts
  20. from scripts.quandl import *
  21. from scripts.paypal import PaypalOauthClient
  22. from scripts.twitter import TwitterOauthClient
  23. # Python
  24. import oauth2 as oauth
  25. from rest_framework.renderers import JSONRenderer
  26. from rest_framework.parsers import JSONParser
  27. # Models
  28. from hackathon.models import Snippet, Profile
  29. from hackathon.serializers import SnippetSerializer
  30. from hackathon.forms import UserForm
  31. getTumblr = TumblrOauthClient(settings.TUMBLR_CONSUMER_KEY, settings.TUMBLR_CONSUMER_SECRET)
  32. getInstagram = InstagramOauthClient(settings.INSTAGRAM_CLIENT_ID, settings.INSTAGRAM_CLIENT_SECRET)
  33. getPaypal = PaypalOauthClient(settings.PAYPAL_CLIENT_ID, settings.PAYPAL_CLIENT_SECRET)
  34. getTwitter = TwitterOauthClient(settings.TWITTER_CONSUMER_KEY, settings.TWITTER_CONSUMER_SECRET, settings.TWITTER_ACCESS_TOKEN, settings.TWITTER_ACCESS_TOKEN_SECRET)
  35. def index(request):
  36. context = {'hello': 'world'}
  37. return render(request, 'hackathon/index.html', context)
  38. ##################
  39. # API Examples #
  40. ##################
  41. def api_examples(request):
  42. instagram_url =getInstagram.get_authorize_url()
  43. paypal_url = getPaypal.get_authorize_url()
  44. twitter_url = getTwitter.get_authorize_url()
  45. if not getTumblr.accessed:
  46. obtain_oauth_verifier = getTumblr.authorize_url()
  47. else:
  48. obtain_oauth_verifier = '/hackathon/tumblr'
  49. #obtain_oauth_verifier = getTumblr.authorize_url()
  50. context = {'title': 'API Examples Page', 'tumblr_url': obtain_oauth_verifier, 'instagram_url':instagram_url, 'paypal_url': paypal_url, 'twitter_url':twitter_url}
  51. return render(request, 'hackathon/api_examples.html', context)
  52. #################
  53. # STEAM API #
  54. #################
  55. def steam(request):
  56. #Should link to test of Steam API example.
  57. key = '231E98D442E52B87110816C3D5114A1D'
  58. SteamUN = "Marorin"
  59. steamID = steamidpulling(SteamUN, key)
  60. game = gamespulling(steamID, key)
  61. return render(request,'hackathon/steam.html', {"game": game })
  62. def steamDiscountedGames(request):
  63. data = steamDiscounts()
  64. return JsonResponse({ 'data': data })
  65. #################
  66. # FACEBOOK API #
  67. #################
  68. def facebook(request):
  69. '''A sample application that will publish a status update after going into the login process using the Javascript SDK '''
  70. yourappid = '364831617044713'
  71. return render(request, 'hackathon/facebook.html', { 'yourappid' : yourappid })
  72. #################
  73. # QUANDL API #
  74. #################
  75. def quandlDowJones(request):
  76. '''Returns JSON response about the latest dowjones index.'''
  77. APIKEY = 'fANs6ykrCdAxas7zpMz7'
  78. dowjonesdata = fetchData(APIKEY, 'https://www.quandl.com/api/v1/datasets/BCB/UDJIAD1.json?')
  79. print dowjonesdata
  80. return JsonResponse({'data': dowjonesdata})
  81. def quandlSnp500(request):
  82. '''Returns JSON response about the latest SNP 500 index.'''
  83. APIKEY = 'fANs6ykrCdAxas7zpMz7'
  84. snpdata = fetchData(APIKEY, 'https://www.quandl.com/api/v1/datasets/YAHOO/INDEX_GSPC.json?')
  85. return JsonResponse({'data': snpdata})
  86. def quandlNasdaq(request):
  87. '''Returns JSON response about the latest nasdaq index.'''
  88. APIKEY = 'fANs6ykrCdAxas7zpMz7'
  89. nasdaqdata = fetchData(APIKEY, 'https://www.quandl.com/api/v1/datasets/NASDAQOMX/COMP.json?')
  90. return JsonResponse({'data': nasdaqdata})
  91. def quandlstocks(request):
  92. APIKEY = 'fANs6ykrCdAxas7zpMz7'
  93. everyData = {}
  94. dowjonesdata = fetchData(APIKEY, 'https://www.quandl.com/api/v1/datasets/BCB/UDJIAD1.json?')
  95. everyData['dow'] = dowjonesdata
  96. snpdata = fetchData(APIKEY, 'https://www.quandl.com/api/v1/datasets/YAHOO/INDEX_GSPC.json?')
  97. everyData['snp'] = snpdata
  98. nasdaqdata = fetchData(APIKEY, 'https://www.quandl.com/api/v1/datasets/NASDAQOMX/COMP.json?')
  99. everyData['nasdaq'] = nasdaqdata
  100. return render(request, 'hackathon/quandl.html', { 'everyData': everyData })
  101. #################
  102. # GITHUB API #
  103. #################
  104. def githubUser(request):
  105. '''Returns JSON response about a specific Github User'''
  106. parsedData = {}
  107. parsedData['userData'] = getUserData(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  108. return JsonResponse({ 'data': parsedData })
  109. def githubTopRepositories(request):
  110. '''Returns JSON response of a User's Top Committed repositories'''
  111. parsedData = {}
  112. repositories = getUserRepositories(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  113. list = getTopContributedRepositories(repositories, settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  114. filtered = filterCommits(list)
  115. parsedData['committed'] = filtered
  116. return JsonResponse({ 'data': parsedData })
  117. def githubResume(request):
  118. '''A sample application which pulls various Github data to form a Resume of sorts'''
  119. allData = {}
  120. userData = getUserData(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  121. repositories = getUserRepositories(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  122. list = getTopContributedRepositories(repositories, settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  123. filtered = filterCommits(list)
  124. stargazers = getStarGazerCount(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  125. filteredStargazers = filterStarGazerCount(stargazers)
  126. forkedRepos = getForkedRepositories(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  127. allData['userData'] = userData
  128. allData['filteredData'] = filtered
  129. allData['filteredStargazers'] = filteredStargazers
  130. allData['forkedRepos'] = forkedRepos
  131. return render(request, 'hackathon/github.html', { 'data': allData })
  132. #################
  133. # TUMBLR API #
  134. #################
  135. def tumblr(request):
  136. ''' Tumblr api calls '''
  137. if not getTumblr.accessed:
  138. oauth_verifier = request.GET.get('oauth_verifier')
  139. getTumblr.access_token_url(oauth_verifier)
  140. if request.user not in User.objects.all():
  141. try:
  142. user_info, total_blog = getTumblr.getUserInfo()
  143. username = str(user_info['name'])+ "2"
  144. user = User.objects.get(username=username)
  145. except User.DoesNotExist:
  146. user_info, total_blog = getTumblr.getUserInfo()
  147. username = str(user_info['name'])+ "2"
  148. new_user = User.objects.create_user(username, username+'@example.com','password')
  149. new_user.save()
  150. profile =Profile()
  151. profile.user = new_user
  152. profile.oauth_token = getTumblr.oauth_token
  153. profile.oauth_secret = getTumblr.oauth_token_secret
  154. profile.save()
  155. user = authenticate(username=username, password='password')
  156. login(request, user)
  157. #get blogger twitterthecomic's blog information
  158. blog = getTumblr.getBlogInfo('twitterthecomic')
  159. #get tags that was tagged along starbucks
  160. tagged_blog = getTumblr.getTaggedInfo("starbucks")
  161. #get blog information tagged with starbucks
  162. blogontag = getTumblr.getTaggedBlog("starbucks")
  163. context = {'title': "What's up Starbucks?", 'blogData': blog, 'blogTag': tagged_blog, 'blogontag': blogontag}
  164. return render(request, 'hackathon/tumblr.html', context)
  165. ####################
  166. # INSTAGRAM API #
  167. ####################
  168. def instagram(request):
  169. code = request.GET['code']
  170. getInstagram.get_access_token(code)
  171. if request.user not in User.objects.all():
  172. try:
  173. user = User.objects.get(username=getInstagram.user_data['username'] )
  174. except User.DoesNotExist:
  175. username = getInstagram.user_data['username']
  176. new_user = User.objects.create_user(username, username+'@example.com', 'password')
  177. new_user.save()
  178. profile = Profile()
  179. profile.user = new_user
  180. profile.oauth_token = getInstagram.client_id
  181. #since instagram doesnt have oauth_secret value, using this field to temp set in access token
  182. # for JSON response
  183. profile.oauth_secret = getInstagram.access_token
  184. profile.save()
  185. user = authenticate(username=getInstagram.user_data['username'], password='password')
  186. login(request, user)
  187. search_tag = 'kitten'
  188. #return tagged objects
  189. tagged_media = getInstagram.get_tagged_media(search_tag)
  190. context = {'title': 'Instagram', 'tagged_media': tagged_media, 'search_tag': search_tag}
  191. return render(request, 'hackathon/instagram.html', context)
  192. def instagramUser(request):
  193. ''' Returns JSON response about a specific Instagram User. '''
  194. user_id = User.objects.get(username='mk200789').id
  195. access_token = Profile.objects.get(user=user_id).oauth_secret
  196. parsedData = getInstagram.get_user_info(access_token)
  197. return JsonResponse({ 'data': parsedData })
  198. def instagramUserMedia(request):
  199. ''' Returns JSON response about a specific Instagram User's Media. '''
  200. user_id = User.objects.get(username='mk200789').id
  201. access_token = Profile.objects.get(user=user_id).oauth_secret
  202. parsedData = getInstagram.get_user_media(32833691,access_token)
  203. return JsonResponse({'data': parsedData })
  204. def instagramMediaByLocation(request):
  205. if request.method == 'GET':
  206. if request.GET.items():
  207. if request.user in User.objects.all():
  208. address = request.GET.get('address_field')
  209. user_id = User.objects.get(username=request.user).id
  210. access_token = Profile.objects.get(user=user_id).oauth_secret
  211. #lat, lng = getInstagram.search_for_location(address, access_token)
  212. geocode_result = getInstagram.search_for_location(address, access_token)
  213. if geocode_result:
  214. location_ids =getInstagram.search_location_ids(geocode_result['lat'], geocode_result['lng'], access_token)
  215. media = getInstagram.search_location_media(location_ids, access_token)
  216. title = address
  217. else:
  218. title, media,location_ids, geocode_result = 'Media by location', '','', ''
  219. context = {'title': title, 'geocode_result':geocode_result, 'media':media, 'list_id':location_ids}
  220. return render(request, 'hackathon/instagram_q.html', context)
  221. ####################
  222. # PAYPAL API #
  223. ####################
  224. def paypal(request):
  225. authorization_code = request.GET['code']
  226. refresh_token = getPaypal.get_access_token(authorization_code)
  227. getPaypal.get_refresh_token(refresh_token)
  228. #getPaypal.userinfo()
  229. print getPaypal.access_token
  230. getPaypal.create_invoice()
  231. context = {'title':'paypal'}
  232. return render(request, 'hackathon/paypal.html', context)
  233. ####################
  234. # TWITTER API #
  235. ####################
  236. def twitter(request):
  237. oauth_verifier = request.GET['oauth_verifier']
  238. getTwitter.get_access_token_url(oauth_verifier)
  239. if request.user not in User.objects.all():
  240. try:
  241. user = User.objects.get(username=getTwitter.username )
  242. except User.DoesNotExist:
  243. username = getTwitter.username
  244. new_user = User.objects.create_user(username, username+'@example.com', 'password')
  245. new_user.save()
  246. profile = Profile()
  247. profile.user = new_user
  248. profile.oauth_token = getTwitter.oauth_token
  249. profile.oauth_secret = getTwitter.oauth_token_secret
  250. profile.save()
  251. user = authenticate(username=getTwitter.username, password='password')
  252. login(request, user)
  253. context ={'title': 'twitter'}
  254. return render(request, 'hackathon/twitter.html', context)
  255. ##################
  256. # LINKED IN API #
  257. ##################
  258. def linkedin(request):
  259. userinfo = getUserInfo()
  260. context = {'title': 'linkedin Example','userdata': userinfo}
  261. return render(request, 'hackathon/linkedin.html', context)
  262. #########################
  263. # Snippet RESTful Model #
  264. #########################
  265. class JSONResponse(HttpResponse):
  266. """
  267. An HttpResponse that renders its content into JSON.
  268. """
  269. def __init__(self, data, **kwargs):
  270. content = JSONRenderer().render(data)
  271. kwargs['content_type'] = 'application/json'
  272. super(JSONResponse, self).__init__(content, **kwargs)
  273. @csrf_exempt
  274. def snippet_list(request):
  275. """
  276. List all code snippets, or create a new snippet.
  277. """
  278. if request.method == 'GET':
  279. snippets = Snippet.objects.all()
  280. serializer = SnippetSerializer(snippets, many=True)
  281. return JSONResponse(serializer.data)
  282. ##################
  283. # Twilio API #
  284. ##################
  285. def twilio(request):
  286. # Test credentials
  287. # sendSMS('Meow', '+13473282978', '+13473781813')
  288. if request.method == 'POST':
  289. number = request.POST.get('number')
  290. message = request.POST.get('message')
  291. sendSMS(str(message), str(number), '+13473781813')
  292. context = {'message': 'Your message has been sent successfully!'}
  293. return HttpResponseRedirect('/hackathon/api/')
  294. return render(request, 'hackathon/twilio.html')
  295. ######################
  296. # Registration Views #
  297. ######################
  298. def register(request):
  299. registered = False
  300. if request.method == 'POST':
  301. user_form = UserForm(data=request.POST)
  302. if user_form.is_valid():
  303. user = user_form.save()
  304. user.set_password(user.password)
  305. user.save()
  306. registered = True
  307. else:
  308. print user_form.errors
  309. else:
  310. user_form = UserForm()
  311. return render(request,
  312. 'hackathon/register.html',
  313. {'user_form': user_form, 'registered': registered} )
  314. def user_login(request):
  315. if request.method == 'POST':
  316. username = request.POST.get('username')
  317. password = request.POST.get('password')
  318. user = authenticate(username=username, password=password)
  319. if user:
  320. if user.is_active:
  321. login(request, user)
  322. return HttpResponseRedirect('/hackathon/')
  323. else:
  324. return HttpResponse("Your Django Hackathon account is disabled.")
  325. else:
  326. print ("Invalid login details: {0}, {1}".format(username, password))
  327. return HttpResponse("Invalid login details supplied.")
  328. else:
  329. return render(request, 'hackathon/login.html', {})
  330. def user_logout(request):
  331. logout(request)
  332. return HttpResponseRedirect('/hackathon/')
  333. def instagram_login(request):
  334. instagram_url =getInstagram.get_authorize_url()
  335. return HttpResponseRedirect(instagram_url)
  336. def tumblr_login(request):
  337. tumblr_url = getTumblr.authorize_url()
  338. return HttpResponseRedirect(tumblr_url)
  339. def twitter_login(request):
  340. twitter_url = getTwitter.get_authorize_url()
  341. return HttpResponseRedirect(twitter_url)