Public/Set-PSRyverConfigPath.ps1

function Set-PSRyverConfigPath {
    <#
    .SYNOPSIS
        Sets the PSRyver config file path.
 
    .DESCRIPTION
        Sets the PSRyver config file path.
 
    .INPUTS
        System.IO.FileInfo
 
    .NOTES
        - Troy Lindsay
        - Twitter: @troylindsay42
        - GitHub: tlindsay42
 
    .EXAMPLE
        Set-PSRyverConfigPath -Path '~/.psryver.xml'
        Sets the PSRyver config file path.
 
    .EXAMPLE
        '~/.psryver.xml' | Set-PSRyverConfigPath
        Sets the PSRyver config file path via the pipeline.
 
    .EXAMPLE
        Set-PSRyverConfigPath '~/.psryver.xml'
        Sets the PSRyver config file path via positional parameter.
 
    .LINK
        https://tlindsay42.github.io/PSRyver/Public/Set-PSRyverConfigPath/
 
    .LINK
        https://github.com/tlindsay42/PSRyver/blob/master/PSRyver/Public/Set-PSRyverConfigPath.ps1
 
    .LINK
        Get-PSRyverConfigPath
 
    .FUNCTIONALITY
        Ryver
    #>

    [CmdletBinding(
        HelpUri = 'https://tlindsay42.github.io/PSRyver/Public/Set-PSRyverConfigPath/',
        SupportsShouldProcess = $true,
        ConfirmImpact = 'High'
    )]
    [OutputType( [System.IO.FileInfo] )]
    param (
        # Specifies the PSRyver config file path that will be used as the default.
        [Parameter(
            Mandatory = $true,
            Position = 0,
            ValueFromPipeline = $true
        )]
        [ValidateScript( { Test-Path -Path $_ -IsValid } )]
        [System.IO.FileInfo]
        $Path
    )

    begin {
        $function = $MyInvocation.MyCommand.Name

        Write-Verbose -Message (
            "Beginning: '${function}' with ParameterSetName '$( $PSCmdlet.ParameterSetName )' and Parameters: " +
            ( $PSBoundParameters | Remove-SensitiveData | Format-Table -AutoSize | Out-String )
        )
    }

    process {
        $proceed = $true
        if ( $Script:PSRyverConfigFilePath -and $Script:PSRyverConfigFilePath.FullName -ne $Path.FullName ) {
            $proceed = $PSCmdlet.ShouldProcess( '$Script:PSRyverConfigFilePath', 'Set the default PSRyver config file path for this session' )
        }

        if ( $proceed ) {
            if ( ( Test-Path -Path $Path ) -eq $true ) {
                $Script:PSRyverConfigFilePath = Get-Item -Path $Path -ErrorAction 'Stop'
            }
            else {
                $Script:PSRyverConfigFilePath = $Path
            }
        }
    }

    end {
        Write-Verbose -Message "Ending: '${function}'."
    }
}