⚡ Format-JSONFilesToSingleLine

Format-JSONFilesToSingleLine


Formats JSON files to a single-line format using the jq utility.

<#
.SYNOPSIS
    Formats JSON files to a single-line format using the jq utility.

.DESCRIPTION
    This script contains two functions: Format-JSONFilesToSingleLine and Format-JSONFileToSingleLine.
    The Format-JSONFilesToSingleLine function accepts a path as input and processes either a single file or all JSON files within a directory to convert them to a single-line format.
    The Format-JSONFileToSingleLine function formats a single JSON file to a single-line format.

.PARAMETER Path
    Specifies the path to either a JSON file or a directory containing JSON files to be formatted.

.EXAMPLE
    Format-JSONFilesToSingleLine -Path "C:\path\to\your\directory"
    Formats all JSON files in the specified directory to a single-line format.

.EXAMPLE
    Format-JSONFileToSingleLine -FilePath "C:\path\to\your\file.json"
    Formats the specified JSON file to a single-line format.

.NOTES
    - Requires the jq utility to be installed and added to the system PATH.
    - Overwrites the original JSON files with their single-line formatted versions.
    - If the jq utility is not installed, the script displays an error message and exits.
    - If the specified file or directory does not exist, the script displays an error message.

    Author: _ka_de
    Date: 2024-04-20
    Version: 1.0
#>

function Format-JSONFilesToSingleLine {
    param (
        [Parameter(Mandatory = $true, ValueFromPipeline = $true, ValueFromPipelineByPropertyName = $true)]
        [string]$Path
    )

    process {
        if (Test-Path $Path -PathType Container) {
            # If the path is a directory, format all JSON files in the directory
            Get-ChildItem -Path $Path -Filter "*.json" | ForEach-Object {
                Format-JSONFileToSingleLine -FilePath $_.FullName
            }
        }
        elseif (Test-Path $Path -PathType Leaf) {
            # If the path is a single file, format that file
            Format-JSONFileToSingleLine -FilePath $Path
        }
        else {
            Write-Host "Invalid path: $Path"
        }
    }
}

function Format-JSONFileToSingleLine {
    param (
        [Parameter(Mandatory = $true)]
        [string]$FilePath
    )

    # Check if jq is installed
    if (-not (Test-Path "jq")) {
        Write-Host "jq is not installed. Please install jq and ensure it's added to the system PATH."
        return
    }

    # Check if the file exists
    if (-not (Test-Path $FilePath -PathType Leaf)) {
        Write-Host "File not found: $FilePath"
        return
    }

    # Construct the command to format the JSON file to single line using jq
    $command = "jq -c . '$FilePath' > '$FilePath.tmp' && move /Y '$FilePath.tmp' '$FilePath'"

    # Execute the command
    Invoke-Expression -Command $command
    Write-Host "Formatted $($FilePath) to single-line successfully."
}

# Usage examples:
# Format a single JSON file to single-line format
# Format-JSONFileToSingleLine -FilePath "C:\path\to\your\file.json"

# Format all JSON files in a directory to single-line format
# Format-JSONFilesToSingleLine -Path "C:\path\to\your\directory"