public function getSetOfUsersMilestoneInfo($experienceInstanceId, $userIds) { //init experience variables $experienceInstance = ExperienceModel::find($experienceInstanceId); $maxExperiencePts = $experienceInstance->total_points; $utcTimeZone = new DateTimeZone('UTC'); $stDate = $experienceInstance->start_date->setTimezone($utcTimeZone); $endDate = $experienceInstance->end_date->setTimezone($utcTimeZone); $expComponent = new ExperienceComponent(); $ptsPerSecond = $expComponent->getPtsPerSecond($stDate, $endDate, $experienceInstance->total_points); $bonusPerSecond = $experienceInstance->bonus_per_day / 24 / 60 / 60; $bonusSeconds = $experienceInstance->bonus_days * 24 * 60 * 60; $penaltyPerSecond = $experienceInstance->penalty_per_day / 24 / 60 / 60; $penaltySeconds = $experienceInstance->penalty_days * 24 * 60 * 60; //get milestones $expComponent = new ExperienceComponent(); $milestonesOrderedByPointsDesc = $expComponent->getMilestonesOrderedByPointsDesc($experienceInstanceId); //get grading standards if (is_null($this->roots)) { $this->roots = new Roots(); } $standards = $this->roots->getGradingStandards(); $grading_scheme = $standards[0]->grading_scheme; //get all students in course $dbHelper = new DbHelper(); if (!isset($_SESSION)) { session_start(); } $courseId = $_SESSION['courseID']; $users = $dbHelper->getUsersInCourseWithRole($courseId, 'Learner'); $filteredUsers = array(); foreach ($userIds as $userId) { $res = array_values(array_filter($users->toArray(), function ($elem) use($userId) { return intval($elem['user']['user_id']) === intval($userId); })); $filteredUsers = array_merge($filteredUsers, $res); } $masterArr = array(); foreach ($filteredUsers as $user) { $item = $this->getUserMilestoneInfo($user['user'], $milestonesOrderedByPointsDesc, $ptsPerSecond, $stDate, $endDate, $bonusPerSecond, $bonusSeconds, $penaltyPerSecond, $penaltySeconds, $maxExperiencePts, $grading_scheme); $masterArr[] = $item; } return $masterArr; }
public function doBltiHandshake() { //first obtain the details of the LTI configuration they chose $dbHelper = new DbHelper(); $instanceFromDB = LtiConfigurations::find($this->property('ltiInstance')); $approver = $this->property('approver'); $arr = $this->getApproverOptions(); $approverRole = $arr[$approver]; if (!isset($_SESSION)) { session_start(); } $_SESSION['baseUrl'] = Config::get('app.url', 'backend'); $_SESSION['courseID'] = \Input::get('custom_canvas_course_id'); $_SESSION['userID'] = \Input::get('custom_canvas_user_id'); $_SESSION['domain'] = \Input::get('custom_canvas_api_domain'); //TODO: make sure this parameter below works with all other LMSs $_SESSION['lms'] = \Input::get('tool_consumer_info_product_family_code'); //check to see if user is an Instructor $rolesStr = \Input::get('roles'); $consumerKey = $instanceFromDB['ConsumerKey']; $clientId = $instanceFromDB['DeveloperId']; //Check to see if the lti handshake passes $context = new Blti($consumerKey, false, false); if ($context->valid) { // query DB to see if user has token, if yes, go to LTI. $userCheck = $dbHelper->getCourseApprover($_SESSION['courseID']); if (!$userCheck) { //if no user is found, redirect to canvas permission page if (stristr($rolesStr, $approverRole)) { //As per my discussion with Jared, we will use the instructor's token only. This is the token that will be stored in the DB //and the one that will be used to make all requests. We will NOT store student's tokens. //TODO: take this redirectUri out into some parameter somewhere... $redirectUri = "{$_SESSION['baseUrl']}saveUserInfo?lti={$this->property('ltiInstance')}"; $url = "https://{$_SESSION['domain']}/login/oauth2/auth?client_id={$clientId}&response_type=code&redirect_uri={$redirectUri}"; $this->redirect($url); } else { echo "A(n) {$approverRole} must authorize this course. Please contact your instructor."; return; } } else { //set the professor's token $_SESSION['userToken'] = $userCheck->encrypted_token; //get the timezone $roots = new Roots(); $course = $roots->getCourse(); $account_id = $course->account_id; $account = $roots->getAccount($account_id); $courseId = $_SESSION['courseID']; $_SESSION['timezone'] = new \DateTimeZone($account->default_time_zone); //to maintain the users table synchronized with Canvas, everytime a student comes in we'll check to make sure they're in the DB. //If they're not, we will pull all the students from Canvas and refresh our users table. $dbHelper = new DbHelper(); $user = $dbHelper->getUserInCourse($courseId, $_SESSION['userID']); if (is_null($user)) { //get all students from Canvas $roots = new Roots(); $roots->getStudentsInCourse(); } //Also, every so often (every 12 hrs?) we will check to make sure that students who have dropped the class are deleted from the users_course table //Failing to do so will make it so that when we request their submissions along with other students' submissions, the entire // call returns with an Unauthorized error message $approver = $dbHelper->getCourseApprover($courseId); $now = Carbon::now(); $updatedDate = $approver->updated_at; $diff = $updatedDate->diffInHours($now, false); if ($diff > 24) { $allStudentsDb = $dbHelper->getUsersInCourseWithRole($_SESSION['courseID'], 'Learner'); $allStudentsFromCanvas = $roots->getStudentsInCourse(); foreach ($allStudentsDb as $dbStudent) { $filteredItems = array_values(array_filter($allStudentsFromCanvas, function ($elem) use($dbStudent) { return intval($elem->user_id) === intval($dbStudent->user_id); })); if (count($filteredItems) < 1) { $dbHelper->deleteUserFromRole($courseId, $dbStudent->user_id, 'Learner'); } } //update the approver $approver->updated_at = $now; $approver->save(); } } } else { echo 'There is a problem. Please notify your instructor'; } }