Public/Get-ScriptMessageConfig.ps1

function Get-ScriptMessageConfig
{
    <#
        .LINK
        https://github.com/Sekers/ScriptMessage/wiki

        .SYNOPSIS
        Get the configuration and secrets to connect to the messaging service(s).

        .DESCRIPTION
       Get the configuration and secrets to connect to the messaging service(s).

        .PARAMETER ConfigPath
        Optional. If not provided, the function will use the path used in the current session (if set).

        .EXAMPLE
        Get-ScriptMessageConfig
        .EXAMPLE
        Get-ScriptMessageConfig -Path '.\Config\config_scriptmessage.json'
    #>


    [CmdletBinding()]
    param(
        [Parameter(
        Position=0,
        ValueFromPipeline=$true,
        ValueFromPipelineByPropertyName=$true)]
        [string]$Path = $scriptmessage_config_file_path # If not entered will see if it can pull path from this variable.
    )
    
    begin {}

    process
    {
        # Make Sure Requested Path Isn't Null or Empty (better to catch it here than validating on the parameter of this function)
        if ([string]::IsNullOrEmpty($Path))
        {
            throw "`'`$scriptmessage_config_file_path`' is not specified. Don't forget to first use the `'Set-ScriptMessageConfigFilePath`' cmdlet!"
        }

        # Get Config and Secrets
        try
        {
            $ScriptMessageConfig = Get-Content -Path "$Path" -ErrorAction 'Stop' | ConvertFrom-Json
            return $ScriptMessageConfig 
        }
        catch
        {
            throw "Can't find the JSON configuration file. Use 'Set-ScriptMessageConfigFilePath' to create one."
        }
    }

    end {}
}