Added add-firewall-rules.ps1

This commit is contained in:
Markus Fleschutz 2021-01-28 15:02:16 +01:00
parent f350629396
commit 9a30e78a82
4 changed files with 79 additions and 0 deletions

View File

@ -1,4 +1,5 @@
Filename,Description
add-firewall-rules.ps1, adds firewall rules to the given executables, requires admin rights
check-ipv4-address.ps1, checks the given IPv4 address for validity
check-mac-address.ps1, checks the given MAC address for validity
check-xml-file.ps1, checks the given XML file for validity

1 Filename Filename,Description Description
2 add-firewall-rules.ps1, adds firewall rules to the given executables, requires admin rights
3 check-ipv4-address.ps1 check-ipv4-address.ps1, checks the given IPv4 address for validity checks the given IPv4 address for validity
4 check-mac-address.ps1 check-mac-address.ps1, checks the given MAC address for validity checks the given MAC address for validity
5 check-xml-file.ps1 check-xml-file.ps1, checks the given XML file for validity checks the given XML file for validity

View File

@ -7,6 +7,7 @@ List of Scripts
---------------
The following PowerShell scripts can be found in the [Scripts/](Scripts/) subfolder:
* [add-firewall-rules.ps1](Scripts/add-firewall-rules.ps1) - adds firewall rules for the given executables
* [check-ipv4-address.ps1](Scripts/check-ipv4-address.ps1) - checks the given IPv4 address for validity
* [check-mac-address.ps1](Scripts/check-mac-address.ps1) - checks the given MAC address for validity
* [check-xml-file.ps1](Scripts/check-xml-file.ps1) - checks the given XML file for validity

77
Scripts/add-firewall-rules.ps1 Executable file
View File

@ -0,0 +1,77 @@
#!/snap/bin/powershell
<#
.SYNTAX ./add-firewall-rules.ps1 [<path-to-executables>]
.DESCRIPTION adds firewall rules for the given executables, administrator rights are required
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
#Requires -RunAsAdministrator
param([string]$PathToExecutables)
$command = '
$output = ''Firewall rules for path '' + $args[0]
write-output $output
for($i = 1; $i -lt $args.count; $i++){
$path = $args[0]
$path += ''\''
$path += $args[$i]
$null = $args[$i] -match ''[^\\]*\.exe$''
$name = $matches[0]
$output = ''Adding firewall rule for '' + $name
write-output $output
$null = New-NetFirewallRule -DisplayName $name -Direction Inbound -Program $path -Profile Domain, Private -Action Allow
}
Write-Host -NoNewLine ''Done - press any key to continue...'';
$null = $Host.UI.RawUI.ReadKey(''NoEcho,IncludeKeyDown'');
'
#get current path
$path = get-location
$path = Convert-Path -Path $path
if(test-path "$path\executables"){
#get all executables
$Apps = @()
$Apps += Get-ChildItem "$path\executables\*.exe" -Name
for($i = 0; $i -lt $Apps.length; $i++){
$Apps[$i] = "executables\" + $Apps[$i]
}
#Add 64bit Apps (if applicable)
$Apps64 = @()
if(test-path "$path\executables64"){
#only try if 64bit executables are present
$Apps64 += Get-ChildItem "$path\executables64\*.exe" -Name
for($i = 0; $i -lt $Apps64.length; $i++){
$Apps64[$i] = "executables64\" + $Apps64[$i]
}
$Apps += $Apps64
}
#Add all Java runtimes delivered
$subdirs = get-childitem $path\jre
foreach($item in $subdirs){
if($item.PSIsContainer){
$itempath = $item.BaseName
$itempath += "\bin\javaw.exe"
$itempath = "jre\$itempath"
if(test-path("$path\$itempath")){
$Apps += $itempath
}
}
}
if($Apps.count -eq 0){
Write-Warning "No executables found. No Firewall rules have been created."
Write-Host -NoNewhLine 'Press any key to continue...';
$null = $Host.UI.RawUI.ReadKey('NoEcho,IncludeKeyDown');
}else{
$arg = "$path $Apps"
Start-Process powershell -Verb runAs -ArgumentList "-command & {$command} $arg"
}
}else{
write-warning "Cannot find executables path. The script must be executed in ATTower root directory"
Write-Host -NoNewLine 'Press any key to continue...';
$null = $Host.UI.RawUI.ReadKey('NoEcho,IncludeKeyDown');
}
exit 0

0
Scripts/set-wallpaper.ps1 Normal file → Executable file
View File