summaryrefslogtreecommitdiff
path: root/yaksh/views.py
diff options
context:
space:
mode:
authorprathamesh2017-11-14 17:27:05 +0530
committerprathamesh2017-11-14 17:27:05 +0530
commit8bbcd2163c20bc3bd7b501d108ede59614deced5 (patch)
tree5d762bbd6ecdc400b71af1f805fafe5628d29fe7 /yaksh/views.py
parent1b456a3d0ee1edd1a05d7d0fa08c074f26454d04 (diff)
downloadonline_test-8bbcd2163c20bc3bd7b501d108ede59614deced5.tar.gz
online_test-8bbcd2163c20bc3bd7b501d108ede59614deced5.tar.bz2
online_test-8bbcd2163c20bc3bd7b501d108ede59614deced5.zip
Added sample csv for user to download and upload.
Diffstat (limited to 'yaksh/views.py')
-rw-r--r--yaksh/views.py41
1 files changed, 27 insertions, 14 deletions
diff --git a/yaksh/views.py b/yaksh/views.py
index 8d965f1..c46329f 100644
--- a/yaksh/views.py
+++ b/yaksh/views.py
@@ -37,7 +37,7 @@ from yaksh.models import (
HookTestCase, IntegerTestCase, McqTestCase, Profile,
QuestionPaper, QuestionSet, Quiz, Question, StandardTestCase,
StdIOBasedTestCase, StringTestCase, TestCase, User,
- get_model_class
+ get_model_class, FIXTURES_DIR_PATH
)
from yaksh.forms import (
UserRegisterForm, UserLoginForm, QuizForm, QuestionForm,
@@ -1912,14 +1912,12 @@ def _read_user_csv(reader, course):
continue
user_defaults = {'email': email, 'first_name': first_name,
'last_name': last_name}
- user, created = _create_or_update_user(username, user_defaults)
+ user, created = _create_or_update_user(username, password, user_defaults)
profile_defaults = {'institute': institute, 'roll_number': roll_no,
'department': department, 'is_email_verified': True}
_create_or_update_profile(user, profile_defaults)
if created:
state = "Added"
- user.set_password(password)
- user.save()
course.students.add(user)
else:
state = "Updated"
@@ -1936,12 +1934,10 @@ def _get_csv_values(row, fields):
email, first_name, last_name = map(str.strip, [row['email'],
row['firstname'],
row['lastname']])
- if 'password' in fields:
+ password = email
+ username = email
+ if 'password' in fields and row['password']:
password = row['password'].strip()
- if not password:
- password = email
- else:
- password = email
if 'roll_no' in fields:
roll_no = row['roll_no'].strip()
if 'institute' in fields:
@@ -1950,10 +1946,8 @@ def _get_csv_values(row, fields):
department = row['department'].strip()
if 'remove' in fields:
remove = row['remove'].strip()
- if 'username' in fields:
+ if 'username' in fields and row['username']:
username = row['username'].strip()
- else:
- username = email
if 'remove' in fields:
remove = row['remove']
return (username, email, first_name, last_name, password, roll_no, institute,
@@ -1972,8 +1966,12 @@ def _add_to_course(user, course):
return True
-def _create_or_update_user(username, defaults):
- return User.objects.update_or_create(username=username, defaults=defaults)
+def _create_or_update_user(username, password, defaults):
+ user, created = User.objects.update_or_create(username=username,
+ defaults=defaults)
+ user.set_password(password)
+ user.save()
+ return user, created
def _create_or_update_profile(user, defaults):
@@ -1982,6 +1980,21 @@ def _create_or_update_profile(user, defaults):
@login_required
@email_verified
+def download_sample_csv(request):
+ user = request.user
+ if not is_moderator(user):
+ raise Http404('You are not allowed to view this page!')
+ csv_file_path = os.path.join(FIXTURES_DIR_PATH,
+ "sample_user_upload.csv")
+ with open(csv_file_path, 'rb') as csv_file:
+ response = HttpResponse(csv_file.read(), content_type='text/csv')
+ response['Content-Disposition'] = 'attachment;\
+ filename="sample_user_upload"'
+ return response
+
+
+@login_required
+@email_verified
def duplicate_course(request, course_id):
user = request.user
course = get_object_or_404(Course, pk=course_id)