mirror of https://github.com/k3s-io/k3s
151 lines
5.1 KiB
PowerShell
151 lines
5.1 KiB
PowerShell
# Copyright 2019 The Kubernetes Authors.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
<#
|
|
.SYNOPSIS
|
|
Library containing common variables and code used by other PowerShell modules
|
|
and scripts for configuring Windows nodes.
|
|
#>
|
|
|
|
# Disable progress bar to increase download speed.
|
|
$ProgressPreference = 'SilentlyContinue'
|
|
|
|
# REDO_STEPS affects the behavior of a node that is rebooted after initial
|
|
# bringup. When true, on a reboot the scripts will redo steps that were
|
|
# determined to have already been completed once (e.g. to overwrite
|
|
# already-existing config files). When false the scripts will perform the
|
|
# minimum required steps to re-join this node to the cluster.
|
|
$REDO_STEPS = $false
|
|
Export-ModuleMember -Variable REDO_STEPS
|
|
|
|
# Writes $Message to the console. Terminates the script if $Fatal is set.
|
|
function Log-Output {
|
|
param (
|
|
[parameter(Mandatory=$true)] [string]$Message,
|
|
[switch]$Fatal
|
|
)
|
|
Write-Host "${Message}"
|
|
if (${Fatal}) {
|
|
Exit 1
|
|
}
|
|
}
|
|
|
|
# Checks if a file should be written or overwritten by testing if it already
|
|
# exists and checking the value of the global $REDO_STEPS variable. Emits an
|
|
# informative message if the file already exists.
|
|
#
|
|
# Returns $true if the file does not exist, or if it does but the global
|
|
# $REDO_STEPS variable is set to $true. Returns $false if the file exists and
|
|
# the caller should not overwrite it.
|
|
function ShouldWrite-File {
|
|
param (
|
|
[parameter(Mandatory=$true)] [string]$Filename
|
|
)
|
|
if (Test-Path $Filename) {
|
|
if ($REDO_STEPS) {
|
|
Log-Output "Warning: $Filename already exists, will overwrite it"
|
|
return $true
|
|
}
|
|
Log-Output "Skip: $Filename already exists, not overwriting it"
|
|
return $false
|
|
}
|
|
return $true
|
|
}
|
|
|
|
# Returns the GCE instance metadata value for $Key. If the key is not present
|
|
# in the instance metadata returns $Default if set, otherwise returns $null.
|
|
function Get-InstanceMetadataValue {
|
|
param (
|
|
[parameter(Mandatory=$true)] [string]$Key,
|
|
[parameter(Mandatory=$false)] [string]$Default
|
|
)
|
|
|
|
$url = ("http://metadata.google.internal/computeMetadata/v1/instance/" +
|
|
"attributes/$Key")
|
|
try {
|
|
$client = New-Object Net.WebClient
|
|
$client.Headers.Add('Metadata-Flavor', 'Google')
|
|
return ($client.DownloadString($url)).Trim()
|
|
}
|
|
catch [System.Net.WebException] {
|
|
if ($Default) {
|
|
return $Default
|
|
}
|
|
else {
|
|
Log-Output "Failed to retrieve value for $Key."
|
|
return $null
|
|
}
|
|
}
|
|
}
|
|
|
|
function Validate-SHA1 {
|
|
param(
|
|
[parameter(Mandatory=$true)] [string]$Hash,
|
|
[parameter(Mandatory=$true)] [string]$Path
|
|
)
|
|
$actual = Get-FileHash -Path $Path -Algorithm SHA1
|
|
# Note: Powershell string comparisons are case-insensitive by default, and this
|
|
# is important here because Linux shell scripts produce lowercase hashes but
|
|
# Powershell Get-FileHash produces uppercase hashes. This must be case-insensitive
|
|
# to work.
|
|
if ($actual.Hash -ne $Hash) {
|
|
Log-Output "$Path corrupted, sha1 $actual doesn't match expected $Hash"
|
|
Throw ("$Path corrupted, sha1 $actual doesn't match expected $Hash")
|
|
}
|
|
}
|
|
|
|
# Attempts to download the file from URLs, trying each URL until it succeeds.
|
|
# It will loop through the URLs list forever until it has a success.
|
|
# If successful, it will write the file to OutFile. You can optionally provide a SHA1 Hash
|
|
# argument, in which case it will attempt to validate the downloaded file against the hash.
|
|
function MustDownload-File {
|
|
param (
|
|
[parameter(Mandatory=$false)] [string]$Hash,
|
|
[parameter(Mandatory=$true)] [string]$OutFile,
|
|
[parameter(Mandatory=$true)] [System.Collections.Generic.List[String]]$URLs
|
|
)
|
|
|
|
While($true) {
|
|
ForEach($url in $URLs) {
|
|
# Attempt to download the file
|
|
Try {
|
|
# TODO(mtaufen): When we finally get a Windows version that has Powershell 6
|
|
# installed we can set `-MaximumRetryCount 6 -RetryIntervalSec 10` to make this even more robust.
|
|
Invoke-WebRequest $url -OutFile $OutFile -TimeoutSec 300
|
|
} Catch {
|
|
$message = $_.Exception.ToString()
|
|
Log-Output "Failed to download file from $url. Will retry. Error: $message"
|
|
continue
|
|
}
|
|
# Attempt to validate the hash
|
|
if ($Hash) {
|
|
Try {
|
|
Validate-SHA1 -Hash $Hash -Path $OutFile
|
|
} Catch {
|
|
$message = $_.Exception.ToString()
|
|
Log-Output "Hash validation of $url failed. Will retry. Error: $message"
|
|
continue
|
|
}
|
|
Log-Output "Downloaded $url (SHA1 = $Hash)"
|
|
return
|
|
}
|
|
Log-Output "Downloaded $url"
|
|
return
|
|
}
|
|
}
|
|
}
|
|
|
|
# Export all public functions:
|
|
Export-ModuleMember -Function *-*
|