2013-03-25 13:56:33 +00:00
|
|
|
# IBM(c) 2013 EPL license http://www.eclipse.org/legal/epl-v10.html
|
|
|
|
# This function specifically validates that the peer we are talking to is signed by the xCAT blessed CA and no other CA
|
2013-03-25 13:56:44 +00:00
|
|
|
Function Approve-xCATCert ($sender, $cert, $chain, $polerrs) {
|
2013-03-25 13:56:39 +00:00
|
|
|
if ($polerrs -ne "None") { return $false } #if the overall policy suggests rejection, go with it
|
|
|
|
#now, system policy suggests that everything is ok, but we want to be more picky, because we
|
|
|
|
#are measuring something more specific than 'did any old CA sign this', we specifically want to assue the signer CA is xCAT's
|
|
|
|
#TODO: perhaps ignore the RemoteCertificateChainErrors condition and chase a chain of our own creation
|
|
|
|
#that chain could live outside the user or system wide root to avoid giving xCAT the power to sign certs for things it shouldn't
|
2013-03-25 13:56:33 +00:00
|
|
|
foreach ($cert in $chain.chainElements) {
|
2013-03-25 13:56:39 +00:00
|
|
|
if ($script:xcatcacert.thumbprint -eq $cert.Certificate.thumprint) {
|
|
|
|
return $true
|
|
|
|
}
|
2013-03-25 13:56:33 +00:00
|
|
|
}
|
2013-03-25 13:56:39 +00:00
|
|
|
return $false
|
2013-03-25 13:56:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#we import the xCAT certificate authority into the appropriate scope
|
2013-03-25 13:56:39 +00:00
|
|
|
#we have to use localmachine in order to avoid interactive prompt, meaning we need admin for this one, besides
|
|
|
|
#this means admin installs CA cert for everyone
|
|
|
|
#TODO: use cert:\currentuser\root when not administrator to facilitate xCAT-client case, take the prompt once
|
2013-03-25 13:56:44 +00:00
|
|
|
Function Import-xCATCA ( $certpath ) {
|
2013-03-25 13:56:33 +00:00
|
|
|
$script:xcatcacert=Import-Certificate -FilePath $certpath -CertStoreLocation Cert:\LocalMachine\root
|
|
|
|
}
|
2013-03-25 13:56:39 +00:00
|
|
|
|
|
|
|
#this removes the xCAT CA from trust store, if user wishes to explicitly distrust xCAT post deploy
|
2013-03-25 13:56:44 +00:00
|
|
|
Function Remove-xCATCA ( $certpath ) {
|
2013-03-25 13:56:39 +00:00
|
|
|
xCAT-Import-CA($certpath) #this seems insane, but it's easiest way to make sure we have the correct path
|
|
|
|
rm $script:xcatcacert.PSPath
|
2013-03-25 13:56:33 +00:00
|
|
|
}
|
|
|
|
|
2013-03-25 13:56:39 +00:00
|
|
|
#specify a client certificate to use in pfx format
|
|
|
|
#we put this one in the user's store instead of system wide
|
2013-03-25 13:56:44 +00:00
|
|
|
Function Set-xCATClientCertificate ( $pfxPath ) {
|
2013-03-25 13:56:39 +00:00
|
|
|
$script:xcatclientcert=Import-pfxCertificate $pfxPath -certStoreLocation cert:\currentuser\my
|
|
|
|
}
|
2013-03-25 13:56:44 +00:00
|
|
|
Function Remove-xCATClientCertificate( $pfxPath ) {
|
2013-03-25 13:56:39 +00:00
|
|
|
xCAT-Set-Client-Certificate($pfxpath)
|
|
|
|
rm cert:\currentuser\my\$script:xcatclientcert.thumbprint
|
|
|
|
}
|
|
|
|
|
|
|
|
#key here is that we might have two certificates:
|
|
|
|
#-one intended to identify the system that was deployed by xcat
|
|
|
|
#-one intended to identify the user to do things like 'rpower'
|
|
|
|
#TODO: argument to specify whether this is a human or machine. Default would be human and machine invocation would be in scripts
|
2013-03-25 13:56:44 +00:00
|
|
|
Function Select-xCATClientCert ($sender, $targetHost, $localCertificates, $remoteCertificate,$acceptableIssuers) {
|
2013-03-25 13:56:39 +00:00
|
|
|
$script:xcatclientcert
|
|
|
|
}
|
2013-03-25 13:56:44 +00:00
|
|
|
Function Connect-xCAT {
|
2013-03-25 13:56:39 +00:00
|
|
|
Param(
|
|
|
|
$mgtServer,
|
2013-03-25 13:57:04 +00:00
|
|
|
$mgtServerPort=3001,
|
2013-03-25 13:56:39 +00:00
|
|
|
$mgtServerAltName=$mgtServer
|
|
|
|
)
|
2013-03-25 13:57:04 +00:00
|
|
|
$script:xcatconnection = New-Object Net.Sockets.TcpClient($mgtServer,$mgtServerPort)
|
|
|
|
$script:verifycallback = Get-Content Function:\Appve-xCATCert
|
|
|
|
$script:xcatstream = $script:xcatconnection
|
2013-03-25 13:56:44 +00:00
|
|
|
}
|