version 1.575, 2022/02/27 01:43:13
|
version 1.578, 2023/06/02 01:20:28
|
Line 306 my %trust = (
|
Line 306 my %trust = (
|
servertimezone => {remote => 1, enroll => 1}, |
servertimezone => {remote => 1, enroll => 1}, |
setannounce => {remote => 1, domroles => 1}, |
setannounce => {remote => 1, domroles => 1}, |
sethost => {anywhere => 1}, |
sethost => {anywhere => 1}, |
|
signlti => {remote => 1}, |
store => {remote => 1, enroll => 1, reqcrs => 1,}, |
store => {remote => 1, enroll => 1, reqcrs => 1,}, |
studentphoto => {remote => 1, enroll => 1}, |
studentphoto => {remote => 1, enroll => 1}, |
sub => {content => 1,}, |
sub => {content => 1,}, |
Line 865 sub PushFile {
|
Line 866 sub PushFile {
|
|
|
if($filename eq "host") { |
if($filename eq "host") { |
$contents = AdjustHostContents($contents); |
$contents = AdjustHostContents($contents); |
} elsif (($filename eq 'dns_host') || ($filename eq 'dns_domain') || |
} elsif (($filename eq 'dns_hosts') || ($filename eq 'dns_domain') || |
($filename eq 'loncapaCAcrl')) { |
($filename eq 'loncapaCAcrl')) { |
if ($contents eq '') { |
if ($contents eq '') { |
&logthis('<font color="red"> Pushfile: unable to install ' |
&logthis('<font color="red"> Pushfile: unable to install ' |
Line 5307 sub lti_handler {
|
Line 5308 sub lti_handler {
|
®ister_handler("lti", \<i_handler, 1, 1, 0); |
®ister_handler("lti", \<i_handler, 1, 1, 0); |
|
|
# |
# |
|
# LTI data for launch payload (received encrypted) are unencrypted and |
|
# then signed with the appropriate key and secret, before re-encrypting |
|
# for sending as the signed payload to the client (caller lonnet::sign_lti()). |
|
# |
|
# Parameters: |
|
# $cmd - Command request keyword (signlti). |
|
# $tail - Tail of the command. This is a colon-separated list |
|
# consisting of the domain, coursenum (if for an External |
|
# Tool defined in a course), crsdef (true if defined in |
|
# a course), context (launch, roster, logout, or grade), |
|
# escaped launch URL, numeric ID of external tool, |
|
# version number for encryption key (if tool's LTI secret was |
|
# encrypted before storing), a frozen hash of LTI launch |
|
# parameters, and a frozen hash of LTI information, |
|
# (e.g., method => 'HMAC-SHA1', |
|
# respfmt => 'to_authorization_header'). |
|
# $client - File descriptor open on the client. |
|
# Returns: |
|
# 1 - Continue processing. |
|
# 0 - Exit. |
|
# Side effects: |
|
# The reply will contain the LTI payload, as & separated key=value pairs, |
|
# where value is itself a frozen hash, if the required key and secret |
|
# for the apecific tool ID are available. The payload data are retrived from |
|
# a call to Lond::sign_lti_payload(), and the reply is encrypted before being |
|
# written to $client. |
|
# |
|
sub sign_lti_handler { |
|
my ($cmd, $tail, $client) = @_; |
|
|
|
my $userinput = "$cmd:$tail"; |
|
|
|
my ($cdom,$cnum,$crsdef,$context,$escurl,$ltinum,$keynum,$paramsref,$inforef) = split(/:/,$tail); |
|
my $url = &unescape($escurl); |
|
my $params = &Apache::lonnet::thaw_unescape($paramsref); |
|
my $info = &Apache::lonnet::thaw_unescape($inforef); |
|
my $res = |
|
&LONCAPA::Lond::sign_lti_payload($cdom,$cnum,$crsdef,$context,$url,$ltinum,$keynum, |
|
$perlvar{'lonVersion'},$params,$info); |
|
my $result; |
|
if (ref($res) eq 'HASH') { |
|
foreach my $key (keys(%{$res})) { |
|
$result .= &escape($key).'='.&Apache::lonnet::freeze_escape($res->{$key}).'&'; |
|
} |
|
$result =~ s/\&$//; |
|
} else { |
|
$result = $res; |
|
} |
|
if ($result =~ /^error:/) { |
|
&Failure($client, \$result, $userinput); |
|
} else { |
|
if ($cipher) { |
|
my $cmdlength=length($result); |
|
$result.=" "; |
|
my $encres=''; |
|
for (my $encidx=0;$encidx<=$cmdlength;$encidx+=8) { |
|
$encres.= unpack("H16", |
|
$cipher->encrypt(substr($result, |
|
$encidx, |
|
8))); |
|
} |
|
&Reply( $client,"enc:$cmdlength:$encres\n",$userinput); |
|
} else { |
|
&Failure( $client, "error:no_key\n",$userinput); |
|
} |
|
} |
|
return 1; |
|
} |
|
®ister_handler("signlti", \&sign_lti_handler, 1, 1, 0); |
|
|
|
# |
# Puts an id to a domains id database. |
# Puts an id to a domains id database. |
# |
# |
# Parameters: |
# Parameters: |