Private/Set-JavMovie.ps1
function Set-JavMovie { [CmdletBinding(SupportsShouldProcess = $true)] param( [Parameter(Mandatory = $true, Position = 0)] [object]$DataObject, [object]$Settings, [string]$Path, [string]$DestinationPath, [string]$ScriptRoot, [switch]$Force ) begin { Write-Debug "[$(Get-TimeStamp)][$($MyInvocation.MyCommand.Name)] Function started" $r18ThumbCsv = Import-Csv -LiteralPath (Join-Path -Path $ScriptRoot -ChildPath 'r18-thumbs.csv') $fixedPath = ($Path).replace('`[', '[').replace('`]', ']') $Path = (Get-Item -LiteralPath $fixedPath).FullName $fileExtension = (Get-Item -LiteralPath $fixedPath).Extension $fixedDestinationPath = ($DestinationPath).replace('`[', '[').replace('`]', ']') $DestinationPath = (Get-Item -LiteralPath $fixedDestinationPath).FullName $webClient = New-Object System.Net.WebClient $cropPath = Join-Path -Path $ScriptRoot -ChildPath 'crop.py' if ($Settings.General.'move-to-folder' -eq 'True') { $folderPath = Join-Path -Path $fixedDestinationPath -ChildPath $DataObject.FolderName } else { $folderPath = (Get-Item -Path $DataObject.OriginalDirectory).FullName } $nfoPath = Join-Path -Path $folderPath -ChildPath ($DataObject.NfoName + '.nfo') $coverPath = Join-Path -Path $folderPath -ChildPath ($DataObject.ThumbnailName + '.jpg') $posterPath = Join-Path -Path $folderPath -ChildPath ($DataObject.PosterName + '.jpg') $trailerPath = Join-Path -Path $folderPath -ChildPath ($DataObject.TrailerName + '.mp4') $screenshotPath = Join-Path -Path $folderPath -ChildPath $DataObject.ScreenshotFolderName $actorPath = Join-Path -Path $folderPath -ChildPath $DataObject.ActorImgFolderName $fixedFolderPath = ($folderPath.replace('[', '`[')).replace(']', '`]') $fixedNfoPath = ($nfoPath).replace('`[', '[').replace('`]', ']') $fixedCoverPath = ($coverPath).replace('`[', '[').replace('`]', ']') $fixedPosterPath = ($posterPath).replace('`[', '[').replace('`]', ']') $fixedTrailerPath = ($trailerPath).replace('`[', '[').replace('`]', ']') $fixedScreenshotPath = ($screenshotPath).replace('`[', '[').replace('`]', ']') $fixedActorPath = ($actorPath).replace('`[', '[').replace('`]', ']') Write-Debug "[$(Get-TimeStamp)][$($MyInvocation.MyCommand.Name)] Crop path: [$cropPath]" Write-Debug "[$(Get-TimeStamp)][$($MyInvocation.MyCommand.Name)] Folder path: [$folderPath]" Write-Debug "[$(Get-TimeStamp)][$($MyInvocation.MyCommand.Name)] Nfo path: [$nfoPath]" Write-Debug "[$(Get-TimeStamp)][$($MyInvocation.MyCommand.Name)] Cover path: [$coverPath]" Write-Debug "[$(Get-TimeStamp)][$($MyInvocation.MyCommand.Name)] Poster path: [$posterPath]" Write-Debug "[$(Get-TimeStamp)][$($MyInvocation.MyCommand.Name)] Screenshot path: [$screenshotPath]" Write-Debug "[$(Get-TimeStamp)][$($MyInvocation.MyCommand.Name)] Trailer path: [$trailerPath]" } process { $screenshotImgName = $DataObject.ScreenshotImgName $newFileName = $DataObject.FileName + $fileExtension $DataObject = Test-RequiredMetadata -DataObject $DataObject -Settings $settings if ($null -ne $DataObject) { if ($Settings.General.'move-to-folder' -eq 'True') { $fixedDestinationPath = $DestinationPath.replace('[', '`[').replace(']', '`]') # Check that folder path is not longer than 256 characters $pathLength = (Join-Path -Path $fixedDestinationPath -ChildPath $DataObject.FolderName).Length if ($pathLength -gt 215) { Write-Warning "[$(Get-TimeStamp)][$($MyInvocation.MyCommand.Name)] Skipped: [$($DataObject.OriginalFileName)] Path length limitations: [$pathLength characters]" Write-Log -Log $logPath -Level WARN -Text "Skipped: [$($DataObject.OriginalFileName)] Path length limitations: [$pathLength characters]" -UseMutex continue } if (-not (Test-Path -LiteralPath (Join-Path -Path $fixedDestinationPath -ChildPath $DataObject.FolderName))) { New-Item -ItemType Directory -Name $DataObject.FolderName -Path $fixedDestinationPath -Force:$Force -ErrorAction Stop | Out-Null } Get-MetadataNfo -DataObject $DataObject -Settings $Settings -R18ThumbCsv $r18ThumbCsv -ErrorAction 'SilentlyContinue' | Out-File -LiteralPath $fixednfoPath -Force:$Force -ErrorAction 'SilentlyContinue' if ($Settings.General.'rename-file' -eq 'True') { Rename-Item -LiteralPath $Path -NewName $newFileName -PassThru -Force:$Force -ErrorAction Stop | Move-Item -Destination $folderPath -Force:$Force -ErrorAction 'Stop' } else { Move-Item -LiteralPath $Path -Destination $folderPath -Force:$Force -ErrorAction 'Stop' } } else { Get-MetadataNfo -DataObject $DataObject -Settings $Settings -R18ThumbCsv $r18ThumbCsv -ErrorAction 'SilentlyContinue' | Out-File -LiteralPath $fixedNfoPath -Force:$Force -ErrorAction 'SilentlyContinue' if ($Settings.General.'rename-file' -eq 'True') { Rename-Item -LiteralPath $Path -NewName $newFileName -PassThru -Force:$Force -ErrorAction 'Stop' | Out-Null } } if ($Settings.Metadata.'download-thumb-img' -eq 'True') { try { if ($null -ne $DataObject.CoverUrl) { if ($Force.IsPresent) { $webClient.DownloadFile(($DataObject.CoverUrl).ToString(), $fixedCoverPath) } elseif ((-not (Test-Path -LiteralPath $fixedCoverPath))) { $webClient.DownloadFile(($DataObject.CoverUrl).ToString(), $fixedCoverPath) } } } catch { Write-Warning "[$(Get-TimeStamp)][$($MyInvocation.MyCommand.Name)] Error downloading cover images" throw $_ } try { if ($Settings.Metadata.'download-poster-img' -eq 'True') { # Double backslash to conform with Python path standards if ($null -ne $DataObject.CoverUrl) { $pythonCoverPath = $fixedCoverPath -replace '\\', '\\' $pythonPosterPath = $posterPath -replace '\\', '\\' if ($Force.IsPresent) { if ([System.Environment]::OSVersion.Platform -eq 'Win32NT') { python $cropPath $pythonCoverPath $pythonPosterPath } elseif ([System.Environment]::OSVersion.Platform -eq 'Unix') { python3 $cropPath $pythonCoverPath $pythonPosterPath } } elseif ((-not (Test-Path -LiteralPath $posterPath))) { if ([System.Environment]::OSVersion.Platform -eq 'Win32NT') { python $cropPath $pythonCoverPath $pythonPosterPath } elseif ([System.Environment]::OSVersion.Platform -eq 'Unix') { python3 $cropPath $pythonCoverPath $pythonPosterPath } } } } } catch { Write-Warning "[$(Get-TimeStamp)][$($MyInvocation.MyCommand.Name)] Error cropping cover to poster image" throw $_ } } try { if ($Settings.Metadata.'download-screenshot-img' -eq 'True') { if ($null -ne $DataObject.ScreenshotUrl) { New-Item -ItemType Directory -Name $DataObject.ScreenshotFolderName -Path $fixedFolderPath -Force:$Force -ErrorAction SilentlyContinue | Out-Null $index = 1 foreach ($screenshot in $DataObject.ScreenshotUrl) { if ($Force.IsPresent) { $webClient.DownloadFile($screenshot, (Join-Path -Path $screenshotPath -ChildPath ($screenshotImgName + $index + '.jpg'))) } elseif (-not (Test-Path -LiteralPath (Join-Path -Path $screenshotPath -ChildPath ($screenshotImgName + $index + '.jpg')))) { $webClient.DownloadFile($screenshot, (Join-Path -Path $screenshotPath -ChildPath ($screenshotImgName + $index + '.jpg'))) } $index++ } } } } catch { Write-Warning "[$(Get-TimeStamp)][$($MyInvocation.MyCommand.Name)] Error downloading screenshots" throw $_ } try { if ($Settings.Metadata.'download-actress-img' -eq 'True') { if ($null -ne $DataObject.ActressThumbUrl) { New-Item -ItemType Directory -Name $DataObject.ActorImgFolderName -Path $fixedFolderPath -Force:$Force -ErrorAction SilentlyContinue | Out-Null if ($DataObject.ActressThumbUrl.Count -eq 1) { if ($DataObject.ActressThumbUrl -match 'https:\/\/pics\.r18\.com\/mono\/actjpgs\/.*\.jpg') { $first, $second = $DataObject.Actress -split ' ' if ($null -eq $second -or $second -eq '') { $actressFileName = $first + '.jpg' } else { $actressFileName = $first + '_' + $second + '.jpg' } if ($Force.IsPresent) { $webClient.DownloadFile($DataObject.ActressThumbUrl, (Join-Path -Path $actorPath -ChildPath $actressFileName)) } elseif (-not (Test-Path -LiteralPath (Join-Path -Path $actorPath -ChildPath $actressFileName))) { $webClient.DownloadFile($DataObject.ActressThumbUrl, (Join-Path -Path $actorPath -ChildPath $actressFileName)) } } } else { for ($i = 0; $i -lt $DataObject.ActressThumbUrl.Count; $i++) { if ($DataObject.ActressThumbUrl[$i] -match 'https:\/\/pics\.r18\.com\/mono\/actjpgs\/.*\.jpg') { $first, $second = $DataObject.Actress[$i] -split ' ' if ($null -eq $second -or $second -eq '') { $actressFileName = $first + '.jpg' } else { $actressFileName = $first + '_' + $second + '.jpg' } if ($Force.IsPresent) { $webClient.DownloadFile($DataObject.ActressThumbUrl[$i], (Join-Path -Path $actorPath -ChildPath $actressFileName)) } elseif (-not (Test-Path -LiteralPath (Join-Path -Path $actorPath -ChildPath $actressFileName))) { $webClient.DownloadFile($DataObject.ActressThumbUrl[$i], (Join-Path -Path $actorPath -ChildPath $actressFileName)) } } } } } } } catch { Write-Warning "[$(Get-TimeStamp)][$($MyInvocation.MyCommand.Name)] Error downloading actress images" throw $_ } try { if ($Settings.Metadata.'download-trailer-vid' -eq 'True') { if ($null -ne $DataObject.TrailerUrl) { if ($Force.IsPresent) { $webClient.DownloadFile($DataObject.TrailerUrl, $trailerPath) } elseif (-not (Test-Path -LiteralPath $trailerPath)) { $webClient.DownloadFile($DataObject.TrailerUrl, $trailerPath) } } } } catch { Write-Warning "[$(Get-TimeStamp)][$($MyInvocation.MyCommand.Name)] Error downloading trailer video" throw $_ } } } end { Write-Host "[$(Get-TimeStamp)][$($MyInvocation.MyCommand.Name)] Success: [$($DataObject.OriginalFileName)]" Write-Log -Log $logPath -Level INFO -Text "Success: [$($DataObject.OriginalFileName)]" -UseMutex Write-Debug "[$(Get-TimeStamp)][$($MyInvocation.MyCommand.Name)] Function ended" } } |