-
Notifications
You must be signed in to change notification settings - Fork 0
/
Pils.psm1
74 lines (67 loc) · 2.03 KB
/
Pils.psm1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
function WriteLog
{
param(
[Parameter(ParameterSetName="Message",Mandatory=$true)]
[String]$Message,
[Parameter(ParameterSetName="Message",Mandatory=$true)][ValidateSet('Information','Warning','Error')]
[String]$Severity,
[Parameter(ParameterSetName="CustomMessage",Mandatory=$true)]
[String]$CustomMessage
)
begin
{
$Date = Get-Date
$DateMessage = $Date | Get-Date -Format "dd-MM-yyyy HH:mm:ss"
$DateLog = $Date | Get-Date -Format "yyyy-MM-dd HH:mm:ss"
$DateLogFileName = $Date | Get-Date -Format "yyyyMMdd"
if ($PILSLogFilePrefix)
{
$LogFilePrefix = $PILSLogFilePrefix
}
else
{
$LogFilePrefix = "PILS"
}
if ($PILSLogFolder)
{
$LogFolder = $PILSLogFolder
}
else
{
$LogFolder = $env:TEMP
}
$LogFilePath = Join-Path -Path $LogFolder -ChildPath ($LogFilePrefix + "-" + $DateLogFileName + ".txt")
}
process
{
if($Message)
{
Write-Host "[$DateMessage] " -NoNewline
Write-Host "[" -NoNewline
switch ($Severity)
{
"Information"
{
Write-Host -ForegroundColor Cyan "Information" -NoNewline
}
"Warning"
{
Write-Host -ForegroundColor Yellow "Warning " -NoNewline
}
"Error"
{
Write-Host -ForegroundColor Red "Error " -NoNewline
}
}
Write-Host "] " -NoNewline
Write-Host $Message
"[$DateLog] - $Severity - $Message" | Out-File -FilePath $LogFilePath -Append
}
if($CustomMessage)
{
Write-Output "[$DateMessage] $CustomMessage
"[$DateLog] $CustomMessage | Out-File -FilePath $LogFilePath -Append
}
}
end {}
}