PoshCode Archive  Artifact [46f53490c6]

Artifact 46f53490c65027f062c61f8d430762919198639b072f7a1486aa52950f180812:

  • File Get-WebsiteCertificate.ps1 — part of check-in [cc7056aa4e] at 2018-06-10 13:11:52 on branch trunk — This will return the specified website’s X.509 certificate either as an object or a file (if the -OutputFile parameter is specified). See included comment based help for documentation. (user: Andy Arismendi size: 3913)

# encoding: ascii
# api: powershell
# title: Get-WebsiteCertificate
# description: This will return the specified website’s X.509 certificate either as an object or a file (if the -OutputFile parameter is specified). See included comment based help for documentation.
# version: 0.1
# type: function
# author: Andy Arismendi
# license: CC0
# function: Get-WebsiteCertificate
# x-poshcode-id: 2521
# x-archived: 2017-05-26T18:33:58
# x-published: 2011-02-24T18:15:00
#
#
function Get-WebsiteCertificate {
	[CmdletBinding()]
	param (
		[Parameter(Mandatory=$true)] [System.Uri]
			$Uri,
		[Parameter()] [System.IO.FileInfo]
			$OutputFile,
		[Parameter()] [Switch]
			$UseSystemProxy,	
		[Parameter()] [Switch]
			$UseDefaultCredentials,
		[Parameter()] [Switch]
			$TrustAllCertificates
	)
	try {
		$request = [System.Net.WebRequest]::Create($Uri)
		if ($UseSystemProxy) {
			$request.Proxy = [System.Net.WebRequest]::DefaultWebProxy
		}
		
		if ($UseSystemProxy -and $UseDefaultCredentials) {
			$request.Proxy.Credentials = [System.Net.CredentialCache]::DefaultNetworkCredentials
		}
		
		if ($TrustAllCertificates) {
			# Create a compilation environment
			$Provider=New-Object Microsoft.CSharp.CSharpCodeProvider
			$Compiler=$Provider.CreateCompiler()
			$Params=New-Object System.CodeDom.Compiler.CompilerParameters
			$Params.GenerateExecutable=$False
			$Params.GenerateInMemory=$True
			$Params.IncludeDebugInformation=$False
			$Params.ReferencedAssemblies.Add("System.DLL") > $null
			$TASource=@'
			  namespace Local.ToolkitExtensions.Net.CertificatePolicy {
			    public class TrustAll : System.Net.ICertificatePolicy {
			      public TrustAll() { 
			      }
			      public bool CheckValidationResult(System.Net.ServicePoint sp,
			        System.Security.Cryptography.X509Certificates.X509Certificate cert, 
			        System.Net.WebRequest req, int problem) {
			        return true;
			      }
			    }
			  }
'@ 
			$TAResults=$Provider.CompileAssemblyFromSource($Params,$TASource)
			$TAAssembly=$TAResults.CompiledAssembly

			## We now create an instance of the TrustAll and attach it to the ServicePointManager
			$TrustAll=$TAAssembly.CreateInstance("Local.ToolkitExtensions.Net.CertificatePolicy.TrustAll")
			[System.Net.ServicePointManager]::CertificatePolicy=$TrustAll
		}
		
		$response = $request.GetResponse()
		$servicePoint = $request.ServicePoint
		$certificate = $servicePoint.Certificate
		
		if ($OutputFile) {
			$certBytes = $certificate.Export(
					[System.Security.Cryptography.X509Certificates.X509ContentType]::Cert
				)
			[System.IO.File]::WriteAllBytes( $OutputFile, $certBytes )
			$OutputFile.Refresh()
			return $OutputFile
		} else {
			return $certificate
		}
	} catch {
		Write-Error "Failed to get website certificate. The error was '$_'."
		return $null
	}
	
	<#
		.SYNOPSIS
			Retrieves the certificate used by a website.
	
		.DESCRIPTION
			Retrieves the certificate used by a website. Returns either an object or file.
	
		.PARAMETER  Uri
			The URL of the website. This should start with https.
	
		.PARAMETER  OutputFile
			Specifies what file to save the certificate as.
			
		.PARAMETER  UseSystemProxy
			Whether or not to use the system proxy settings.
			
		.PARAMETER  UseDefaultCredentials
			Whether or not to use the system logon credentials for the proxy.
			
		.PARAMETER  TrustAllCertificates
			Ignore certificate errors for certificates that are expired, have a mismatched common name or are self signed.
	
		.EXAMPLE
			PS C:\> Get-WebsiteCertificate "https://www.gmail.com" -UseSystemProxy -UseDefaultCredentials -TrustAllCertificates -OutputFile C:\gmail.cer
		
		.INPUTS
			Does not accept pipeline input.
	
		.OUTPUTS
			System.Security.Cryptography.X509Certificates.X509Certificate, System.IO.FileInfo
	#>
}