With the migration of our little blog I’m also trying move the help content for various PowerShell scripts/modules to a central location and make updating/managing that content easier. I’ve recently found the platyPS module, which can be used to create markdown formatted files for PowerShell help topics.

Now you might have read that our blog is powered by Jekyll, which is just a static-site generator for markdown files. So, obviously, if I would be able to convert PowerShell help content to markdown files, I could simply put them into a folder an serve them via the blog.

Create markdown files

The first step is to install platyPS (available on the PS Gallery) and create the markdown files for every function.

Install-Module platyPS
Import-Module platyPS, tak

foreach ($cmdlet in (Get-Command -Module tak)) { 
    $meta = @{
        'layout' = 'post';
        'author' = 'thomas torggler';
        'title' = $($cmdlet.Name);
        'category' = $($cmdlet.ModuleName).ToUpper();
        'tags' = 'OnlineHelp PowerShell';
    }
    New-MarkdownHelp -Command $cmdlet -OutputFolder tak-md-help -Metadata $meta -Force 
}

The above example creates a .md help file for every function in the tak module. The files are almost ready to be used by our Jekyll-powered blog, I’m using the -Metadata parameter to add some additional information to the ‘front matter’ of each file.

Note: I could be using New-MarkdownHelp -Module tak but that way, I was not able to include the metadata automatically.

Rename files for Jekyll

The only thing that I have to do now, in order to have Jekyll pick up the files and create websites, is to rename them accordingly.

foreach ($file in (Get-ChildItem '.\tak-md-help\*.md')) {
    $timestamp = (Get-Date -Format 'yyyy-MM-dd')
    $NewName = $timestamp, $file.name -join '-'
    Rename-Item -Path $file.FullName -NewName $NewName
}

The above example renames all *.md files in the tak-md-help folder to include a timestamp.

Note: PlatyPS does currently not work on macOS/Linux editions of PowerShell.

Include HelpUri

The Get-Help command has an -Online parameter, that can be used to easily open a related link when looking for help. To include this functionality in my scripts, I just have to put the URL of the online article in the [CmdletBinding()] statement, like so:

[CmdletBinding(HelpUri = 'https://ntsystems.it/PowerShell/TAK/test-tlsconnection/')]

That’s it :) Tom