Diff for /loncom/auth/lonlogin.pm between versions 1.158.2.13.2.6 and 1.158.2.13.2.7

version 1.158.2.13.2.6, 2022/07/08 15:43:51 version 1.158.2.13.2.7, 2022/08/30 12:28:08
Line 659  function enableInput() { Line 659  function enableInput() {
 ENDSCRIPT  ENDSCRIPT
   
     my ($lonhost_in_use,@hosts,%defaultdomconf,$saml_prefix,$saml_landing,      my ($lonhost_in_use,@hosts,%defaultdomconf,$saml_prefix,$saml_landing,
         $samlssotext,$samlnonsso,$samlssoimg,$samlssoalt,$samlssourl,$samltooltip);          $samlssotext,$samlnonsso,$samlssoimg,$samlssoalt,$samlssourl,$samltooltip,
           $samlwindow);
     %defaultdomconf = &Apache::loncommon::get_domainconf($defdom);      %defaultdomconf = &Apache::loncommon::get_domainconf($defdom);
     @hosts = &Apache::lonnet::current_machine_ids();      @hosts = &Apache::lonnet::current_machine_ids();
     $lonhost_in_use = $lonhost;      $lonhost_in_use = $lonhost;
Line 680  ENDSCRIPT Line 681  ENDSCRIPT
         $samlssoalt = $defaultdomconf{$saml_prefix.'alt_'.$lonhost_in_use};          $samlssoalt = $defaultdomconf{$saml_prefix.'alt_'.$lonhost_in_use};
         $samlssourl = $defaultdomconf{$saml_prefix.'url_'.$lonhost_in_use};          $samlssourl = $defaultdomconf{$saml_prefix.'url_'.$lonhost_in_use};
         $samltooltip = $defaultdomconf{$saml_prefix.'title_'.$lonhost_in_use};          $samltooltip = $defaultdomconf{$saml_prefix.'title_'.$lonhost_in_use};
           $samlwindow = $defaultdomconf{$saml_prefix.'window_'.$lonhost_in_use};
     }      }
     if ($saml_landing) {      if ($saml_landing) {
        if ($samlssotext eq '') {         if ($samlssotext eq '') {
Line 867  HEADER Line 869  HEADER
   
     my $stdauthformstyle = 'inline-block';      my $stdauthformstyle = 'inline-block';
     my $ssoauthstyle = 'none';      my $ssoauthstyle = 'none';
       my $sso_onclick;
     my $logintype;      my $logintype;
     $r->print('<div style="float:left;margin-top:0;">');      $r->print('<div style="float:left;margin-top:0;">');
     if ($saml_landing) {      if ($saml_landing) {
Line 877  HEADER Line 880  HEADER
         if ($samlssourl  ne '') {          if ($samlssourl  ne '') {
             $ssologin = $samlssourl;              $ssologin = $samlssourl;
         }          }
           my $ssologin_for_js = &js_escape($ssologin);
           my $querystr_for_js;
         if (($logtoken eq 'con_lost') || ($logtoken eq 'no_such_host')) {          if (($logtoken eq 'con_lost') || ($logtoken eq 'no_such_host')) {
             my $querystring;              my $querystring;
             if ($env{'form.firsturl'} ne '') {              if ($env{'form.firsturl'} ne '') {
Line 897  HEADER Line 902  HEADER
             }              }
             if ($querystring ne '') {              if ($querystring ne '') {
                 $ssologin .= (($ssologin=~/\?/)?'&amp;':'?') . $querystring;                  $ssologin .= (($ssologin=~/\?/)?'&amp;':'?') . $querystring;
                   $querystr_for_js = &js_escape($querystring);
             }              }
         } elsif ($logtoken ne '') {          } elsif ($logtoken ne '') {
             $ssologin .= (($ssologin=~/\?/)?'&amp;':'?') . 'logtoken='.$logtoken;              $ssologin .= (($ssologin=~/\?/)?'&amp;':'?') . 'logtoken='.$logtoken;
               $querystr_for_js = &js_escape('logtoken='.$logtoken);
         }          }
         my $ssohref;          my $ssohref;
           if ($samlwindow) {
               $sso_onclick = <<"ENDJS";
   if (document.getElementById('LC_sso_login_link')) {
       var ssoelem = document.getElementById('LC_sso_login_link')
       ssoelem.addEventListener('click',samlWinFunction,false);
       var windows = {};
       function samlWinFunction(evt) {
           evt.preventDefault();
           var url = '$ssologin_for_js';
           var name = 'lcssowin';
           var querystr = '$querystr_for_js';
           if (querystr) {
               url += '?'+querystr+'&lcssowin=1';
           } else {
               url += '?lcssowin=1';
           }
           if ((typeof windows[name] !== 'undefined') && (!windows[name].closed)) {
               windows[name].close();
           }
           windows[name]=window.open(url,name,'width=350,height=600');
           windows[name].focus();
           return false;
       }
   }
   ENDJS
           }
         if ($samlssoimg ne '') {          if ($samlssoimg ne '') {
             $ssohref = '<a href="'.$ssologin.'" title="'.$samltooltip.'">'.              $ssohref = '<a href="'.$ssologin.'" title="'.$samltooltip.'" id="LC_sso_login_link">'.
                        '<img src="'.$samlssoimg.'" alt="'.$samlssoalt.'" id="lcssobutton" /></a>';                         '<img src="'.$samlssoimg.'" alt="'.$samlssoalt.'" id="lcssobutton" /></a>';
         } else {          } else {
             $ssohref = '<a href="'.$ssologin.'">'.$samlssotext.'</a>';              $ssohref = '<a href="'.$ssologin.'" id="LC_sso_login_link">'.$samlssotext.'</a>';
         }          }
         if (($env{'form.saml'} eq 'no') ||          if (($env{'form.saml'} eq 'no') ||
             (($env{'form.username'} ne '') && ($env{'form.domain'} ne ''))) {              (($env{'form.username'} ne '') && ($env{'form.domain'} ne ''))) {
Line 961  ENDTARG Line 994  ENDTARG
 // <![CDATA[  // <![CDATA[
 if ((window.self !== window.top) && (document.server.target != '_self')) {  if ((window.self !== window.top) && (document.server.target != '_self')) {
     $set_target      $set_target
       $sso_onclick
 }  }
 // ]]>  // ]]>
 </script>  </script>
 ENDJS  ENDJS
         }          }
       } elsif ($samlwindow) {
           $in_frame_js = <<ENDJS;
   <script type="text/javascript">
   // <![CDATA[
   if ((window.self !== window.top) && (document.server.target != '_self')) {
       $sso_onclick
   }
   // ]]>
   </script>
   ENDJS
     }      }
   
     $r->print(<<ENDLOGIN);      $r->print(<<ENDLOGIN);

Removed from v.1.158.2.13.2.6  
changed lines
  Added in v.1.158.2.13.2.7


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>