From dd36beb6333d6bc6ab35c29d094a92e8c982680c Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Andreas=20=C3=85kre=20Solberg?= <andreas.solberg@uninett.no>
Date: Fri, 15 Feb 2008 10:45:31 +0000
Subject: [PATCH] Automatically generation of shibboleth sp and idp metadata,
 improvement to the metadata generation. And improvement to the frontpage
 (adding enablematrix and links to documentation)

git-svn-id: https://simplesamlphp.googlecode.com/svn/trunk@311 44740490-163a-0410-bde0-09ae8108e29a
---
 templates/default/en/frontpage.php |  72 ++++++++++++++++++-----
 templates/default/en/metadata.php  |  10 ++--
 www/index.php                      |  87 +++++++++++++++++++++------
 www/resources/default.css          |  19 +++++-
 www/resources/icons/accept.png     | Bin 0 -> 781 bytes
 www/resources/icons/delete.png     | Bin 0 -> 715 bytes
 www/saml2/idp/metadata.php         |  32 +++++-----
 www/saml2/sp/metadata.php          |  31 ++++++----
 www/shib13/idp/metadata.php        |  91 ++++++++++++-----------------
 www/shib13/sp/metadata.php         |  86 +++++++++++----------------
 10 files changed, 254 insertions(+), 174 deletions(-)
 create mode 100755 www/resources/icons/accept.png
 create mode 100755 www/resources/icons/delete.png

diff --git a/templates/default/en/frontpage.php b/templates/default/en/frontpage.php
index bc2ff455f..909e4cfe1 100644
--- a/templates/default/en/frontpage.php
+++ b/templates/default/en/frontpage.php
@@ -5,9 +5,34 @@
 
 	<div id="content">
 
-		<h2>Welcome to simpleSAMlphp</h2>
+<div class="enablebox">
+<table>
+
+<?php
+
+$icon_enabled  = '<img src="/' . $data['baseurlpath'] . 'resources/icons/accept.png" alt="enabled" />';
+$icon_disabled = '<img src="/' . $data['baseurlpath'] . 'resources/icons/delete.png" alt="disabled" />';
+?>
+
+<tr class="<?php echo $this->data['enablematrix']['saml20-sp'] ? 'enabled' : 'disabled'; ?>"><td>SAML 2.0 SP</td>
+	<td><?php echo $this->data['enablematrix']['saml20-sp'] ? $icon_enabled : $icon_disabled; ?></td></tr>
+	
+<tr class="<?php echo $this->data['enablematrix']['saml20-idp'] ? 'enabled' : 'disabled'; ?>"><td>SAML 2.0 IdP</td>
+	<td><?php echo $this->data['enablematrix']['saml20-idp'] ? $icon_enabled : $icon_disabled; ?></td></tr>
+	
+<tr class="<?php echo $this->data['enablematrix']['shib13-sp'] ? 'enabled' : 'disabled'; ?>"><td>Shib 1.3 SP</td>
+	<td><?php echo $this->data['enablematrix']['shib13-sp'] ? $icon_enabled : $icon_disabled; ?></td></tr>
+	
+<tr class="<?php echo $this->data['enablematrix']['shib13-idp'] ? 'enabled' : 'disabled'; ?>"><td>Shib 1.3 IdP</td>
+	<td><?php echo $this->data['enablematrix']['shib13-idp'] ? $icon_enabled : $icon_disabled; ?></td></tr>
+	
+</table>
+</div>
+
+
+		<p><strong>Congratulations</strong>, you have successfully installed simpleSAMLphp. This is the start page of your installation, where you will find links to test examples, diagnostics, metadata and even links to relevant documentation.</p>
 		
-		<p>You have installed simpleSAMLphp on this web host. Here are some relevant links for your installation:
+		<h2>Useful links for your installation</h2>
 			<ul>
 			<?php
 			
@@ -17,23 +42,42 @@
 			?>
 			</ul>
 		</p>
-		<?php
 		
-			foreach($this->data['warnings'] AS $warning) {
-			
-			
-				echo '<div class="caution">' . $warning . '</div>';
-				
+		<h2>Metadata</h2>
+			<ul>
+			<?php
 			
+				foreach ($this->data['links_meta'] AS $link) {
+					echo '<li><a href="' . htmlspecialchars($link['href']) . '">' . htmlspecialchars($link['text']) . '</a></li>';
+				}
+			?>
+			</ul>
+		</p>
+		
+		<h2>Documentation</h2>
+			<ul>
+			<?php
 			
-			}
+				foreach ($this->data['links_doc'] AS $link) {
+					echo '<li><a href="' . htmlspecialchars($link['href']) . '">' . htmlspecialchars($link['text']) . '</a></li>';
+				}
+			?>
+			</ul>
+		</p>
 		
