GitClone fix

GitClone will work even when Scripts dir already exist
This commit is contained in:
lksz 2020-09-30 11:30:28 -04:00
parent 607fff132f
commit 7117e78a7a
1 changed files with 325 additions and 302 deletions

View File

@ -1,244 +1,270 @@
[CmdletBinding(SupportsShouldProcess)]param( [CmdletBinding(SupportsShouldProcess)]param(
[switch]$sudo, [switch]$sudo,
[switch]$RemoveOnly, [switch]$RemoveOnly,
[switch]$ShowSkipped, [switch]$ShowSkipped,
[switch]$Force, [switch]$Force,
[switch]$GitClone, [switch]$GitClone,
[string]$GitURL = 'https://code.lksz.me/lksz/PowerShell_Scripts', [string]$GitURL = 'https://code.lksz.me/lksz/PowerShell_Scripts',
[Parameter(DontShow)] [Parameter(DontShow)]
[string]$MyPSScriptRoot = $MyPSScriptRoot [string]$MyPSScriptRoot = $MyPSScriptRoot
) )
function _Setup { function _Setup {
[CmdletBinding(SupportsShouldProcess)]param( [CmdletBinding(SupportsShouldProcess)]param(
[switch]$sudo, [switch]$sudo,
[switch]$RemoveOnly, [switch]$RemoveOnly,
[switch]$ShowSkipped, [switch]$ShowSkipped,
[switch]$Force, [switch]$Force,
[switch]$GitClone, [switch]$GitClone,
[string]$GitURL = 'https://code.lksz.me/lksz/PowerShell_Scripts', [string]$GitURL = 'https://code.lksz.me/lksz/PowerShell_Scripts',
[Parameter(DontShow)] [Parameter(DontShow)]
[string]$MyPSScriptRoot = $MyPSScriptRoot) [string]$MyPSScriptRoot = $MyPSScriptRoot)
####################################################################### #######################################################################
## ProfileCode function (source) will contain the code to be written ## ProfileCode function (source) will contain the code to be written
####################################################################### #######################################################################
function ProfileCode_pre_common { function ProfileCode_pre_common {
# # If TMUX isn't loaded, start byobu, then exit this script (and current shell) # # If TMUX isn't loaded, start byobu, then exit this script (and current shell)
# if ( -not ( Test-Path env:TMUX ) ) { byobu; exit } # if ( -not ( Test-Path env:TMUX ) ) { byobu; exit }
} }
####################################################################### #######################################################################
## common Profile Code - receommended not to change this ## common Profile Code - receommended not to change this
## Code will be loaded from profile.d sub-directory after this. ## Code will be loaded from profile.d sub-directory after this.
####################################################################### #######################################################################
function ProfileCode_post_common { function ProfileCode_post_common {
# This loads the personal profile section from the $MyPSScriptRoot/profile.d directory # This loads the personal profile section from the $MyPSScriptRoot/profile.d directory
Get-Command Reload-MyScripts -ErrorAction SilentlyContinue | ForEach-Object { . $_.Name } Get-Command Reload-MyScripts -ErrorAction SilentlyContinue | ForEach-Object { . $_.Name }
} }
####################################################################### #######################################################################
## Setup-Profile code continues below ## Setup-Profile code continues below
####################################################################### #######################################################################
if ( $GitClone -and -not (Test-Path $(Join-Path $MyPSScriptRoot '.git')) ) { if ( $GitClone -and -not (Test-Path $(Join-Path $MyPSScriptRoot '.git')) ) {
if( -not [bool]$(Get-Command git -ErrorAction SilentlyContinue) ) { if ( -not [bool]$(Get-Command git -ErrorAction SilentlyContinue) ) {
throw "No git command found, you may either omit the -GitClone switch or install git and try again." throw "No git command found, you may either omit the -GitClone switch or install git and try again."
} }
if( $PSCmdlet.ShouldProcess("Pull git repo from $GitURL into $MyPSScriptRoot ?") ) { if ( $PSCmdlet.ShouldProcess("Pull git repo from $GitURL into $MyPSScriptRoot ?") ) {
git clone $GitURL $MyPSScriptRoot Push-Location $MyPSScriptRoot
} $local:tmpGitDir = New-TemporaryFile
Remove-Item $tmpGitDir
New-Item -Type Directory $tmpGitDir.FullName | Out-Null
$local:GitOutput = "$(& git clone $GitURL $tmpGitDir.FullName --no-checkout)"
Write-Verbose $GitOutput
Move-Item (Join-Path $tmpGitDir.FullName .git) ./.git
Remove-Item $tmpGitDir.FullName
$GitOutput = "$(& git checkout --force)"
Write-Verbose $GitOutput
Pop-Location
}
} }
$local:ProfileSignature = [PSCustomObject]([ordered]@{ $local:ProfileSignature = [PSCustomObject]([ordered]@{
Begin = '#### SZ Auto Profile Setup - BEGIN ####' Begin = '#### SZ Auto Profile Setup - BEGIN ####'
End = '#### SZ Auto Profile Setup - END ####' End = '#### SZ Auto Profile Setup - END ####'
}) Removed = '#### SZ Auto Profile Setup'
})
function New-ProfileSetupStatus{ function New-ProfileSetupStatus {
param($Name,$Path,$Status,$Exist) param($Name, $Path, $Status, $Exist)
return [PSCustomObject]([ordered]@{ return [PSCustomObject]([ordered]@{
Name = $Name Name = $Name
Path = $Path Path = $Path
Status = $Status Status = $Status
Exist = $Exist Exist = $Exist
}) })
} }
$local:_profiles= $PROFILE | fl * -Force | Out-String -Stream | ForEach-Object { $local:_profiles = $PROFILE | fl * -Force | Out-String -Stream | ForEach-Object {
$local:p = $($_ -split ' : [/A-Z\\]'); $local:p = $($_ -split ' : [/A-Z\\]');
if( $p[0] -match 'User' ) { if ( $p[0] -match 'User' ) {
$p[0].Trim() $p[0].Trim()
} }
} }
$local:_profile = $profile.CurrentUserAllHosts; $local:_profile = $profile.CurrentUserAllHosts;
$local:randomSeed = "####$(Get-Random)####"; $local:randomSeed = "####$(Get-Random)####";
if( $RemoveOnly -and $ConfirmPreference -eq 'High' -and (-not $PSBoundParameters -or -not $PSBoundParameters.ContainsKey('Confirm')) ) { if ( $RemoveOnly -and $ConfirmPreference -eq 'High' -and (-not $PSBoundParameters -or -not $PSBoundParameters.ContainsKey('Confirm')) ) {
$script:ConfirmPreference = 'Low' $script:ConfirmPreference = 'Low'
} }
if( $sudo -or $(Test-IsAdmin) ) { $_profile = $profile.AllUsersAllHosts } if ( $sudo -or $(Test-IsAdmin) ) { $_profile = $profile.AllUsersAllHosts }
$_profiles | Foreach-Object { $_profiles | Foreach-Object {
$local:p = Invoke-Expression "`$profile.$_" $local:p = Invoke-Expression "`$profile.$_"
$local:profileContent = $randomSeed; $local:profileContent = $randomSeed;
$local:exists = Test-Path $p $local:exists = Test-Path $p
$local:userFile = $($_ -match 'CurrentUser') $local:userFile = $($_ -match 'CurrentUser')
$local:cleanupValue = '' $local:cleanupValue = ''
if ( $exists -and ((Get-Content -Path $p | Out-String ) -match $ProfileSignature.Begin ) ) { if ( $exists -and ((Get-Content -Path $p | Out-String ) -match $ProfileSignature.Begin ) ) {
Write-Verbose "Found code in [$_]'$p', preparing..." Write-Verbose "Found code in [$_]'$p', preparing..."
$local:gate = $true; $local:gate = $true;
$profileContent = Get-Content $p | ForEach-Object { $profileContent = Get-Content $p | ForEach-Object {
if( -not $gate ) { if ( -not $gate ) {
if ( $_ -match $ProfileSignature.End ) { if ( $_ -match $ProfileSignature.End ) {
$gate = $true; $gate = $true;
} }
} else { }
if ( $_ -match $ProfileSignature.Begin ) { else {
$gate = $false; if ( $_ -match $ProfileSignature.Begin ) {
$cleanupValue = ' ' $gate = $false;
return $randomSeed; $cleanupValue = $ProfileSignature.Removed
} return $randomSeed;
return $_ }
return $_
}
} }
}
}
if( ($p -eq $_profile) -and -not $RemoveOnly ) {
Write-Verbose "Inserting ProfileCode into $($_)..."
$profileContent = $profileContent -replace $randomSeed,$((@(
'',
$ProfileSignature.Begin,
'',
$(Export-FunctionSource -NoHeader ProfileCode_pre_common),
'',
'',
$(Export-FunctionSource -NoHeader ProfileCode_common),
'',
'',
$(Export-FunctionSource -NoHeader ProfileCode_post_common),
'',
$ProfileSignature.End
) -join "`n" ).Trim().Replace(('$'+'_'),('$$'+'_')))
}
$profileContent = $($profileContent -replace $randomSeed,$cleanupValue).Trim()
$local:shouldSudo = $sudo -and -not $userFile
$local:status = 'Skipped'
if( $VerbosePreference -eq 'Continue' ) { $ShowSkipped = $true }
if( -not ([string]::IsNullOrWhiteSpace($profileContent)) ) {
$status = "Need $(if($cleanupValue){'Setup'}else{'Cleanup'})"
if( $sudo -or $userFile ) {
Write-Verbose "Writing content to $($_)..."
$local:tmpOutput = New-TemporaryFile -WhatIf:$false
$profileContent | Out-File $tmpOutput.FullName -WhatIf:$false
if( $shouldSudo -and $( $PSVersionTable.Platform -eq 'Unix' ) ) {
Invoke-ExpressionEx -sudo:$shouldSudo chmod 'a+r' $tmpOutput.FullName
}
try {
function BreakPointHere{} BreakPointHere;
$local:errMsg = $(Invoke-ExpressionEx -sudo:$shouldSudo "Move-Item $($tmpOutput.FullName) $p -Force:`$$Force -ErrorAction Stop | Out-Null" 2>&1)
if( $errMsg ) {
Write-Error "$errMsg"
$status = $status -replace 'Need ','Failed '
} else {
$status = $status -replace 'Need ',''
}
} catch {
Write-Error "Writing $p failed!"
}
} else {
$status = "Need $status"
Write-Error "Cannot write into [$_]'$p'! Please re-run with sudo."
} }
} elseif( ($Force -or $RemoveOnly) -and $exists ) {
$status = 'Need Removal' $local:insertProfileCode = $false;
if( $sudo -or $userFile ) { if ( ($p -eq $_profile) -and -not $RemoveOnly ) {
Write-Verbose "Removing [$_]'$p'..." $insertProfileCode = $true
try { Write-Verbose "Inserting ProfileCode into $($_)..."
Invoke-ExpressionEx -sudo:$shouldSudo Remove-Item $p $cleanupValue = $((@(
if( -not (Test-Path $p) ) { $status = 'Removed' } '',
} catch { $ProfileSignature.Begin,
Write-Error "Removal of $p failed!" '',
} $(Export-FunctionSource -NoHeader ProfileCode_pre_common),
} else { '',
Write-Error "Cannot remove [$_]'$p'! Please re-run with sudo." '',
$(Export-FunctionSource -NoHeader ProfileCode_common),
'',
'',
$(Export-FunctionSource -NoHeader ProfileCode_post_common),
'',
$ProfileSignature.End
) -join "`n" ).Trim().Replace(('$' + '_'), ('$$' + '_')))
}
$profileContent = $($profileContent -replace $randomSeed, $cleanupValue).Trim()
$local:shouldSudo = $sudo -and -not $userFile
$local:status = 'Skipped'
if ( $VerbosePreference -eq 'Continue' ) { $ShowSkipped = $true }
if ( -not ([string]::IsNullOrWhiteSpace($profileContent)) ) {
$status = "Need $(if($insertProfileCode){'Setup'}else{'Cleanup'})"
if ( $sudo -or $userFile ) {
Write-Verbose "Writing content to $($_)..."
$local:tmpOutput = New-TemporaryFile -WhatIf:$false
$profileContent | Out-File $tmpOutput.FullName -WhatIf:$false
if ( $shouldSudo -and $( $PSVersionTable.Platform -eq 'Unix' ) ) {
Invoke-ExpressionEx -sudo:$shouldSudo chmod 'a+r' $tmpOutput.FullName
}
try {
function BreakPointHere {} BreakPointHere;
$local:errMsg = $(Invoke-ExpressionEx -sudo:$shouldSudo "Move-Item $($tmpOutput.FullName) $p -Force:`$$Force -ErrorAction Stop | Out-Null" 2>&1)
if ( $errMsg ) {
Write-Error "$errMsg"
$status = $status -replace 'Need ', 'Failed '
}
else {
$status = $status -replace 'Need ', ''
}
}
catch {
Write-Error "Writing $p failed!"
}
}
else {
$status = "Need $status"
Write-Error "Cannot write into [$_]'$p'! Please re-run with sudo."
}
}
elseif ( ($Force -or $RemoveOnly) -and $exists ) {
$status = 'Need Removal'
if ( $sudo -or $userFile ) {
Write-Verbose "Removing [$_]'$p'..."
try {
Invoke-ExpressionEx -sudo:$shouldSudo Remove-Item $p
if ( -not (Test-Path $p) ) { $status = 'Removed' }
}
catch {
Write-Error "Removal of $p failed!"
}
}
else {
Write-Error "Cannot remove [$_]'$p'! Please re-run with sudo."
}
}
if ( $status -ne 'Skipped' -or $ShowSkipped ) {
if ( $shouldSudo -and $status -ne 'Skipped' ) { $status = "$status via sudo" }
New-ProfileSetupStatus -Name $_ -Path $p -Status $status -Exist $(Test-Path $p)
} }
}
if( $status -ne 'Skipped' -or $ShowSkipped ) {
if( $shouldSudo -and $status -ne 'Skipped' ) { $status = "$status via sudo" }
New-ProfileSetupStatus -Name $_ -Path $p -Status $status -Exist $(Test-Path $p)
}
} }
Remove-Item function:ProfileCode* -Confirm:$false Remove-Item function:ProfileCode* -Confirm:$false
} }
#######################################################################
## ProfileCode_common (source) containing mandatory code for $PROFILE
#######################################################################
function ProfileCode_common { function ProfileCode_common {
function Get-PowerShellPath { function Get-PowerShellPath {
Get-Process -PID $PID | ForEach-Object { $_.Path,$_.Parent.Path } | Where-Object { $_ -match 'powershell|pwsh' } | Select-Object -First 1 Get-Process -PID $PID | ForEach-Object { $_.Path, $_.Parent.Path } | Where-Object { $_ -match 'powershell|pwsh' } | Select-Object -First 1
} }
function ConvertTo-Base64 { function ConvertTo-Base64 {
param([string]$String) param([string]$String)
return [Convert]::ToBase64String([Text.Encoding]::Unicode.GetBytes($String)) return [Convert]::ToBase64String([Text.Encoding]::Unicode.GetBytes($String))
} }
function Invoke-ExpressionEx { function Invoke-ExpressionEx {
[CmdletBinding(SupportsShouldProcess)]param( [CmdletBinding(SupportsShouldProcess)]param(
[switch]$sudo, [switch]$sudo,
[switch]$Force, [switch]$Force,
[string]$Function, [string]$Function,
[switch]$MarshalOutput, [switch]$MarshalOutput,
[Parameter(Position = 1, ValueFromRemainingArguments = $true)] [Parameter(Position = 1, ValueFromRemainingArguments = $true)]
[string[]]$expr [string[]]$expr
) )
function do_sudo { function do_sudo {
[CmdletBinding()]param ( [CmdletBinding()]param(
[string]$sudo_cmd [string]$sudo_cmd
)
function do_sudo_win {
[CmdletBinding()]param(
[string]$sudo_cmd
) )
function do_sudo_win {
[CmdletBinding()]param (
[string]$sudo_cmd
)
$local:sudo_exec = [string]::Empty $local:sudo_exec = [string]::Empty
if( (Get-Command scoop -ErrorAction SilentlyContinue) ) { if ( (Get-Command scoop -ErrorAction SilentlyContinue) ) {
$sudo_exec = $(scoop which gsudo *>&1) $sudo_exec = $(scoop which gsudo *>&1)
if( $sudo_exec -match 'not found' ) { if ( $sudo_exec -match 'not found' ) {
$sudo_exec = $(scoop which sudo *>&1) $sudo_exec = $(scoop which sudo *>&1)
} }
if( $sudo_exec -match 'not found' ) { $sudo_exec = [string]::Empty } if ( $sudo_exec -match 'not found' ) { $sudo_exec = [string]::Empty }
} }
if( $sudo_exec ) { if ( $sudo_exec ) {
& $sudo_exec $sudo_cmd & $sudo_exec $sudo_cmd
} else {
Write-Error "Didn't find a known sudo command"
} }
} else {
Write-Error "Didn't find a known sudo command"
if( $PSVersionTable.Platform -eq 'Unix' ) {
/usr/bin/env sudo $(Get-PowerShellPath) "-noprofile" "-EncodedCommand" $(ConvertTo-Base64 $sudo_cmd)
} else {
$local:currentIdenity = [System.Security.Principal.WindowsIdentity]::GetCurrent()
if( $currentIdenity.UserClaims.Value -contains 'S-1-5-32-544' ) {
do_sudo_win $sudo_cmd
} else {
Write-Error "User [$($currentIdenity.Name)]does not have permissions to run as admin."
} }
}
} }
if( $sudo -and -not $(Test-IsAdmin) ) { if ( $PSVersionTable.Platform -eq 'Unix' ) {
$local:tmpOutputFile = $null /usr/bin/env sudo $(Get-PowerShellPath) "-noprofile" "-EncodedCommand" $(ConvertTo-Base64 $sudo_cmd)
$local:tmpScriptFile = $null }
else {
$local:currentIdenity = [System.Security.Principal.WindowsIdentity]::GetCurrent()
if ( $currentIdenity.UserClaims.Value -contains 'S-1-5-32-544' ) {
do_sudo_win $sudo_cmd
}
else {
Write-Error "User [$($currentIdenity.Name)]does not have permissions to run as admin."
}
}
$local:sudo_cmd = "$($expr -join ' ')".Trim() }
if( $Function ) {
if ( $sudo -and -not $(Test-IsAdmin) ) {
$local:tmpOutputFile = $null
$local:tmpScriptFile = $null
$local:sudo_cmd = "$($expr -join ' ')".Trim()
if ( $Function ) {
$tmpScriptFile = New-TemporaryFile -WhatIf:$false -Confirm:$false $tmpScriptFile = New-TemporaryFile -WhatIf:$false -Confirm:$false
$tmpScriptFile = Move-Item $tmpScriptFile.FullName "$($tmpScriptFile.FullName).ps1" -PassThru -WhatIf:$false -Confirm:$false $tmpScriptFile = Move-Item $tmpScriptFile.FullName "$($tmpScriptFile.FullName).ps1" -PassThru -WhatIf:$false -Confirm:$false
@ -247,138 +273,135 @@ function ProfileCode_common {
$tmpScriptContent | Out-File $tmpScriptFile.FullName -WhatIf:$false $tmpScriptContent | Out-File $tmpScriptFile.FullName -WhatIf:$false
$expr = @( ".", $tmpScriptFile.FullName, ";", "`n$Function" ) + $expr $expr = @( ".", $tmpScriptFile.FullName, ";", "`n$Function" ) + $expr
} }
$expr = @( $expr = @(
"`n`$WhatIfPreference=`$$WhatIfPreference;", "`n`$WhatIfPreference=`$$WhatIfPreference;",
"`n`$VerbosePreference='$VerbosePreference';", "`n`$VerbosePreference='$VerbosePreference';",
"`n`$ErrorActionPreference='$ErrorActionPreference';", "`n`$ErrorActionPreference='$ErrorActionPreference';",
"`n`$ConfirmPreference='$ConfirmPreference';`n" "`n`$ConfirmPreference='$ConfirmPreference';`n"
) + $expr ) + $expr
if( $MarshalOutput ) { if ( $MarshalOutput ) {
$tmpOutputFile = New-TemporaryFile -WhatIf:$false -Confirm:$false $tmpOutputFile = New-TemporaryFile -WhatIf:$false -Confirm:$false
$expr += @( "| Export-CliXml -Path '$($tmpOutputFile.FullName)'" ) $expr += @( "| Export-CliXml -Path '$($tmpOutputFile.FullName)'" )
}
$expr += @( ";`n exit `$LastExitCode" )
## $tmpScriptContent += "$($expr -join ' ')".Trim()
Write-Verbose "Performing the following command line via SUDO:`n{$sudo_cmd}"
$sudo_cmd = "$($expr -join ' ')".Trim()
do_sudo $sudo_cmd
## do_sudo 'Get-Content' $tmpScriptFile.FullName '|' 'Invoke-Expression' '|' 'Export-Clixml' '-Path' $tmpOutputFile.FullName
#do_sudo $sudo_cmd
if( $tmpScriptFile ) { Remove-Item $tmpScriptFile }
if( $tmpOutputFile ) { Import-Clixml $tmpOutputFile; Remove-Item $tmpOutputFile }
return
} }
Write-Verbose "Perofrming the following expression in-line:`n{$($expr -join ' ')}" $expr += @( ";`n exit `$LastExitCode" )
Invoke-Expression "$expr"
}
function Test-IsAdmin{ ## $tmpScriptContent += "$($expr -join ' ')".Trim()
[CmdletBinding(ConfirmImpact = 'None')] Write-Verbose "Performing the following command line via SUDO:`n{$sudo_cmd}"
[OutputType([bool])]
param ()
switch($true){ $sudo_cmd = "$($expr -join ' ')".Trim()
$( ($PSVersionTable.PSEdition -eq 'Desktop') -or
($PSVersionTable.Platform -eq 'Win32NT') do_sudo $sudo_cmd
) { ## do_sudo 'Get-Content' $tmpScriptFile.FullName '|' 'Invoke-Expression' '|' 'Export-Clixml' '-Path' $tmpOutputFile.FullName
# Fastest way on Windows #do_sudo $sudo_cmd
([Security.Principal.WindowsPrincipal](
[Security.Principal.WindowsIdentity]::GetCurrent() if ( $tmpScriptFile ) { Remove-Item $tmpScriptFile }
)).IsInRole( if ( $tmpOutputFile ) { Import-Clixml $tmpOutputFile; Remove-Item $tmpOutputFile }
[Security.Principal.WindowsBuiltInRole]'Administrator' return
) }
Write-Verbose "Perofrming the following expression in-line:`n{$($expr -join ' ')}"
Invoke-Expression "$expr"
}
function Test-IsAdmin {
[CmdletBinding(ConfirmImpact = 'None')]
[OutputType([bool])]
param()
switch ($true) {
$( ($PSVersionTable.PSEdition -eq 'Desktop') -or
($PSVersionTable.Platform -eq 'Win32NT')
) {
# Fastest way on Windows
([Security.Principal.WindowsPrincipal](
[Security.Principal.WindowsIdentity]::GetCurrent()
)).IsInRole(
[Security.Principal.WindowsBuiltInRole]'Administrator'
)
} }
$( ($PSVersionTable.PSEdition -eq 'Core') -and $( ($PSVersionTable.PSEdition -eq 'Core') -and
($PSVersionTable.Platform -eq 'Unix') ($PSVersionTable.Platform -eq 'Unix')
) { ) {
# On macOS and Linux we use ID to figure out if we run elevated (0 means superuser rights) # On macOS and Linux we use ID to figure out if we run elevated (0 means superuser rights)
return $((id -u) -eq 0) return $((id -u) -eq 0)
} }
default { default {
# Unable to figure it out! # Unable to figure it out!
Write-Warning -Message 'Unknown' Write-Warning -Message 'Unknown'
return return
} }
} }
}
} function Export-FunctionSource {
param(
function Export-FunctionSource {
param(
[switch]$NoHeader, [switch]$NoHeader,
[Parameter(Position = 0, ValueFromRemainingArguments = $true)] [Parameter(Position = 0, ValueFromRemainingArguments = $true)]
#[ValidateSet([Functions])] #[ValidateSet([Functions])]
[string[]]$FunctionName [string[]]$FunctionName
)
) $local:src = ""
foreach ( $local:func in $FunctionName ) {
if ( -not $NoHeader ) { $src += "`nfunction $func {" }
$src += "`n"
$src += $((Get-Command -Type Function $func).Definition) ### .Replace(('$'+'_'),('$$'+'_'))
if ( -not $NoHeader ) { $src += "`n}" }
$src += "`n"
}
return $src.Trim()
}
$local:src = "" # Are we running in Unix or Windows?
foreach( $local:func in $FunctionName ) { $global:PathEnvDelimiter = $(if ( $PSVersionTable.Platform -match 'unix' ) { ':' } else { ';' })
if( -not $NoHeader ) { $src += "`nfunction $func {" } function Split-PathEnv {
$src += "`n" param([string]$EnvPath)
$src += $((Get-Command -Type Function $func).Definition) ### .Replace(('$'+'_'),('$$'+'_'))
if( -not $NoHeader ) { $src += "`n}" }
$src += "`n"
}
return $src.Trim()
}
# Are we running in Unix or Windows?
$global:PathEnvDelimiter = $(if( $PSVersionTable.Platform -match 'unix' ) {':'} else {';'})
function Split-PathEnv {
param([string]$EnvPath)
$EnvPath -split $PathEnvDelimiter $EnvPath -split $PathEnvDelimiter
} }
# Establish Module Path # Establish Module Path
$global:MyPSModulePath = Split-PathEnv $env:PSModulePath | $global:MyPSModulePath = Split-PathEnv $env:PSModulePath |
Where-Object { $_ -match "^$($(Resolve-Path ~) -replace '\\',"\\")" } | Where-Object { $_ -match "^$($(Resolve-Path ~) -replace '\\',"\\")" } |
Where-Object { Test-Path $_ } | Where-Object { Test-Path $_ } |
Get-Item | Sort-Object -Property LastWriteTime -Descending | Get-Item | Sort-Object -Property LastWriteTime -Descending |
Select-Object -ExpandProperty FullName -First 1 Select-Object -ExpandProperty FullName -First 1
if( -not $MyPSModulePath ) { if ( -not $MyPSModulePath ) {
$MyPSModulePath = $(Join-Path $(Join-Path $(Resolve-Path ~) 'powershell') 'Modules') $MyPSModulePath = $(Join-Path $(Join-Path $(Resolve-Path ~) 'powershell') 'Modules')
$env:PSModulePath = "$MyPSModulePath$PathEnvDelimiter$env:PSModulePath" $env:PSModulePath = "$MyPSModulePath$PathEnvDelimiter$env:PSModulePath"
} }
if( -not (Test-Path $MyPSModulePath) ) { if ( -not (Test-Path $MyPSModulePath) ) {
New-Item -ItemType Directory -Path $MyPSModulePath -Force | Out-Null New-Item -ItemType Directory -Path $MyPSModulePath -Force | Out-Null
} }
Write-Verbose $(Get-Item $MyPSModulePath | Select-Object -ExpandProperty FullName) Write-Verbose $(Get-Item $MyPSModulePath | Select-Object -ExpandProperty FullName)
# Establish local/personal Script Root and make sure it's in $env:Path # Establish local/personal Script Root and make sure it's in $env:Path
$local:p = Split-PathEnv $env:PATH $local:p = Split-PathEnv $env:PATH
$MyPSScriptRoot = Join-Path (Split-Path -Parent $MyPSModulePath) Scripts $MyPSScriptRoot = Join-Path (Split-Path -Parent $MyPSModulePath) Scripts
Write-Verbose "MyPSScriptRoot = $MyPSScriptRoot" Write-Verbose "MyPSScriptRoot = $MyPSScriptRoot"
if( -not (Test-Path $MyPSScriptRoot) ) { if ( -not (Test-Path $MyPSScriptRoot) ) {
New-Item -ItemType Directory -Path $MyPSScriptRoot -Force | Out-Null New-Item -ItemType Directory -Path $MyPSScriptRoot -Force | Out-Null
New-Item -ItemType Directory -Path $MyPSScriptRoot/profile.d -Force | Out-Null New-Item -ItemType Directory -Path $MyPSScriptRoot/profile.d -Force | Out-Null
} }
$global:MyPSScriptRoot = $MyPSScriptRoot $global:MyPSScriptRoot = $MyPSScriptRoot
$p = @($p[0], $MyPSScriptRoot) + $($p | Select-Object -Skip 1) $p = @($p[0], $MyPSScriptRoot) + $($p | Select-Object -Skip 1)
$env:PATH = $p -join $PathEnvDelimiter $env:PATH = $p -join $PathEnvDelimiter
} }
if ( -not $MyPSScriptRoot -or (Test-Path function:Test-IsAdmin, function:ConvertTo-Base64, function:Invoke-ExpressionEx, function:Get-PowerShellPath, function:Export-FunctionSource | Where-Object { -not $_ } | Measure-Object | Select-Object -ExpandProperty Count) ) {
if ( -not $MyPSScriptRoot -or (Test-Path function:Test-IsAdmin,function:ConvertTo-Base64,function:Invoke-ExpressionEx,function:Get-PowerShellPath,function:Export-FunctionSource | Where-Object { -not $_ } | Measure-Object | Select-Object -ExpandProperty Count) ) { Write-Verbose "Calling ProfileCode inline..."
Write-Verbose "Calling ProfileCode inline..." . ProfileCode_common
. ProfileCode_common
} }
if( -not $SetupFromWeb ) { if ( -not $SetupFromWeb ) {
_setup @PSBoundParameters _setup @PSBoundParameters
Get-Item function:_setup | Remove-Item Get-Item function:_setup | Remove-Item
} }
Remove-Variable SetupFromWeb -ErrorAction SilentlyContinue Remove-Variable SetupFromWeb -ErrorAction SilentlyContinue