Public/Set-Space.ps1

<#
.SYNOPSIS
Sets the current space for the Octopus connection and saves it to your configuration if one exists.
 
.DESCRIPTION
This function sets the current space for the Octopus connection and saves it to your configuration if one exists. It takes either the name or ID of the space as input.
 
.PARAMETER Name
Specifies the name of the space to set.
 
.PARAMETER Id
Specifies the ID of the space to set.
 
.EXAMPLE
Set-Space "MySpace"
Sets the current space to the space with the name "MySpace".
 
.EXAMPLE
Set-Space -Id "Spaces-1"
Sets the current space to the space with the ID "Spaces-1".
 
.NOTES
This function requires an active connection to an Octopus server. Use Test-OctopusConnection to test the connection before calling this function.
#>


function Set-Space {
    [cmdletBinding()]
    param (
        # Specifies a path to one or more locations.
        [Parameter(Mandatory = $true,
            Position = 0,
            ParameterSetName = "Name",
            ValueFromPipeline = $true)]
        [Alias("SpaceName")]
        [ValidateNotNullOrEmpty()]
        [string]
        $Name,
        [Parameter(Mandatory = $true,
            ParameterSetName = "ID",
            ValueFromPipelineByPropertyName = $true)]
        [Alias("SpaceId")]
        [ValidateNotNullOrEmpty()]
        [string]
        $Id

    )
    begin {
        try {
            ValidateConnection
        }
        catch {
            $PSCmdlet.ThrowTerminatingError($_)
        }
    }
    process {
        # call SetSpace to set the space
        SetSpace @PSBoundParameters

        #get space object
        if ($PSCmdlet.ParameterSetName -eq "name") {
            $space = Get-Space | Where-Object name -EQ $name
        } else {
            $space = Get-Space | Where-Object id -EQ $id
        }
        # save the space in the configuration file if one exists
        $config = Get-ConnectionConfiguration
        if (($config.space -ne $space.name) -and ($null -ne $config)) {
            Write-Verbose "Setting space in config file to $($space.name)"
            Set-ConnectionConfiguration -Space $space.name
        }

    }

}