-		?>
-
+		<?php
+			if (array_key_exists('warnings', $this->data) && is_array($this->data['warnings']) && !empty($this->data['warnings'])) {
 
+				echo '<h2>Warnings</h2>';
+		
+				foreach($this->data['warnings'] AS $warning) {
+					echo '<div class="caution">' . $warning . '</div>';
+				}
+			}
+		?>
+		
 
-		<h2>About simpleSAMLphp</h2>
-		<p>Hey! This simpleSAMLphp thing is pretty cool, where can I read more about it?
-		You can find more information about <a href="http://rnd.feide.no/simplesamlphp">simpleSAMLphp at the Feide RnD blog</a> over at <a href="http://uninett.no">UNINETT</a>.</p>
+	<h2>About simpleSAMLphp</h2>
+		<p>Hey! This simpleSAMLphp thing is pretty cool, where can I read more about it? You can find more information about <a href="http://rnd.feide.no/simplesamlphp">simpleSAMLphp at the Feide RnD blog</a> over at <a href="http://uninett.no">UNINETT</a>.</p>
 		
 <?php $this->includeAtTemplateBase('includes/footer.php'); ?>
\ No newline at end of file
diff --git a/templates/default/en/metadata.php b/templates/default/en/metadata.php
index 704e1799d..57d48db4c 100644
--- a/templates/default/en/metadata.php
+++ b/templates/default/en/metadata.php
@@ -31,15 +31,15 @@
 			
 				<h2>Send your metadata to <?php echo $this->data['federationname']; ?></h2>
 				
-				<p>simpleSAMLphp has detected that you have configured Feide as your default IdP.</p>
+				<p>simpleSAMLphp has detected that you have configured <?php echo $this->data['federationname']; ?> as your default IdP.</p>
 				
-				<p>Before you can connect to Feide, Feide needs to add your service in its trust configuration. When you
-					contact Feide to add you as a new service, you will be asked to send your metadata. Here you can easily send
-					the metadata to Feide by clicking the button below.</p>
+				<p>Before you can connect to <?php echo $this->data['federationname']; ?>, <?php echo $this->data['federationname']; ?> needs to add your service in its trust configuration. When you
+					contact <?php echo $this->data['federationname']; ?> to add you as a new service, you will be asked to send your metadata. Here you can easily send
+					the metadata to <?php echo $this->data['federationname']; ?> by clicking the button below.</p>
 					
 				<form action="<?php echo $this->data['sendmetadatato']; ?>" method="post">
 
-					<p>Feide needs to know how to get in contact with you, so you need to type in <strong>your email address</strong>:
+					<p><?php echo $this->data['federationname']; ?> needs to know how to get in contact with you, so you need to type in <strong>your email address</strong>:
 						<input type="text" size="25" name="email" value="" />
 					</p>
 					
diff --git a/www/index.php b/www/index.php
index 9f756764e..17697b1b9 100644
--- a/www/index.php
+++ b/www/index.php
@@ -21,43 +21,26 @@ if ($config->getValue('admin.protectindexpage', false)) {
 	}
 }
 
-
 $warnings = array();
 
 if (SimpleSAML_Utilities::getSelfProtocol() != 'https') {
-	$warnings[] = '<strong>You are not using HTTPS</strong> - encrypted communication with the user. Using simpleSAMLphp will works perfectly fine on HTTP for test purposes, but if you will be using simpleSAMLphp in a production environment, you should be running it on HTTPS.';
+	$warnings[] = '<strong>You are not using HTTPS</strong> - encrypted communication with the user. Using simpleSAMLphp will works perfectly fine on HTTP for test purposes, but if you will be using simpleSAMLphp in a production environment, you should be running it on HTTPS. [ <a href="http://rnd.feide.no/content/simplesamlphp-maintenance-and-configuration">read more about simpleSAMLphp maintenance</a> ]';
 }
 
-
-
 	
 $links = array();
 
-$links[] = array(
-	'href' => 'admin/metadata.php', 
-	'text' => 'Meta data overview for your installation. Diagnose your meta data files.');
-
-if ($config->getValue('enable.saml20-sp') === true)
-	$links[] = array(
-		'href' => 'saml2/sp/metadata.php', 
-		'text' => 'SAML 2.0 Service Provider Metadata (automatically generated)');
 
 if ($config->getValue('enable.saml20-sp') === true)
 	$links[] = array(
 		'href' => 'example-simple/saml2-example.php', 
 		'text' => 'SAML 2.0 SP example - test logging in through your IdP');
 
-if ($config->getValue('enable.saml20-idp') === true)
-	$links[] = array(
-		'href' => 'saml2/idp/metadata.php', 
-		'text' => 'SAML 2.0 Identity Provider Metadata (automatically generated)');
-
 if ($config->getValue('enable.shib13-sp') === true)
 	$links[] = array(
 		'href' => 'example-simple/shib13-example.php', 
 		'text' => 'Shibboleth 1.3 SP example - test logging in through your Shib IdP');
 
