--- loncom/lti/ltiutils.pm 2024/02/27 04:13:34 1.17.2.5 +++ loncom/lti/ltiutils.pm 2024/11/21 07:26:04 1.22 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA -# Utility functions for managing LON-CAPA LTI interactions +# Utility functions for managing LON-CAPA LTI interactions # -# $Id: ltiutils.pm,v 1.17.2.5 2024/02/27 04:13:34 raeburn Exp $ +# $Id: ltiutils.pm,v 1.22 2024/11/21 07:26:04 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -34,7 +34,7 @@ use Digest::SHA; use Digest::MD5 qw(md5_hex); use Encode; use UUID::Tiny ':std'; -use LWP::UserAgent(); +use HTTP::Status; use Apache::lonnet; use Apache::loncommon; use Apache::loncoursedata; @@ -55,13 +55,13 @@ use LONCAPA qw(:DEFAULT :match); # When LON-CAPA is operating as a Consumer, nonce checking # occurs when a Tool Provider launched from an instance of # an external tool in a LON-CAPA course makes a request to -# (a) /adm/service/roster or (b) /adm/service/passback to, -# respectively, retrieve a roster or store the grade for +# (a) /adm/service/roster or (b) /adm/service/passback to, +# respectively, retrieve a roster or store the grade for # the original launch by a specific user. # -# When LON-CAPA is operating as a Provider, nonce checking -# occurs when a user in course context in another LMS (the -# Consumer) launches an external tool to access a LON-CAPA URL: +# When LON-CAPA is operating as a Provider, nonce checking +# occurs when a user in course context in another LMS (the +# Consumer) launches an external tool to access a LON-CAPA URL: # /adm/lti/ with LON-CAPA symb, map, or deep-link ID appended. # @@ -359,9 +359,9 @@ sub verify_lis_item { # LON-CAPA as LTI Consumer # # Sign a request used to launch an instance of an external -# tool in a LON-CAPA course, using the key and secret supplied +# tool in a LON-CAPA course, using the key and secret supplied # by the Tool Provider. -# +# sub sign_params { my ($url,$key,$secret,$paramsref,$sigmethod,$type,$callback,$post) = @_; @@ -693,9 +693,7 @@ sub get_roster { ? join("&$name=", map {escape($_) } @{$hashref->{$_}}) : &escape($hashref->{$_}) ); } keys(%{$hashref}))); - my $ua=new LWP::UserAgent; - $ua->timeout(10); - my $response=$ua->request($request); + my $response = &LONCAPA::LWPReq::makerequest('',$request,'','',10); my $message=$response->status_line; if (($response->is_success) && ($response->content ne '')) { my %data = (); @@ -761,7 +759,7 @@ sub send_grade { if ($sigmethod eq '') { $sigmethod = 'HMAC-SHA1'; } - my $request; + my ($request,$sendit,$respcode,$result); if ($msgformat eq '1.0') { my $date = &Apache::loncommon::utc_string(time); my %ltiparams = ( @@ -788,7 +786,7 @@ sub send_grade { ? join("&$name=", map {escape($_) } @{$hashref->{$_}}) : &escape($hashref->{$_}) ); } keys(%{$hashref}))); -#FIXME Need to handle case where passback failed. + $sendit = 1; } } else { srand( time() ^ ($$ + ($$ << 15)) ); # Seed rand. @@ -845,13 +843,16 @@ END ], $gradexml, ); - my $ua=new LWP::UserAgent; - $ua->timeout(10); - my $response=$ua->request($request); - my $message=$response->status_line; -#FIXME Handle case where pass back of score to LTI Consumer failed. + $sendit = 1; } } + if ($sendit) { + my $response = &LONCAPA::LWPReq::makerequest('',$request,'','',10); + my $message=$response->status_line; + $respcode = $response->code; + $result = HTTP::Status::status_message($respcode); + } + return ($sendit,$score,$respcode,$result); } sub setup_logout_callback { @@ -873,11 +874,9 @@ sub setup_logout_callback { &Apache::lonnet::sign_lti($cdom,$cnum,$crstool,'lti','logout',$service_url,$idx, $keynum,\%ltiparams,\%info); if (($status eq 'ok') && ($post ne '')) { - my $ua=new LWP::UserAgent; - $ua->timeout(10); my $request=new HTTP::Request('POST',$service_url); $request->content($post); - my $response=$ua->request($request); + my $response = &LONCAPA::LWPReq::makerequest('',$request,'','',10); } } } @@ -887,7 +886,7 @@ sub setup_logout_callback { # # LON-CAPA as LTI Provider # -# Create a new user in LON-CAPA. If the domain's configuration +# Create a new user in LON-CAPA. If the domain's configuration # includes rules for format of "official" usernames, those rules # will apply when determining if a user is to be created. In # additional if institutional user information is available that @@ -1028,7 +1027,7 @@ sub create_passwd { # in the Consumer, user privs will be added to the user's environment for # the new role. # -# If this is a self-enroll case, a Course Coordinator role will only be assigned +# If this is a self-enroll case, a Course Coordinator role will only be assigned # if the current user is also the course owner. # @@ -1320,7 +1319,7 @@ sub batchaddroster { # # Which LON-CAPA roles are assignable by the current user # and how LTI roles map to LON-CAPA roles (as defined in -# the domain configuration for the specific Consumer) are +# the domain configuration for the specific Consumer) are # factored in when compiling the list of available roles. # # Inputs: 3