diff options
Diffstat (limited to 'website/views.py')
-rw-r--r-- | website/views.py | 335 |
1 files changed, 330 insertions, 5 deletions
diff --git a/website/views.py b/website/views.py index 8d63b28..4a956ea 100644 --- a/website/views.py +++ b/website/views.py @@ -3,12 +3,337 @@ from django.http import HttpResponse from django.template import loader import requests import uuid +from website.models import * +from django.db.models import Q +import json as simplejson +from . import utils +from django.db import connections +from .query import * + +def dictfetchall(cursor): + "Return all rows from a cursor as a dict" + columns = [col[0] for col in cursor.description] + return [ + dict(zip(columns, row)) + for row in cursor.fetchall() + ] + +def catg(cat_id, all_cat): + if all_cat is False: + category = TextbookCompanionCategoryList.objects.using('r')\ + .get(category_id=cat_id) + return category.maincategory + else: + category = TextbookCompanionCategoryList.objects.using('r')\ + .filter(~Q(category_id=0)).order_by('maincategory') + return category + + +def subcatg(subcat_id, all_subcat): + if all_subcat is False: + category = TextbookCompanionSubCategoryList.objects.using('r')\ + .get(id=subcat_id) + return category.subcategory + else: + category = TextbookCompanionSubCategoryList.objects.using('r')\ + .all().order_by('subcategory') + return category + + +def get_subcategories(maincat_id): + subcategories = TextbookCompanionSubCategoryList.objects.using('r')\ + .filter(maincategory_id=maincat_id).order_by('subcategory_id') + return subcategories + + + +def get_books(category_id): + + with connections['r'].cursor() as cursor: + cursor.execute(GET_TBC_PREFERENCE_FROM_CATEGORY_ID_SQL, + params=[category_id]) + books = dictfetchall(cursor) + return books + +def get_chapters(book_id): + with connections['r'].cursor() as cursor: + cursor.execute(GET_TBC_CHAPTER_SQL, + params=[book_id]) + chapters = dictfetchall(cursor) + return chapters + + +def get_examples(chapter_id): + with connections['r'].cursor() as cursor: + cursor.execute(GET_TBC_EXAMPLE_SQL, + params=[chapter_id]) + examples = dictfetchall(cursor) + return examples + + +def get_revisions(example_id): + with connections['r'].cursor() as cursor: + cursor.execute(GET_TBC_EXAMPLE_FILE_SQL, params=[example_id]) + example_file = cursor.fetchone() + example_file_filepath = example_file[4] + '/' + example_file[5] + commits = utils.get_commits(file_path=example_file_filepath) + return commits + + +def get_code(file_path, commit_sha): + code= utils.get_file(file_path, commit_sha, main_repo=True) + return code + def index(request): context = {} - session_id = uuid.uuid4() - context['session_id'] = str(session_id) - request.session['session_id'] = str(session_id) - template = loader.get_template('index.html') - return HttpResponse(template.render(context, request)) + book_id = request.GET.get('book_id') + user = request.user + + # if not user.is_anonymous(): + # social = user.social_auth.get(provider='google-oauth2') + # url = 'https://www.googleapis.com/plus/v1/people/me' + # params = {'access_token': social.extra_data['access_token']} + # # r = requests.get(url, params=params) + # # print(r.content) + + # context = { + # 'user': user + # } + + if not (request.GET.get('eid') or request.GET.get('book_id')): + catg_all = catg(None, all_cat=True) + subcatg_all = subcatg(None, all_subcat=True) + context = { + 'catg': catg_all, + 'subcatg': subcatg_all, + } + if 'maincat_id' in request.session: + maincat_id = request.session['maincat_id'] + context['maincat_id'] = int(maincat_id) + context['subcatg'] = get_subcategories(maincat_id) + + if 'subcategory_id' in request.session: + category_id = request.session['subcategory_id'] + context['subcategory_id'] = int(category_id) + context['books'] = get_books(category_id) + + if 'book_id' in request.session: + book_id = request.session['book_id'] + context['book_id'] = int(book_id) + context['chapters'] = get_chapters(book_id) + + if 'chapter_id' in request.session: + chapter_id = request.session['chapter_id'] + context['chapter_id'] = int(chapter_id) + context['examples'] = get_examples(chapter_id) + + if 'example_id' in request.session: + example_id = request.session['example_id'] + context['eid'] = int(example_id) + context['revisions'] = get_revisions(example_id) + with connections['r'].cursor() as cursor: + cursor.execute(GET_TBC_EXAMPLE_R_CLOUD_COMMENT_SQL, + params=[example_id]) + review = cursor.fetchone() + review_url = "https://r.fossee.in/cloud_comments/" + str(example_id) + context['review'] = review[0] + context['review_url'] = review_url + + if 'commit_sha' in request.session: + commit_sha = request.session['commit_sha'] + context['commit_sha'] = commit_sha + + if 'code' in request.session: + session_code = request.session['code'] + context['code'] = session_code + elif 'filepath' in request.session: + session_code = get_code( + request.session['filepath'], commit_sha) + context['code'] = session_code + template = loader.get_template('index.html') + return HttpResponse(template.render(context, request)) + elif book_id: + books = TextbookCompanionPreference.objects\ + .db_manager('r').raw(""" + SELECT DISTINCT (loc.category_id),pe.id, + tcbm.sub_category,loc.maincategory, pe.book as + book,loc.category_id,tcbm.sub_category, + pe.author as author, pe.publisher as publisher, + pe.year as year, pe.id as pe_id, pe.edition, + po.approval_date as approval_date + FROM textbook_companion_preference pe LEFT JOIN + textbook_companion_proposal po ON pe.proposal_id = po.id + LEFT JOIN textbook_companion_book_main_subcategories + tcbm ON pe.id = tcbm.pref_id LEFT JOIN list_of_category + loc ON tcbm.main_category = loc.category_id WHERE + po.proposal_status = 3 AND pe.approval_status = 1 + AND pe.id = tcbm.pref_id AND + pe.cloud_pref_err_status = 0 AND + pe.id=%s""", [book_id]) + books = list(books) + + if len(books) == 0: + catg_all = catg(None, all_cat=True) + context = { + 'catg': catg_all, + 'err_msg': """This book is not supported by Scilab on Cloud.""" + """ You are redirected to home page.""" + } + + template = loader.get_template('index.html') + return HttpResponse(template.render(context, request)) + + books = get_books(books[0].sub_category) + maincat_id = books[0].category_id + subcat_id = books[0].sub_category + request.session['maincat_id'] = maincat_id + request.session['subcategory_id'] = subcat_id + request.session['book_id'] = book_id + chapters = get_chapters(book_id) + subcateg_all = TextbookCompanionSubCategoryList.objects\ + .using('r').filter(maincategory_id=maincat_id)\ + .order_by('subcategory_id') + categ_all = TextbookCompanionCategoryList.objects.using('r')\ + .filter(~Q(category_id=0)).order_by('maincategory') + context = { + 'catg': categ_all, + 'subcatg': subcateg_all, + 'maincat_id': maincat_id, + 'chapters': chapters, + 'subcategory_id': books[0].sub_category, + 'books': books, + 'book_id': int(book_id), + + } + template = loader.get_template('index.html') + return HttpResponse(template.render(context, request)) + else: + try: + eid = int(request.GET['eid']) + except ValueError: + context = { + 'catg': catg_all, + 'err_msg': """This example is currently not available on """ + """scilab on cloud.""" + } + template = loader.get_template('index.html') + return HttpResponse(template.render(context, request)) + + if eid: + try: + with connections['r'].cursor() as cursor: + cursor.execute(GET_TBC_EXAMPLE_R_CLOUD_COMMENT_SQL, + params=[eid]) + review = cursor.fetchone() + review_url = "https://r.fossee.in/cloud_comments/" + str(eid) + + with connections['r'].cursor() as cursor: + cursor.execute(GET_TBC_EXAMPLE_CHAPTER_ID_SQL, + params=[eid]) + chapter_id = cursor.fetchone() + + with connections['r'].cursor() as cursor: + cursor.execute(GET_TBC_CHAPTER_DETAIL_SQL, + params=[chapter_id[0]]) + chapters = dictfetchall(cursor) + + with connections['r'].cursor() as cursor: + cursor.execute(GET_TBC_CHAPTER_PREFERENCE_ID_SQL, + params=[chapter_id[0]]) + preference_id = cursor.fetchone() + with connections['r'].cursor() as cursor: + cursor.execute(GET_TBC_PREFERENCE_DETAIL_CATEGORY_SQL, + params=[preference_id[0]]) + books_detail = cursor.fetchone() + books = get_books(books_detail[1]) + maincat_id = books_detail[0] + subcat_id = books_detail[1] + + + with connections['r'].cursor() as cursor: + cursor.execute(GET_TBC_EXAMPLE_FILE_SQL, + params=[eid]) + example_file = cursor.fetchone() + example_file_filepath = example_file[4] + '/' + example_file[5] + with connections['r'].cursor() as cursor: + cursor.execute(GET_TBC_EXAMPLE_VIEW_SQL, + params=[eid]) + ex_views_count = cursor.fetchone() + + request.session['maincat_id'] = maincat_id + request.session['subcategory_id'] = subcat_id + request.session['book_id'] = preference_id[0] + request.session['chapter_id'] = chapter_id[0] + request.session['example_id'] = eid + request.session['example_file_id'] = example_file[3] + request.session['filepath'] = example_file_filepath + + revisions = get_revisions(eid) + code = get_code(example_file_filepath, revisions[0][1]) + request.session['commit_sha'] = revisions[0][1] + + except IndexError: + categ_all = TextbookCompanionCategoryList.objects\ + .using('r').filter(~Q(category_id=0))\ + .order_by('maincategory') + context = { + 'catg': categ_all, + 'err_msg': """This example is currently not available on""" + """ scilab on cloud.""" + } + template = loader.get_template('index.html') + return HttpResponse(template.render(context, request)) + subcateg_all = TextbookCompanionSubCategoryList.objects\ + .using('r').filter(maincategory_id=maincat_id)\ + .order_by('subcategory_id') + categ_all = TextbookCompanionCategoryList.objects.using('r')\ + .filter(~Q(category_id=0)).order_by('maincategory') + if len(list([ex_views_count[0]])) == 0: + ex_views_count = 0 + else: + ex_views_count = ex_views_count[0] + context = { + 'catg': categ_all, + 'subcatg': subcateg_all, + 'maincat_id': maincat_id, + 'subcategory_id': subcat_id, + 'books': list(books), + 'book_id': preference_id[0], + 'chapters': chapters, + 'chapter_id': chapter_id[0], + 'examples': get_examples(chapter_id[0]), + 'eid': eid, + 'revisions': revisions, + 'commit_sha': revisions[0][1], + 'code': code, + 'ex_views_count': ex_views_count, + 'review': review[0], + 'review_url': review_url, + } + + # if not user.is_anonymous(): + # context['user'] = user + + template = loader.get_template('index.html') + return HttpResponse(template.render(context, request)) + +def update_view_count(request): + ex_id = request.GET.get('ex_id') + with connections['r'].cursor() as cursor: + cursor.execute(GET_TBC_CHAPTER_ID_SQL, params=[ex_id]) + Example_chapter_id = cursor.fetchone() + with connections['r'].cursor() as cursor: + cursor.execute(INSERT_TBC_EXAMPLE_VIEW_SQL, + params=[ex_id,Example_chapter_id[0]]) + with connections['r'].cursor() as cursor: + cursor.execute(UPDATE_TBC_EXAMPLE_VIEW_SQL, + params=[ex_id]) + with connections['r'].cursor() as cursor: + cursor.execute(GET_TBC_EXAMPLE_VIEW_SQL, + params=[ex_id]) + Example_views_count = cursor.fetchone() + data = Example_views_count[0] + return HttpResponse(simplejson.dumps(data), + content_type='application/json') |