-
 if ($config->getValue('enable.openid-provider') === true)
 	$links[] = array(
 		'href' => 'openid/provider/server.php', 
@@ -67,11 +50,79 @@ $links[] = array(
 	'href' => 'example-simple/hostnames.php', 
 	'text' => 'Diagnostics on hostname, port and protocol');
 
+
+
+$linksmeta = array();
+
+$linksmeta[] = array(
+	'href' => 'admin/metadata.php', 
+	'text' => 'Meta data overview for your installation. Diagnose your meta data files.');
+
+if ($config->getValue('enable.saml20-sp') === true)
+	$linksmeta[] = array(
+		'href' => 'saml2/sp/metadata.php', 
+		'text' => 'Hosted SAML 2.0 Service Provider Metadata (automatically generated)');
+
+if ($config->getValue('enable.saml20-idp') === true)
+	$linksmeta[] = array(
+		'href' => 'saml2/idp/metadata.php', 
+		'text' => 'Hosted SAML 2.0 Identity Provider Metadata (automatically generated)');
+	
+
+
+$linksdoc = array();
+
+$linksdoc[] = array(
+	'href' => 'http://rnd.feide.no/content/installing-simplesamlphp', 
+	'text' => 'Installing simpleSAMLphp');
+
+if ($config->getValue('enable.saml20-sp', false ) || $config->getValue('enable.shib13-sp', false))
+	$linksdoc[] = array(
+		'href' => 'http://rnd.feide.no/content/using-simplesamlphp-service-provider', 
+		'text' => 'Using simpleSAMLphp as a Service Provider');
+
+if ($config->getValue('enable.saml20-idp', false ) || $config->getValue('enable.shib13-idp', false))
+	$linksdoc[] = array(
+		'href' => 'http://rnd.feide.no/content/using-simplesamlphp-identity-provider', 
+		'text' => 'Using simpleSAMLphp as an Identity Provider');
+
+if ($config->getValue('enable.shib13-idp', false))
+	$linksdoc[] = array(
+		'href' => 'http://rnd.feide.no/content/configure-shibboleth-13-sp-work-simplesamlphp-idp', 
+		'text' => 'Configure Shibboleth 1.3 SP to work with simpleSAMLphp IdP');
+
+if ($config->getValue('enable.saml20-idp', false ))
+	$linksdoc[] = array(
+		'href' => 'http://rnd.feide.no/content/simplesamlphp-idp-google-apps-education', 
+		'text' => 'simpleSAMLphp as an IdP for Google Apps for Education');
+
+$linksdoc[] = array(
+	'href' => 'http://rnd.feide.no/content/simplesamlphp-advanced-features', 
+	'text' => 'simpleSAMLphp Advanced Features
+');
+
+
+
+$linksdoc[] = array(
+	'href' => 'http://rnd.feide.no/content/simplesamlphp-maintenance-and-configuration', 
+	'text' => 'simpleSAMLphp Maintenance and Configuration');
+
+$enablematrix = array(
+	'saml20-sp' => $config->getValue('enable.saml20-sp', false),
+	'saml20-idp' => $config->getValue('enable.saml20-idp', false),
+	'shib13-sp' => $config->getValue('enable.shib13-sp', false),
+	'shib13-idp' => $config->getValue('enable.shib13-idp', false),
+);
+
+
 $t = new SimpleSAML_XHTML_Template($config, 'frontpage.php');
 $t->data['header'] = 'simpleSAMLphp installation page';
 $t->data['icon'] = 'compass_l.png';
 $t->data['warnings'] = $warnings;
 $t->data['links'] = $links;
+$t->data['links_meta'] = $linksmeta;
+$t->data['links_doc'] = $linksdoc;
+$t->data['enablematrix'] = $enablematrix;
 
 $t->show();
 
diff --git a/www/resources/default.css b/www/resources/default.css
index 5d1eb0535..5b712f557 100644
--- a/www/resources/default.css
+++ b/www/resources/default.css
@@ -217,4 +217,21 @@ div.caution {
 th.rowtitle {
         text-align: left;
 }
-
+.enablebox table {
+	border: 1px solid #eee;
+	float: right;
+	margin-left: 1em;
+}
+.enablebox tr td {
+	padding: .5px 1em 1px .5em;
+	margin: 0px;
+}
+.enablebox {
+	font-size: 85%;
+}
+.enablebox tr.enabled td {
+	background: #eee;
+}
+.enablebox tr.disabled td {
+	background: #ccc;
+}
\ No newline at end of file
diff --git a/www/resources/icons/accept.png b/www/resources/icons/accept.png
new file mode 100755
index 0000000000000000000000000000000000000000..89c8129a490b329f3165f32fa0781701aab417ea
GIT binary patch
literal 781
zcmV+o1M>WdP)<h;3K|Lk000e1NJLTq000mG000mO1^@s6AM^iV00004XF*Lt006JZ
zHwB960000PbVXQnQ*UN;cVTj606}DLVr3vnZDD6+Qe|Oed2z{QJOBU!pGibPR5;6}
zlj}=UVI0T(J9f@?Yy$~oL?MENP<s_55<8j=#k?#_)7`z&He=XKi!yRv#z-kGv(##H
zPHpPc=GK%laoJHq%)RMCwPAFzZ|CgAOcEn{;0q5A&*$@du5ke3{wIG76!;E_a;FdK
zvpp$H#^e2A>4-QibtN)VXQDpczE`xXAkUjh%RI>;okxb7K@0kpyQ1k_Y(|Oe7$m(^
zNYX>mI||sUbmn+c<m#Le&eeX{US5M~t}+^~?^x|a<4hF}*!YoT8=u}L$nm5IGu=t+
z9L!Cu36!D2Ujog{8R*!Qv#Iu-h5hwCT%4+a*g~$0uam-<K;}*|sK&CQl{uILRo+uj
zOcz2iRRHx=A>3<&FnE=4u#()KBS^SH8e)Qs5i!#lY=$-1gbH6VluzU=m=EP78&5vQ
z-?+fFP-G2l&l_QzYealK$;1Rl?FkzXR&Jv<pn=v~#I9rjiy!8pnkdBB+E5h!vH2Zs
z&o03*QH;J|Cj>@fBPNjCr#AYRyJ7UJQ0v#?)7Ott=>3<sG1xL&549^BdiQDc2Rk6B
z`CZUMF*oL$(7tdPx=A_AzG_6ieU8GLKR01{dI4q5ENECkOP~(zUNfjFVrvVjw*&_H
zKpN~TcTqhdhuVD-b<^codbfbK*#?vj9*4ql0y<|7?610!ZaoaDlGr-LWGi2|kG&eR
zM}vpV9aN6yK|7oS)sPHI2Nw>`#-pV!7>9}>Q1jL)H6h&gkP@3nI=+F3nA~M>u#(n*
z8T!#8oEw&-mED4!h4s!N@Jo3S7N&Q6%6l3}nlcd~X@>;uelvPsSkXIgg~e+^T1zSf
z3SNj(5%jK~i8@b;C<CFVY6wQ4<%I<*UYM=Ou+dYcgy^ro@n7=`XV9$WdAihN00000
LNkvXXu0mjf{u*Ke

literal 0
HcmV?d00001

diff --git a/www/resources/icons/delete.png b/www/resources/icons/delete.png
new file mode 100755
index 0000000000000000000000000000000000000000..08f249365afd29594b51210c6e21ba253897505d
GIT binary patch
literal 715
zcmV;+0yO=JP)<h;3K|Lk000e1NJLTq000mG000mO1^@s6AM^iV00004XF*Lt006JZ
zHwB960000PbVXQnQ*UN;cVTj606}DLVr3vnZDD6+Qe|Oed2z{QJOBU!T}ebiR5;6}
zllx0kVHn5#Tecsf1c`2hgi%nK^D=kV+T5njvrLa$EMjSnone|mjm2E}L#U;8)yiKo
zO>C4}Mrzlg<+1Y8PEBfUp0jJpx4B>@E+cy3`^(Gw`Mf+2&yxZm<$to~Vpgvg&QKNR
z_f#1(r6svZt%iF?s+n<8X?B&!h3g9Dbb8_=MX}!;HiQSAh`bp^WMl~Z-44teO7W_Y
zV4thSL{h;rJY7!l3%5J4H1!tIzB`Dv+YxO(haWeausGZYkI8^hWj6mzo=L0{%;<E2
z80_Y*w_}NMA$su)e0B@`wrYegSP*HT5w@N{_}&f79VIb*XrKGBY>yxzh{5!Htr?51
zvG|W62MzC8BZ76hRpCyO2zOn<%e)K>NHge!-~)Ap33OdWw6hsLYbCxGNt0%wk_2z7
zfyYvXheSG)5HRK1VB~%mq7Dmurw#bi@hEcOr3&G1ZiF*$M=&9nB#VNf&Q^r$4G5kp
zTURh&s)E0%5&hyVD}sp<72~zmAY`Y(9aqO6CXF%=zFHGzO-A&I(pE}v70YQxCPJ{Y
z4L+?5-crdLn3ZRPEs!A4ehEY3ZRpL~w9>@aMN+{F4dI@v&>(QDHQum!mG~E^$OS8l
z!7?%Uwib*ROP67Hw`ika)gX-(<Pal@1N`)16#~~<@x7jghg9OTS^;mJ8T{oIOsMnG
zla<QHU?S-#Kb7w%o*dlEj!JgnOSKW+hV$`!syc>8Ia`-u_IEhxG7U<13kSsMW+$<e
xd62)I>lbb2dUMm5p6pa}cjgA+U$^mJ^AjD?&bdi)8~y+Q002ovPDHLkV1g8IMc@Dc

literal 0
HcmV?d00001

diff --git a/www/saml2/idp/metadata.php b/www/saml2/idp/metadata.php
index 560925305..0055f956d 100644
--- a/www/saml2/idp/metadata.php
+++ b/www/saml2/idp/metadata.php
@@ -58,13 +58,13 @@ try {
         WantAuthnRequestsSigned="false"
         protocolSupportEnumeration="urn:oasis:names:tc:SAML:2.0:protocol">
         
-                <KeyDescriptor use="signing">
-                        <ds:KeyInfo xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
-                          <ds:X509Data>
-                                <ds:X509Certificate>' . htmlspecialchars($data) . '</ds:X509Certificate>
-                        </ds:X509Data>
-                  </ds:KeyInfo>
-                </KeyDescriptor>  
+		<KeyDescriptor use="signing">
+			<ds:KeyInfo xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
+				<ds:X509Data>
+					<ds:X509Certificate>' . htmlspecialchars($data) . '</ds:X509Certificate>
+				</ds:X509Data>
+			</ds:KeyInfo>
+		</KeyDescriptor>  
         
 
         
@@ -103,19 +103,15 @@ try {
 
 	$defaultidp = $config->getValue('default-saml20-idp');
 	
-	$et = new SimpleSAML_XHTML_Template($config, 'metadata.php');
+	$t = new SimpleSAML_XHTML_Template($config, 'metadata.php');
 	
 
-	$et->data['header'] = 'SAML 2.0 IdP Metadata';
-	
-	$et->data['metaurl'] = SimpleSAML_Utilities::addURLparameter(SimpleSAML_Utilities::selfURLNoQuery(), 'output=xml');
-	$et->data['metadata'] = htmlentities($metaxml);
-	$et->data['metadataflat'] = htmlentities($metaflat);
-	
-	$et->data['feide'] = in_array($defaultidp, array('sam.feide.no', 'max.feide.no'));
-	$et->data['defaultidp'] = $defaultidp;
-	
-	$et->show();
+	$t->data['header'] = 'SAML 2.0 IdP Metadata';
+	$t->data['metaurl'] = SimpleSAML_Utilities::addURLparameter(SimpleSAML_Utilities::selfURLNoQuery(), 'output=xml');
+	$t->data['metadata'] = htmlentities($metaxml);
+	$t->data['metadataflat'] = htmlentities($metaflat);
+	$t->data['defaultidp'] = $defaultidp;
+	$t->show();
 	
 } catch(Exception $exception) {
 	
diff --git a/www/saml2/sp/metadata.php b/www/saml2/sp/metadata.php
index 30f27dea5..7ebe40ba1 100644
--- a/www/saml2/sp/metadata.php
+++ b/www/saml2/sp/metadata.php
@@ -73,27 +73,34 @@ try {
 	</SPSSODescriptor>
 
 </EntityDescriptor>';
+
+	if (array_key_exists('output', $_GET) && $_GET['output'] == 'xml') {
+		header('Content-Type: application/xml');
+		
+		echo $metaxml;
+		exit(0);
+	}
 	
-	$defaultidp = $config->getValue('default-saml20-idp');
 	
-	$et = new SimpleSAML_XHTML_Template($config, 'metadata.php');
+	$defaultidp = $config->getValue('default-saml20-idp');
 	
+	$t = new SimpleSAML_XHTML_Template($config, 'metadata.php');
 
-	$et->data['header'] = 'SAML 2.0 SP Metadata';
-	$et->data['metadata'] = htmlentities($metaxml);
-	$et->data['metadataflat'] = htmlentities($metaflat);
+	$t->data['header'] = 'SAML 2.0 SP Metadata';
+	$t->data['metadata'] = htmlentities($metaxml);
+	$t->data['metadataflat'] = htmlentities($metaflat);
+	$t->data['metaurl'] = SimpleSAML_Utilities::addURLparameter(SimpleSAML_Utilities::selfURLNoQuery(), 'output=xml');
 	
 	if (array_key_exists($defaultidp, $send_metadata_to_idp)) {
-		$et->data['sendmetadatato'] = $send_metadata_to_idp[$defaultidp]['address'];
-		$et->data['federationname'] = $send_metadata_to_idp[$defaultidp]['name'];
+		$t->data['sendmetadatato'] = $send_metadata_to_idp[$defaultidp]['address'];
+		$t->data['federationname'] = $send_metadata_to_idp[$defaultidp]['name'];
 	}
 
-	$et->data['techemail'] = $config->getValue('technicalcontact_email', 'na');
-	$et->data['version'] = $config->getValue('version', 'na');
-	$et->data['feide'] = in_array($defaultidp, array('sam.feide.no', 'max.feide.no'));
-	$et->data['defaultidp'] = $defaultidp;
+	$t->data['techemail'] = $config->getValue('technicalcontact_email', 'na');
+	$t->data['version'] = $config->getValue('version', 'na');
+	$t->data['defaultidp'] = $defaultidp;
 	
-	$et->show();
+	$t->show();
 	
 } catch(Exception $exception) {
 	
diff --git a/www/shib13/idp/metadata.php b/www/shib13/idp/metadata.php
index 560925305..84e0672e6 100644
--- a/www/shib13/idp/metadata.php
+++ b/www/shib13/idp/metadata.php
@@ -14,7 +14,7 @@ $config = SimpleSAML_Configuration::getInstance();
 $metadata = SimpleSAML_Metadata_MetaDataStorageHandler::getMetadataHandler();
 $session = SimpleSAML_Session::getInstance(true);
 
-if (!$config->getValue('enable.saml20-idp', false))
+if (!$config->getValue('enable.shib13-idp', false))
 	SimpleSAML_Utilities::fatalError($session->getTrackID(), 'NOACCESS');
 
 
@@ -29,8 +29,8 @@ if (!isset($session) || !$session->isValid('login-admin') ) {
 
 try {
 
-	$idpmeta = isset($_GET['idpentityid']) ? $_GET['idpentityid'] : $metadata->getMetaDataCurrent('saml20-idp-hosted');
-	$idpentityid = isset($_GET['idpentityid']) ? $_GET['idpentityid'] : $metadata->getMetaDataCurrentEntityID('saml20-idp-hosted');
+	$idpmeta = isset($_GET['idpentityid']) ? $_GET['idpentityid'] : $metadata->getMetaDataCurrent('shib13-idp-hosted');
+	$idpentityid = isset($_GET['idpentityid']) ? $_GET['idpentityid'] : $metadata->getMetaDataCurrentEntityID('shib13-idp-hosted');
 	
 	$publiccert = $config->getBaseDir() . '/cert/' . $idpmeta['certificate'];
 
@@ -45,51 +45,36 @@ try {
 	'" . htmlspecialchars($idpentityid) . "' =>  array(
 		'name'                 => 'Type in a name for this entity',
 		'description'          => 'and a proper description that would help users know when to select this IdP.',
-		'SingleSignOnService'  => '" . htmlspecialchars($metadata->getGenerated('SingleSignOnService', 'saml20-idp-hosted')) . "',
-		'SingleLogoutService'  => '" . htmlspecialchars($metadata->getGenerated('SingleLogoutService', 'saml20-idp-hosted')) . "',
+		'SingleSignOnService'  => '" . htmlspecialchars($metadata->getGenerated('SingleSignOnService', 'shib13-idp-hosted')) . "',
 		'certFingerprint'      => '" . strtolower(sha1(base64_decode($data))) ."'
 	),
 ";
 	
 	$metaxml = '<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
-	<EntityDescriptor xmlns:xsi="https://www.w3.org/2001/XMLSchema-instance" xmlns="urn:oasis:names:tc:SAML:2.0:metadata"
- entityID="' . htmlspecialchars($idpentityid) . '">
-    <IDPSSODescriptor
-        WantAuthnRequestsSigned="false"
-        protocolSupportEnumeration="urn:oasis:names:tc:SAML:2.0:protocol">
-        
-                <KeyDescriptor use="signing">
-                        <ds:KeyInfo xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
-                          <ds:X509Data>
-                                <ds:X509Certificate>' . htmlspecialchars($data) . '</ds:X509Certificate>
-                        </ds:X509Data>
-                  </ds:KeyInfo>
-                </KeyDescriptor>  
-        
-
-        
-        <!-- Logout endpoints -->
-        <SingleLogoutService
-            Binding="urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect"
-            Location="' . htmlspecialchars($metadata->getGenerated('SingleLogoutService', 'saml20-idp-hosted')) . '"
-            ResponseLocation="' . htmlspecialchars($metadata->getGenerated('SingleLogoutService', 'saml20-idp-hosted')) . '"
-            index="0" 
-            isDefault="true"
-            />
-
-        
-        <!-- Supported Name Identifier Formats -->
-        <NameIDFormat>urn:oasis:names:tc:SAML:2.0:nameid-format:transient</NameIDFormat>
-        
-        <!-- AuthenticationRequest Consumer endpoint -->
-        <SingleSignOnService
-            Binding="urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect"
-            Location="' . htmlspecialchars($metadata->getGenerated('SingleSignOnService', 'saml20-idp-hosted')) . '"
-            index="0" 
-            isDefault="true"
-            />
-        
-    </IDPSSODescriptor>
+<EntityDescriptor entityID="' . htmlspecialchars($idpentityid) . '">
+
+	<IDPSSODescriptor protocolSupportEnumeration="urn:oasis:names:tc:SAML:1.1:protocol urn:mace:shibboleth:1.0">
+
+		<KeyDescriptor use="signing">
+			<ds:KeyInfo xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
+				<ds:X509Data>
+					<ds:X509Certificate>' . htmlspecialchars($data) . '</ds:X509Certificate>
+				</ds:X509Data>
+			</ds:KeyInfo>
+		</KeyDescriptor>
+
+		<NameIDFormat>urn:mace:shibboleth:1.0:nameIdentifier</NameIDFormat>
+		
+		<SingleSignOnService Binding="urn:mace:shibboleth:1.0:profiles:AuthnRequest"
+			Location="' . htmlspecialchars($metadata->getGenerated('SingleSignOnService', 'shib13-idp-hosted')) . '"/>
+
+	</IDPSSODescriptor>
+
+	<ContactPerson contactType="technical">
+		<SurName>' . $config->getValue('technicalcontact_name', 'Not entered') . '</SurName>
+		<EmailAddress>' . $config->getValue('technicalcontact_email', 'Not entered') . '</EmailAddress>
+	</ContactPerson>
+	
 </EntityDescriptor>';
 	
 	
@@ -101,21 +86,19 @@ try {
 	}
 
 
-	$defaultidp = $config->getValue('default-saml20-idp');
-	
-	$et = new SimpleSAML_XHTML_Template($config, 'metadata.php');
+	$defaultidp = $config->getValue('default-shib13-idp');
 	
+	$t = new SimpleSAML_XHTML_Template($config, 'metadata.php');
 
-	$et->data['header'] = 'SAML 2.0 IdP Metadata';
+	$t->data['header'] = 'Shib 1.3 IdP Metadata';
 	
-	$et->data['metaurl'] = SimpleSAML_Utilities::addURLparameter(SimpleSAML_Utilities::selfURLNoQuery(), 'output=xml');
-	$et->data['metadata'] = htmlentities($metaxml);
-	$et->data['metadataflat'] = htmlentities($metaflat);
-	
-	$et->data['feide'] = in_array($defaultidp, array('sam.feide.no', 'max.feide.no'));
-	$et->data['defaultidp'] = $defaultidp;
+	$t->data['metaurl'] = SimpleSAML_Utilities::addURLparameter(SimpleSAML_Utilities::selfURLNoQuery(), 'output=xml');
+	$t->data['metadata'] = htmlspecialchars($metaxml);
+	$t->data['metadataflat'] = htmlspecialchars($metaflat);
+
+	$t->data['defaultidp'] = $defaultidp;
 	
-	$et->show();
+	$t->show();
 	
 } catch(Exception $exception) {
 	
diff --git a/www/shib13/sp/metadata.php b/www/shib13/sp/metadata.php
index 30f27dea5..e7a71c472 100644
--- a/www/shib13/sp/metadata.php
+++ b/www/shib13/sp/metadata.php
@@ -13,87 +13,69 @@ $metadata = SimpleSAML_Metadata_MetaDataStorageHandler::getMetadataHandler();
 $session = SimpleSAML_Session::getInstance(TRUE);
 
 
-if (!$config->getValue('enable.saml20-sp', false))
+if (!$config->getValue('enable.shib13-sp', false))
 	SimpleSAML_Utilities::fatalError($session->getTrackID(), 'NOACCESS');
 
 
-/**
- * Preconfigured to help out some federations. This makes it easier for users to report metadata
- * to the administrators of the IdP.
- */
-$send_metadata_to_idp = array(
-	'sam.feide.no'	=> array(
-		'name' 		=> 'Feide',
-		'address'	=> 'http://rnd.feide.no/content/sending-information-simplesamlphp'
-	),
-	'max.feide.no'	=> array(
-		'name' 		=> 'Feide',
-		'address'	=> 'http://rnd.feide.no/content/sending-information-simplesamlphp'
-	)
-);
-
 
 try {
 
-	$spmeta = isset($_GET['spentityid']) ? $_GET['spentityid'] : $metadata->getMetaDataCurrent();
-	$spentityid = isset($_GET['spentityid']) ? $_GET['spentityid'] : $metadata->getMetaDataCurrentEntityID();
-	
-	/*
-	if (!$spmeta['assertionConsumerServiceURL']) throw new Exception('The following parameter is not set in your SAML 2.0 SP Hosted metadata: assertionConsumerServiceURL');
-	if (!$spmeta['SingleLogOutUrl']) throw new Exception('The following parameter is not set in your SAML 2.0 SP Hosted metadata: SingleLogOutUrl');
-	*/
+	$spmeta = isset($_GET['spentityid']) ? $_GET['spentityid'] : $metadata->getMetaDataCurrent('shib13-sp-hosted');
+	$spentityid = isset($_GET['spentityid']) ? $_GET['spentityid'] : $metadata->getMetaDataCurrentEntityID('shib13-sp-hosted');
 	
+
 	$metaflat = "
 	'" . htmlspecialchars($spentityid) . "' => array(
- 		'AssertionConsumerService' => '" . htmlspecialchars($metadata->getGenerated('AssertionConsumerService', 'saml20-sp-hosted')) . "',
- 		'SingleLogoutService'      => '" . htmlspecialchars($metadata->getGenerated('SingleLogoutService', 'saml20-sp-hosted')) . "'
+ 		'AssertionConsumerService' => '" . htmlspecialchars($metadata->getGenerated('AssertionConsumerService', 'saml20-sp-hosted')) . "'
 	)
 ";
 	
 	$metaxml = '<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
-<EntityDescriptor entityID="' . htmlspecialchars($spentityid) . '" xmlns="urn:oasis:names:tc:SAML:2.0:metadata">
+<EntityDescriptor entityID="' . htmlspecialchars($spentityid) . '">
+	<SPSSODescriptor protocolSupportEnumeration="urn:oasis:names:tc:SAML:1.1:protocol">
 
-	<SPSSODescriptor 
-		AuthnRequestsSigned="false" 
-		WantAssertionsSigned="false" 
-		protocolSupportEnumeration="urn:oasis:names:tc:SAML:2.0:protocol">
-
-		<SingleLogoutService 
-			Binding="urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect" 
-			Location="' . htmlspecialchars($metadata->getGenerated('SingleLogoutService', 'saml20-sp-hosted')) . '"/>
+		<NameIDFormat>urn:mace:shibboleth:1.0:nameIdentifier</NameIDFormat>
 		
-		<NameIDFormat>urn:oasis:names:tc:SAML:2.0:nameid-format:transient</NameIDFormat>
+		<AssertionConsumerService Binding="urn:oasis:names:tc:SAML:1.0:profiles:browser-post" Location="' . htmlspecialchars($metadata->getGenerated('AssertionConsumerService', 'shib13-sp-hosted')) . '" index="1" isDefault="true" />
 		
-		<AssertionConsumerService 
-			index="0" 
-			isDefault="true" 
-			Binding="urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST" 
-			Location="' . htmlspecialchars($metadata->getGenerated('AssertionConsumerService', 'saml20-sp-hosted')) . '" />
-
 	</SPSSODescriptor>
-
+	
+	<ContactPerson contactType="technical">
+		<SurName>' . $config->getValue('technicalcontact_name', 'Not entered') . '</SurName>
+		<EmailAddress>' . $config->getValue('technicalcontact_email', 'Not entered') . '</EmailAddress>
+	</ContactPerson>
+		
 </EntityDescriptor>';
+
+	if (array_key_exists('output', $_GET) && $_GET['output'] == 'xml') {
+		header('Content-Type: application/xml');
+		
+		echo $metaxml;
+		exit(0);
+	}
 	
-	$defaultidp = $config->getValue('default-saml20-idp');
+	$defaultidp = $config->getValue('default-shib13-idp');
 	
-	$et = new SimpleSAML_XHTML_Template($config, 'metadata.php');
+	$t = new SimpleSAML_XHTML_Template($config, 'metadata.php');
 	
 
-	$et->data['header'] = 'SAML 2.0 SP Metadata';
-	$et->data['metadata'] = htmlentities($metaxml);
-	$et->data['metadataflat'] = htmlentities($metaflat);
+	$t->data['header'] = 'Shib 1.3 SP Metadata';
+	$t->data['metadata'] = htmlspecialchars($metaxml);
+	$t->data['metadataflat'] = htmlspecialchars($metaflat);
+	$t->data['metaurl'] = SimpleSAML_Utilities::addURLparameter(SimpleSAML_Utilities::selfURLNoQuery(), 'output=xml');
 	
+	/*
 	if (array_key_exists($defaultidp, $send_metadata_to_idp)) {
 		$et->data['sendmetadatato'] = $send_metadata_to_idp[$defaultidp]['address'];
 		$et->data['federationname'] = $send_metadata_to_idp[$defaultidp]['name'];
 	}
+	*/
 
-	$et->data['techemail'] = $config->getValue('technicalcontact_email', 'na');
-	$et->data['version'] = $config->getValue('version', 'na');
-	$et->data['feide'] = in_array($defaultidp, array('sam.feide.no', 'max.feide.no'));
-	$et->data['defaultidp'] = $defaultidp;
+	$t->data['techemail'] = $config->getValue('technicalcontact_email', 'na');
+	$t->data['version'] = $config->getValue('version', 'na');
+	$t->data['defaultidp'] = $defaultidp;
 	
-	$et->show();
+	$t->show();
 	
 } catch(Exception $exception) {
 	
-- 
GitLab