DimCryGarage.psm1
# MIT License # # Copyright (c) 2020 DimCry's Garage (Cristian Dimofte) # # Permission is hereby granted, free of charge, to any person obtaining a copy # of this software and associated documentation files (the "Software"), to deal # in the Software without restriction, including without limitation the rights # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell # copies of the Software, and to permit persons to whom the Software is # furnished to do so, subject to the following conditions: # # The above copyright notice and this permission notice shall be included in all # copies or substantial portions of the Software. # # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE # SOFTWARE. # Description: ### This module contains common useful functions # Author: ### DimCry (Cristian Dimofte) ##################################### # Common space for Global variables # ##################################### #region "Global variables" ### TheWorkingDirectory (Global: Script) variable is used to list the exact value for the Working Directory $Global:TheWorkingDirectory = $null #endregion "Global variables" ##################################### # Common space for Functions # ##################################### #region "Functions" <# .SYNOPSIS Function to export content from a String or TableStructure to HTML report .DESCRIPTION Function "Export-ReportToHTML" is used to export content from a String or TableStructure to HTML report. It can create the HTML report using different themes (for the moment just the "Blue" / default one is defined). .EXAMPLE Export-ReportToHTML -FilePath $FilePath -PageTitle $PageTitle -ReportTitle $ReportTitle -TheObjectToConvertToHTML $TheObjectToConvertToHTML Description ----------- This example is exporting the information into the $FilePath HTML report .NOTES This function can be used to convert any correctly formatted PowerShell content to an HTML report. #> function Export-ReportToHTML { param( [Parameter(Mandatory=$true)] [string]$FilePath, [Parameter(Mandatory=$false)] [string]$PageTitle, [Parameter(Mandatory=$false)] [string]$ReportTitle, [Parameter(Mandatory=$true)] [System.Collections.ArrayList]$TheObjectToConvertToHTML, [Parameter(Mandatory=$false)] [ValidateSet("Blue")] [string]$Theme = "Blue" ) ### Create header of the HTML file if ($Theme -eq "Blue") { $HTMLBeginning = @" <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta name="description" content="DimCry's Garage"> <meta name="keywords" content="PowerShell, HTML, Report, DimCry, Garage"> <meta name="author" content="Cristian Dimofte"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>$PageTitle</title> <link rel="titlebar icon" href="" /> <link rel="stylesheet" href="https://static2.sharepointonline.com/files/fabric/office-ui-fabric-js/1.4.0/css/fabric.min.css" /> <link rel="stylesheet" href="https://static2.sharepointonline.com/files/fabric/office-ui-fabric-js/1.4.0/css/fabric.components.min.css" /> <script src="https://static2.sharepointonline.com/files/fabric/office-ui-fabric-js/1.4.0/js/fabric.min.js"></script> <style type="text/css"> html { box-sizing: border-box; font-family: FabricMDL2Icons; } *, *:before, *:after { box-sizing: inherit; } .ms-font-su { font-family:FabricMDL2Icons; -webkit-font-smoothing:antialiased; font-weight:100 } .ms-fontColor-themePrimary,.ms-fontColor-themePrimary--hover:hover{ color:#0078d7 } @font-face{ font-family:FabricMDL2Icons; src:url(https://spoprod-a.akamaihd.net/files/fabric/assets/icons/fabricmdl2icons.woff) format('woff'),url(https://spoprod-a.akamaihd.net/files/fabric/assets/icons/fabricmdl2icons.ttf) format('truetype'); font-weight:400; font-style:normal } body { padding: 10px; font-family: FabricMDL2Icons; background: #f6f6f6; } a { color: #06c; } h1 { margin: 0 0 1.5em; font-weight: 600; font-size: 1.5em; } h2 { color: #1a0e0e; font-size: 20px; font-weight: 700; margin: 0; line-height: normal; text-transform:uppercase; margin-block-start: 0.3em; margin-block-end: 0.3em; text-indent: 0px; margin-left: 0px; } h2 span { display: block; padding: 0; font-size: 18px; opacity: 0.7; margin-top: 5px; text-transform:uppercase; } h3 { color: #000000; font-size: 17px; font-weight: 300; margin-left: 10px; font-family: FabricMDL2Icons; } h3 span { color: #000000; font-size: 17px; font-weight: 300; margin-left: 10px; font-family: FabricMDL2Icons; } h5 { display: block; padding: 0; margin: 5px 0px 0px 0px; font-size: 42px; font-weight: 100; font-family: FabricMDL2Icons; } p { margin: 0 0 1em; padding: 10px; font-family: FabricMDL2Icons; } .ms-icon--description:before { font-family: FabricMDL2Icons; content: "\EA16"; color: #0078d7; margin-right: 5px; font-style: normal; font-size: 20px; } .ms-icon--emojineutral:before { font-family: FabricMDL2Icons; content: "\EA87"; margin-left: 25px; margin-right: -15px; font-style: normal; } .ms-icon--emojihappy:before { font-family: FabricMDL2Icons; content: "\E76E"; margin-left: 25px; margin-right: -15px; font-style: normal; } .ms-icon--emojidisappointed:before { font-family: FabricMDL2Icons; content: "\EA88"; margin-left: 25px; margin-right: -15px; font-style: normal; } .label { width: 100%; height: 80px; background-color: #0078d7; color: #ffffff; font-size: 46px; display: inline-block; } .label1 { width: 100%; height: 80px; background-color: #f6f6f6; color: #0078d7; font-size: 46px; display: inline-block; box-sizing: border-box; } .body-panel { font-size: 14px; padding: 15px; margin-bottom: 5px; margin-top: 5px; box-shadow: 0 1px 2px 0 rgba(0,0,0,.1); overflow-x: auto; box-sizing: border-box; background-color: #fff; color: #333; -webkit-tap-highlight-color: rgba(0,0,0,0); padding-top: 15px; font-family: FabricMDL2Icons; } .accordion { margin-bottom: 1em; } .accordion p:last-child { margin-bottom: 0; } .accordion > input[name="collapse"] { display: none; } .accordion > input[name="collapse"]:checked ~ .content { height: auto; transition: height 0.5s; } .accordion label, .accordion .content { max-width: 3200px; width: 99%; } .accordion .content { background: #fff; overflow: hidden; overflow-x: auto; height: 0; transition: 0.5s; box-shadow: 1px 2px 4px rgba(0, 0, 0, 0.3); } .accordion label { display: block; } .accordion > input[name="collapse"]:checked ~ .content { border-top: 0; transition: 0.3s; } .accordion .handle { margin: 0; font-size: 16px; } .accordion label { color: #0078d7; cursor: pointer; font-weight: 300; padding: 10px; background: #e6f3ff; user-select: none; } .accordion label:hover, .accordion label:focus { background: #cce6ff; color: #0000ff; } .accordion .handle label:before { font-family: FabricMDL2Icons; content: "\E972"; display: inline-block; margin-right: -20px; font-size: 1em; line-height: 1.556em; vertical-align: middle; transition: 0.4s; } .accordion > input[name="collapse"]:checked ~ .handle label:before { transform: rotate(180deg); transform-origin: center; transition: 0.4s; } section { float: left; width: 100%; } .container{ max-width: 3200px; width:99%; margin: 0 auto; } table { font-size: 14px; font-weight: 800; border: 1px solid #0078d7; border-collapse: collapse; font-family: FabricMDL2Icons; margin-left: 10px; margin-bottom: 10px; margin-right: 10px; text-align: center; } td { padding: 4px; margin: 0px; border: 1px solid #0078d7; border-collapse: collapse; } th { color: #0078d7; font-family: FabricMDL2Icons; text-transform: uppercase; padding: 10px 5px; vertical-align: middle; border: 1px solid #0078d7; border-collapse: collapse; } tbody tr:nth-child(odd) { background: #f0f0f2; } #output { color: #004377; font-size: 14px; } @media screen and (max-width:639px){ h2 { color: #1a0e0e; font-size: 16px; font-weight: 700; margin: 0; line-height: normal; text-transform:uppercase; text-indent: 0px; margin-left: 0px; } h5 { margin: 5px 0px 0px 0px; font-size: 8vw; font-weight: 100; font-family: FabricMDL2Icons; } .accordion label, .accordion .content { max-width: 3200px; width: 99%; } .accordion .content { background: #fff; overflow: hidden; overflow-x: auto; height: 0; transition: 0.5s; box-shadow: 1px 2px 4px rgba(0, 0, 0, 0.3); } .accordion > input[name="collapse"]:checked ~ .content { height: auto; } } @media (max-device-width:480px) and (orientation:landscape) { .body-panel { max-height:200px } } /* For Desktop */ @media only screen and (min-width: 620px) { .accordion > input[name="collapse"]:checked ~ .content { height: auto; } } .ms-icon--HTMLReport:before { font-family: FabricMDL2Icons; content: "\E9D9"; font-size: 120px; color: #0078d7; font-style: normal; } </style> </head> <body class="ms-Fabric" dir="ltr"> <header> <div class="label1"> <a href="https://github.com/dimcry/DimCry-Garage" target="_blank"> <img src="" alt="DimCry's Garage" width="auto" height="110%" style="float: left; margin-right: 5px"> </a> <div style="width: 100%; height: 100%; "> <h5 class="ms-font-su ms-fontColor-themePrimary" style="font-weight: 350; "> $ReportTitle </h5> </div> </div> </header> <div class="body-panel" style="margin: 30px 0px 0px 0px; display: block;"> "@ $HTMLEnd = @" </div> <div class="ms-font-su ms-fontColor-themePrimary" style="font-size: 15px; margin-left: 10px; text-align: right;"> <ul>Creation Date: $((Get-date).ToUniversalTime()) UTC</ul> <ul>© 2020 DimCry's Garage</ul> </div> </body> </html> "@ } [int]$i = 1 [string]$TheBody = $HTMLBeginning ### For each scenario, convert the data to HTML foreach ($Entry in $TheObjectToConvertToHTML) { [string]$Emoji = $null if ($Entry.SectionTitleColor -eq "Green") { $Emoji = "happy" } elseif ($Entry.SectionTitleColor -eq "Red") { $Emoji = "disappointed" } else { $Emoji = "neutral" } $TheBody = $TheBody + " `<section class=`"accordion`"`> `<input type=`"checkbox`" name=`"collapse`" id=`"handle$i`" `> `<h2 class=`"handle`"`> `<label for=`"handle$i`" `> `<h2 class=`"ms-font-su ms-fontColor-themePrimary`" style=`"display: inline-block; color: $($Entry.SectionTitleColor); font-size: 20px; font-weight: 650;`"`>`<i class=`"ms-icon ms-icon--emoji$Emoji`"`>`</i`> $($Entry.SectionTitle)`</h2`> `</label`> `</h2`> `<div class=`"content`"`> `<h3`>`<i class=`"ms-icon ms-icon--description`"`>`<`/i`>$($Entry.Description)`</h3`> " if ($Entry.DataType -eq "String") { $TheValue = " `<p style=`"font-family: FabricMDL2Icons; font-weight: 800; margin-left: 10px;`"`>$($Entry.EffectiveData)`<`/p>" } else { $TheProperties = ($($Entry.EffectiveData)| Get-Member -MemberType NoteProperty).Name $TheValue = $($Entry.EffectiveData) | ConvertTo-Html -As $($Entry.TableType) -Property $TheProperties -Fragment if ($Entry.TableType -eq "List") { [int]$z = 0 foreach ($NewEntryFound in $TheValue) { if ($NewEntryFound -like "*<table>*") { $TheValue.Item($z) = $NewEntryFound.Replace("<table>", "<table style=`"text-align: left;`">") } elseif ($NewEntryFound -like "*<tr><td>*") { $TheValue.Item($z) = $NewEntryFound.Replace("<tr><td>", "<tr><th>") $TheValue.Item($z) = (($TheValue.Item($z) -split "<td")[0] -replace "`/td>", "`/th>") + ($TheValue.Item($z).Substring((($TheValue.Item($z) -split "<td")[0].Length),($TheValue.Item($z).Length-($TheValue.Item($z) -split "<td")[0].Length))) } $z++ } } } ### Adding sections in the body of the HTML report $TheBody = $TheBody + $TheValue $TheBody = $TheBody + " `<`/div`> `<`/section`> " $i++ } $TheBody = $TheBody + $HTMLEnd $TheBody | Out-File $FilePath -Force } <# .SYNOPSIS "Prepare-ObjectForHTMLReport" function is used to prepare the objects to be converted to HTML file .DESCRIPTION "Prepare-ObjectForHTMLReport" function is used to prepare the objects to be converted to HTML file .EXAMPLE [PSCustomObject]$TheCommand = Prepare-ObjectForHTMLReport -SectionTitle $SectionTitle -SectionTitleColor $SectionTitleColor -Description $Description -DataType "String" -EffectiveDataString $TheString Description ----------- This example is preparing an object that has a string as DataType, to be listed into the HTML report .EXAMPLE [PSCustomObject]$TheCommand = Prepare-ObjectForHTMLReport -SectionTitle $SectionTitle -SectionTitleColor $SectionTitleColor -Description $Description -DataType "TableStructure" -EffectiveDataTableStructure $TheTable -TableType "List" Description ----------- This example is preparing an object that has a TableStructure as DataType, to be listed as a List into the HTML report .EXAMPLE [PSCustomObject]$TheCommand = Prepare-ObjectForHTMLReport -SectionTitle $SectionTitle -SectionTitleColor $SectionTitleColor -Description $Description -DataType "TableStructure" -EffectiveDataTableStructure $TheTable -TableType "Table" Description ----------- This example is preparing an object that has a TableStructure as DataType, to be listed as a Table into the HTML report .NOTES This function can be used to correctly prepare any PowerShell content to be exported to an HTML report #> function Prepare-ObjectForHTMLReport { param ( [Parameter(ParameterSetName = "String", Mandatory=$false)] [Parameter(ParameterSetName = "TableStructure", Mandatory=$false)] [string]$SectionTitle, [Parameter(ParameterSetName = "String", Mandatory=$false)] [Parameter(ParameterSetName = "TableStructure", Mandatory=$false)] [ValidateSet("Black", "Green", "Red")] [ConsoleColor]$SectionTitleColor, [Parameter(ParameterSetName = "String", Mandatory=$false)] [Parameter(ParameterSetName = "TableStructure", Mandatory=$false)] [string]$Description, [Parameter(ParameterSetName = "String", Mandatory=$false)] [Parameter(ParameterSetName = "TableStructure", Mandatory=$false)] [ValidateSet("TableStructure", "String")] [string]$DataType, [Parameter(ParameterSetName = "String", Mandatory=$false)] [string]$EffectiveDataString, [Parameter(ParameterSetName = "TableStructure", Mandatory=$false)] [PSCustomObject]$EffectiveDataTableStructure, [Parameter(ParameterSetName = "TableStructure", Mandatory=$false)] [ValidateSet("List", "Table")] [string]$TableType ) ###Create the object, with all needed Properties, that will be used to convert into an HTML report $TheObject = New-Object PSObject $TheObject | Add-Member -NotePropertyName SectionTitle -NotePropertyValue $SectionTitle $TheObject | Add-Member -NotePropertyName SectionTitleColor -NotePropertyValue $SectionTitleColor $TheObject | Add-Member -NotePropertyName Description -NotePropertyValue $Description $TheObject | Add-Member -NotePropertyName DataType -NotePropertyValue $DataType if ($DataType -eq "TableStructure") { $TheObject | Add-Member -NotePropertyName EffectiveData -NotePropertyValue $EffectiveDataTableStructure $TheObject | Add-Member -NotePropertyName TableType -NotePropertyValue $TableType } else { $TheObject | Add-Member -NotePropertyName EffectiveData -NotePropertyValue $EffectiveDataString } ### Return the created object return $TheObject } function Test-ExportReportToHTMLUsingDummyData { [System.Collections.ArrayList]$TheObjectToConvertToHTML = @() ### "String1" section [string]$SectionTitle = "This is the title of the `"String1`" section" [ConsoleColor]$SectionTitleColor = "Green" [string]$Description = "This is the description of the `"String1`" section" [string]$TheString = "This is the content of the `"String1`" section" [PSCustomObject]$TheCommand = Prepare-ObjectForHTMLReport -SectionTitle $SectionTitle -SectionTitleColor $SectionTitleColor -Description $Description -DataType "String" -EffectiveDataString $TheString $null = $TheObjectToConvertToHTML.Add($TheCommand) ### "List" section [string]$SectionTitle = "This is the title of the `"List`" section" [ConsoleColor]$SectionTitleColor = "Black" [string]$Description = "This is the description of the `"List`" section" [System.Collections.ArrayList]$TheTable = @() $AList = New-Object PSObject $AList | Add-Member -NotePropertyName FirstRow -NotePropertyValue "A value of the first row" $AList | Add-Member -NotePropertyName SecondRow -NotePropertyValue "A value of the second row" $AList | Add-Member -NotePropertyName ThirdRow -NotePropertyValue "A value of the third row" $AList | Add-Member -NotePropertyName FourthRow -NotePropertyValue "A value of the fourth row" $AList | Add-Member -NotePropertyName FifthRow -NotePropertyValue "A value of the fifth row" $null = $TheTable.Add($AList) [PSCustomObject]$TheCommand = Prepare-ObjectForHTMLReport -SectionTitle $SectionTitle -SectionTitleColor $SectionTitleColor -Description $Description -DataType "TableStructure" -EffectiveDataTableStructure $TheTable -TableType "List" $null = $TheObjectToConvertToHTML.Add($TheCommand) ### "Table" section [string]$SectionTitle = "This is the title of the `"Table`" section" [ConsoleColor]$SectionTitleColor = "Red" [string]$Description = "This is the description of the `"Table`" section" [System.Collections.ArrayList]$TheTable = @() $ATable = New-Object PSObject $ATable | Add-Member -NotePropertyName FirstRow -NotePropertyValue "A value of the first column" $ATable | Add-Member -NotePropertyName SecondRow -NotePropertyValue "A value of the second column" $ATable | Add-Member -NotePropertyName ThirdRow -NotePropertyValue "A value of the third column" $ATable | Add-Member -NotePropertyName FourthRow -NotePropertyValue "A value of the fourth column" $ATable | Add-Member -NotePropertyName FifthRow -NotePropertyValue "A value of the fifth column" $null = $TheTable.Add($ATable) $ATable = New-Object PSObject $ATable | Add-Member -NotePropertyName FirstRow -NotePropertyValue "Another value of the first column" $ATable | Add-Member -NotePropertyName SecondRow -NotePropertyValue "Another value of the second column" $ATable | Add-Member -NotePropertyName ThirdRow -NotePropertyValue "Another value of the third column" $ATable | Add-Member -NotePropertyName FourthRow -NotePropertyValue "Another value of the fourth column" $ATable | Add-Member -NotePropertyName FifthRow -NotePropertyValue "Another value of the fifth column" $null = $TheTable.Add($ATable) [PSCustomObject]$TheCommand = Prepare-ObjectForHTMLReport -SectionTitle $SectionTitle -SectionTitleColor $SectionTitleColor -Description $Description -DataType "TableStructure" -EffectiveDataTableStructure $TheTable -TableType "Table" $null = $TheObjectToConvertToHTML.Add($TheCommand) ### "String2" section [string]$SectionTitle = "This is the title of the `"String2`" section" [ConsoleColor]$SectionTitleColor = "Black" [string]$Description = "This is the description of the `"String2`" section" [string]$TheString = "This is the content of the `"String2`" section" [PSCustomObject]$TheCommand = Prepare-ObjectForHTMLReport -SectionTitle $SectionTitle -SectionTitleColor $SectionTitleColor -Description $Description -DataType "String" -EffectiveDataString $TheString $null = $TheObjectToConvertToHTML.Add($TheCommand) # Export the content to an HTML report ### Create the folder, if doesn't exist $null = New-Item -ItemType Directory "$Env:Temp\DimCryGarage" -Force ### Manually set a name of the file $FilePath = "$Env:Temp\DimCryGarage\HTMLReport.HTML" $PageTitle = "This is the title of the page" $ReportTitle = "This is the title of the report" Export-ReportToHTML -FilePath $FilePath -PageTitle $PageTitle -ReportTitle $ReportTitle -TheObjectToConvertToHTML $TheObjectToConvertToHTML Write-Host "The HTML report is located on:" -ForegroundColor White Write-Host "`tLong path: " -ForegroundColor White -NoNewline Write-Host "$Env:Temp\DimCryGarage\HTMLReport.HTML" -ForegroundColor Cyan Write-Host "`tShort path: " -ForegroundColor White -NoNewline Write-Host "%temp%\DimCryGarage\HTMLReport.HTML" -ForegroundColor Cyan } #endregion "Functions" |