views.py 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  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. # Python
  20. import oauth2 as oauth
  21. from rest_framework.renderers import JSONRenderer
  22. from rest_framework.parsers import JSONParser
  23. # Models
  24. from hackathon.models import Snippet, Profile
  25. from hackathon.serializers import SnippetSerializer
  26. from hackathon.forms import UserForm
  27. getTumblr = TumblrOauthClient(settings.TUMBLR_CONSUMER_KEY, settings.TUMBLR_CONSUMER_SECRET)
  28. getInstagram = InstagramOauthClient(settings.INSTAGRAM_CLIENT_ID, settings.INSTAGRAM_CLIENT_SECRET)
  29. def index(request):
  30. context = {'hello': 'world'}
  31. return render(request, 'hackathon/index.html', context)
  32. ##################
  33. # Twilio API #
  34. ##################
  35. def twilio(request):
  36. sendSMS('Meow', '+13473282978', '+13473781813')
  37. return render(request, 'hackathon/twilio.html')
  38. ##################
  39. # API Examples #
  40. ##################
  41. def api_examples(request):
  42. instagram_url =getInstagram.get_authorize_url()
  43. if not getTumblr.accessed:
  44. obtain_oauth_verifier = getTumblr.authorize_url()
  45. else:
  46. obtain_oauth_verifier = '/hackathon/tumblr'
  47. context = {'title': 'API Examples Page', 'tumblr_url': obtain_oauth_verifier, 'instagram_url':instagram_url}
  48. return render(request, 'hackathon/api_examples.html', context)
  49. #################
  50. # STEAM API #
  51. #################
  52. def steam(request):
  53. #Should link to test of Steam API example.
  54. key = '231E98D442E52B87110816C3D5114A1D'
  55. SteamUN = "Marorin"
  56. steamID = steamIDPulling(SteamUN, key)
  57. game = gamesPulling(steamID, key)
  58. return render(request,'hackathon/steam.html', {"game": game })
  59. #################
  60. # GITHUB API #
  61. #################
  62. def githubUser(request):
  63. '''Returns JSON response about a specific Github User'''
  64. parsedData = {}
  65. parsedData['userData'] = getUserData(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  66. return JsonResponse({ 'data': parsedData })
  67. def githubTopRepositories(request):
  68. '''Returns JSON response of a User's Top Committed repositories'''
  69. parsedData = {}
  70. repositories = getUserRepositories(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  71. list = getTopContributedRepositories(repositories, settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  72. filtered = filterCommits(list)
  73. parsedData['committed'] = filtered
  74. return JsonResponse({ 'data': parsedData })
  75. def githubResume(request):
  76. '''A sample application which pulls various Github data to form a Resume of sorts'''
  77. allData = {}
  78. userData = getUserData(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  79. repositories = getUserRepositories(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  80. list = getTopContributedRepositories(repositories, settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  81. filtered = filterCommits(list)
  82. stargazers = getStarGazerCount(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  83. filteredStargazers = filterStarGazerCount(stargazers)
  84. forkedRepos = getForkedRepositories(settings.GITHUB_CLIENT_ID, settings.GITHUB_CLIENT_SECRET)
  85. allData['userData'] = userData
  86. allData['filteredData'] = filtered
  87. allData['filteredStargazers'] = filteredStargazers
  88. allData['forkedRepos'] = forkedRepos
  89. return render(request, 'hackathon/github.html', { 'data': allData })
  90. #################
  91. # TUMBLR API #
  92. #################
  93. def tumblr(request):
  94. ''' Tumblr api calls '''
  95. #retrieve verifier via url link
  96. #if not request.GET.items():
  97. # return HttpResponseRedirect('/hackathon/api/')
  98. if not getTumblr.accessed:
  99. oauth_verifier = request.GET.get('oauth_verifier')
  100. getTumblr.access_token_url(oauth_verifier)
  101. #get blogger twitterthecomic's blog information
  102. blog = getTumblr.getBlogInfo('twitterthecomic')
  103. #get tags that was tagged along starbucks
  104. tagged_blog = getTumblr.getTaggedInfo("starbucks")
  105. #get blog information tagged with starbucks
  106. blogontag = getTumblr.getTaggedBlog("starbucks")
  107. #get user's information
  108. userinfo, total_blog = getTumblr.getUserInfo()
  109. context = {'title': "What's up Starbucks?", 'blogData': blog, 'blogTag': tagged_blog, 'blogontag': blogontag, 'userinfo': userinfo, 'total_blog':total_blog}
  110. return render(request, 'hackathon/tumblr.html', context)
  111. ####################
  112. # INSTAGRAM API #
  113. ####################
  114. def instagram(request):
  115. code = request.GET['code']
  116. getInstagram.get_access_token(code)
  117. if request.user not in User.objects.all():
  118. try:
  119. user = User.objects.get(username=getInstagram.user_data['username'] )
  120. except User.DoesNotExist:
  121. username = getInstagram.user_data['username']
  122. new_user = User.objects.create_user(username, username+'@example.com', 'password')
  123. new_user.save()
  124. profile = Profile()
  125. profile.user = new_user
  126. profile.oauth_token = getInstagram.client_id
  127. profile.oauth_secret = getInstagram.client_secret
  128. profile.save()
  129. user = authenticate(username=getInstagram.user_data['username'], password='password')
  130. login(request, user)
  131. search_tag = 'kitten'
  132. #return tagged objects
  133. tagged_media = getInstagram.get_tagged_media(search_tag)
  134. #user = getInstagram.user_data['username']
  135. #print User.objects.get(username=user)
  136. context = {'title': 'Instagram', 'tagged_media': tagged_media, 'search_tag': search_tag}
  137. return render(request, 'hackathon/instagram.html', context)
  138. ##################
  139. # LINKED IN API #
  140. ##################
  141. def linkedin(request):
  142. userinfo = getUserInfo()
  143. context = {'title': 'linkedin Example','userdata': userinfo}
  144. return render(request, 'hackathon/linkedin.html', context)
  145. #########################
  146. # Snippet RESTful Model #
  147. #########################
  148. class JSONResponse(HttpResponse):
  149. """
  150. An HttpResponse that renders its content into JSON.
  151. """
  152. def __init__(self, data, **kwargs):
  153. content = JSONRenderer().render(data)
  154. kwargs['content_type'] = 'application/json'
  155. super(JSONResponse, self).__init__(content, **kwargs)
  156. @csrf_exempt
  157. def snippet_list(request):
  158. """
  159. List all code snippets, or create a new snippet.
  160. """
  161. if request.method == 'GET':
  162. snippets = Snippet.objects.all()
  163. serializer = SnippetSerializer(snippets, many=True)
  164. return JSONResponse(serializer.data)
  165. ######################
  166. # Registration Views #
  167. ######################
  168. def register(request):
  169. registered = False
  170. if request.method == 'POST':
  171. user_form = UserForm(data=request.POST)
  172. if user_form.is_valid():
  173. user = user_form.save()
  174. user.set_password(user.password)
  175. user.save()
  176. registered = True
  177. else:
  178. print user_form.errors
  179. else:
  180. user_form = UserForm()
  181. return render(request,
  182. 'hackathon/register.html',
  183. {'user_form': user_form, 'registered': registered} )
  184. def user_login(request):
  185. if request.method == 'POST':
  186. username = request.POST.get('username')
  187. password = request.POST.get('password')
  188. user = authenticate(username=username, password=password)
  189. if user:
  190. if user.is_active:
  191. login(request, user)
  192. return HttpResponseRedirect('/hackathon/')
  193. else:
  194. return HttpResponse("Your Django Hackathon account is disabled.")
  195. else:
  196. print "Invalid login details: {0}, {1}".format(username, password)
  197. return HttpResponse("Invalid login details supplied.")
  198. else:
  199. return render(request, 'hackathon/login.html', {})
  200. def user_logout(request):
  201. logout(request)
  202. return HttpResponseRedirect('/hackathon/')
  203. def instagram_login(request):
  204. instagram_url =getInstagram.get_authorize_url()
  205. return HttpResponseRedirect(instagram_url)