173 lines
6.7 KiB
PowerShell
173 lines
6.7 KiB
PowerShell
# 7zip_to_netapp.ps1
|
|
# Author: F. Bischof (info@meer-web.nl)
|
|
# Version 3.0.1
|
|
|
|
# Set global vars
|
|
$MAX_FOLDER_SIZE = "500GB"
|
|
$TIMESTAMP = Get-Date -Format "yyyyMMddHHmm"
|
|
$TARGET_FILENAME = "${TIMESTAMP}-archive.7z"
|
|
$CSVFILE = "C:\Scripts\movethis.csv"
|
|
$LOGFILE = "C:\Scripts\$TIMESTAMP.log"
|
|
|
|
# Writelog function
|
|
if (!(test-path $LOGFILE)) {
|
|
New-Item -ItemType File $LOGFILE
|
|
}
|
|
function WRITELOG {
|
|
Param ([string]$LOGSTRING)
|
|
$LOG_TIMESTAMP = (Get-Date).toString("yyyy/MM/dd HH:mm:ss")
|
|
$LOGMESSAGE = "${LOG_TIMESTAMP}: ${LOGSTRING}"
|
|
Add-content $LOGFILE -value $LOGMESSAGE
|
|
Write-Host "${LOGMESSAGE}"
|
|
}
|
|
WRITELOG "=========================== Archiving started ==========================="
|
|
|
|
# Check if CSV file exists
|
|
if (test-path $CSVFILE) {
|
|
WRITELOG "Loading CSV file $CSVFILE"
|
|
} else {
|
|
WRITELOG "CSV file not found! ($CSVFILE)"
|
|
Write-Output "$CSVFILE does not exists!"
|
|
exit
|
|
}
|
|
|
|
# Rebuild CSV file to be valid
|
|
(Get-Content $CSVFILE | Select-Object -Skip 1) | Set-Content $CSVFILE ## Remove first line
|
|
"FROM,TO`n" + (Get-Content $CSVFILE -Raw) | Set-Content $CSVFILE ## Add FROM,TO to CSV file
|
|
(Get-Content $CSVFILE) | Where-Object {$_.trim() -ne "" } | Set-Content $CSVFILE ## Remove empty lines
|
|
$CSVFILE = import-csv -Path ${CSVFILE}
|
|
|
|
# Create alias
|
|
set-alias 7z "$env:ProgramFiles\7-Zip\7z.exe"
|
|
|
|
# Create empty folder for robocopy to mirror over
|
|
$EMPTY_FOLDER = "$env:TEMP\emptyfolder"
|
|
WRITELOG "Creating empty temp folder" ${EMPTY_FOLDER}
|
|
|
|
if (test-path $EMPTY_FOLDER) {
|
|
WRITELOG "${EMPTY_FOLDER} already exists, purging old one."
|
|
Remove-Item $EMPTY_FOLDER -Force -Confirm:$false -Recurse
|
|
New-Item -ItemType Directory $EMPTY_FOLDER
|
|
} else {
|
|
New-Item -ItemType Directory $EMPTY_FOLDER
|
|
}
|
|
|
|
# START LOOPING TROUGH CSV FILE
|
|
$COUNTER = 0
|
|
WRITELOG "Looping through CSV file"
|
|
foreach ($SOURCE_ENTRY in $CSVFILE) {
|
|
$COUNTER++
|
|
$SOURCE = ${SOURCE_ENTRY}.FROM
|
|
if ($null -eq $SOURCE) {
|
|
WRITELOG "SOURCE variable is empty! Please check the CSV file. Exiting..."
|
|
exit
|
|
}
|
|
$TARGET = ${SOURCE_ENTRY}.TO
|
|
if ($null -eq $TARGET) {
|
|
WRITELOG "TARGET variable is empty! Please check the CSV file. Exiting..."
|
|
exit
|
|
}
|
|
|
|
WRITELOG "Archiving: $COUNTER - $SOURCE"
|
|
Write-Output "Archiving $SOURCE"
|
|
|
|
WRITELOG "Calculating folder size of $SOURCE"
|
|
Write-Output "Calculating folder size of $SOURCE"
|
|
$SOURCE_SIZE = (Get-ChildItem ${SOURCE} -Recurse| Measure-Object -Property Length -sum).Sum
|
|
$SOURCE_SIZE_FACTOR = [int]($SOURCE_SIZE / $MAX_FOLDER_SIZE)
|
|
if ($SOURCE_SIZE_FACTOR -ge 1) {
|
|
WRITELOG "$SOURCE is too big to compress using 7zip, switching to robocopy."
|
|
WRITELOG "Mirroring $SOURCE using robocopy"
|
|
robocopy /MIR ${SOURCE} ${TARGET}
|
|
$TARGET_SIZE = (Get-ChildItem ${TARGET} -Recurse| Measure-Object -Property Length -sum).Sum
|
|
if (${SOURCE_SIZE} -ne ${TARGET_SIZE}) {
|
|
WRITELOG "Source and destination sizes do not match!"; exit
|
|
} else {
|
|
WRITELOG "Source and destination sizes match"
|
|
}
|
|
WRITELOG "empty $SOURCE"
|
|
mkdir empty
|
|
robocopy /MIR empty ${SOURCE}
|
|
WRITELOG "Rename $SOURCE to "
|
|
$TEMPFOLDER_DONE = ${SOURCE} + "_is_archived_by_solvinity"
|
|
Rename-Item ${SOURCE} ${TEMPFOLDER_DONE}
|
|
WRITELOG "Temp quit on ${SOURCE}"
|
|
exit
|
|
} else {
|
|
# Create stagefolders which give the state of the source folder
|
|
Write-Output "Creating stage folder"
|
|
$TEMPFOLDER_RUNNING = ${SOURCE} + "_being_archived"
|
|
$TEMPFOLDER_DONE = ${SOURCE} + "_is_archived"
|
|
$TEMPFOLDER_FAILED = ${SOURCE} + "_archived_failed"
|
|
WRITELOG "Creating stage folder $TEMPFOLDER_RUNNING"
|
|
if (!(test-path $TEMPFOLDER_RUNNING)){
|
|
New-Item -ItemType Directory $TEMPFOLDER_RUNNING
|
|
} else {
|
|
WRITELOG "$TEMPFOLDER_RUNNING already exists! Please check or delete this folder! Exiting..."
|
|
exit
|
|
}
|
|
|
|
# Adjust ACL so that users cannot access the archived folder anymore
|
|
WRITELOG "Locking ACL on $SOURCE"
|
|
$ACL = get-acl -Path $SOURCE
|
|
$ACL.SetAccessRuleProtection($True, $False)
|
|
$LOCALADMIN_FULLCONTROL = New-Object system.security.accesscontrol.filesystemaccessrule("builtin\Administrators", "FullControl", "ContainerInherit,ObjectInherit", "none", "Allow")
|
|
$ACL.SetAccessRule($LOCALADMIN_FULLCONTROL)
|
|
Set-Acl -Path $SOURCE -AclObject $ACL
|
|
|
|
# Close down open files
|
|
WRITELOG "Closing OpenFiles on $SOURCE"
|
|
$OPENFILES = Get-SmbOpenFile | Where-Object -Property path -like *$SOURCE*
|
|
$OPENFILES_COUNT = $OPENFILES.count
|
|
WRITELOG "$OPENFILES_COUNT files closed"
|
|
$OPENFILES | Close-SmbOpenFile -Force
|
|
|
|
# Start archiving
|
|
WRITELOG "7ZIP $SOURCE"
|
|
7z a -mx3 -t7z -r "${TARGET}\${TARGET_FILENAME}" "$SOURCE\*"
|
|
|
|
# Validate number of files in archive and DFS
|
|
WRITELOG "Compare the number of files in DFS and archive"
|
|
## 7zip
|
|
WRITELOG "Counting files in 7zip archive"
|
|
$7ZIP_FILECOUNT = '0'
|
|
7z l $TARGET\$TARGET_FILENAME | Select-Object -Last 1 |
|
|
Select-String '([0-9]+) files(?:, ([0-9]+) folders)?' |
|
|
|
|
ForEach-Object {
|
|
$7ZIP_FILECOUNT = [Int] $_.Matches[0].Groups[1].Value
|
|
if ($7ZIP_FILECOUNT -eq $null) {
|
|
# Ignore counter if null
|
|
}
|
|
|
|
}
|
|
|
|
## DFS
|
|
WRITELOG "Counting files in source path"
|
|
$dirandfilelist = Get-ChildItem -Recurse -force $SOURCE
|
|
$DFS_FILECOUNT = ($dirandfilelist | Where-Object { ! $_.PSIsContainer }).count
|
|
|
|
WRITELOG "${SOURCE}: ${7ZIP_FILECOUNT} / ${DFS_FILECOUNT}"
|
|
WRITELOG "Comparing source and target files"
|
|
if ($7ZIP_FILECOUNT -eq $DFS_FILECOUNT) {
|
|
# Compare OK
|
|
WRITELOG "Number of files matching! Cleaning source folder"
|
|
Write-Output "Cleaning up $SOURCE"
|
|
robocopy /MIR $EMPTY_FOLDER $SOURCE
|
|
remove-item -Force -Recurse $SOURCE
|
|
WRITELOG "Source has been archived to $TARGET!"
|
|
if (!(test-path $TEMPFOLDER_DONE)){
|
|
WRITELOG "Renaming stage folder to $TEMPFOLDER_DONE"
|
|
Rename-Item -Path $TEMPFOLDER_RUNNING -NewName $TEMPFOLDER_DONE
|
|
}
|
|
} else {
|
|
# Compare mismatch
|
|
WRITELOG "CRITICAL - Compare failed, the number of files are not matching. Counted: $7ZIP_FILECOUNT / $DFS_FILECOUNT"
|
|
if (!(test-path $TEMPFOLDER_FAILED)){
|
|
WRITELOG "CRITICAL - Renaming stage folder to $TEMPFOLDER_FAILED"
|
|
Rename-Item -Path $TEMPFOLDER_RUNNING -NewName $TEMPFOLDER_FAILED
|
|
}
|
|
}
|
|
}
|
|
}
|
|
WRITELOG "=========================== Archiving ended ===========================" |