From 06c8b9e147097de7cc9eed2bb8280dfe3fcd2402 Mon Sep 17 00:00:00 2001 From: Ivan Carlos de Almeida Date: Tue, 16 Dec 2025 04:45:16 -0300 Subject: [PATCH] first load --- .github/workflows/release_build.yml | 240 ++++++++++++++++++++++++++++ .github/workflows/update_readme.yml | 78 +++++++++ LICENSE | 21 +++ README.md | 50 +++++- Run-WindowsUpdate.bat | 13 ++ Windows-Update.ps1 | 161 +++++++++++++++++++ manifest.json | 4 + 7 files changed, 566 insertions(+), 1 deletion(-) create mode 100644 .github/workflows/release_build.yml create mode 100644 .github/workflows/update_readme.yml create mode 100644 LICENSE create mode 100644 Run-WindowsUpdate.bat create mode 100644 Windows-Update.ps1 create mode 100644 manifest.json diff --git a/.github/workflows/release_build.yml b/.github/workflows/release_build.yml new file mode 100644 index 0000000..fb79cd0 --- /dev/null +++ b/.github/workflows/release_build.yml @@ -0,0 +1,240 @@ +name: Build, Push, Publish + +on: + push: + branches: + - main + workflow_dispatch: + schedule: + - cron: '28 5 * * *' + workflow_run: + workflows: ["Sync Repo"] + types: + - completed + +jobs: + release: + name: Build & Release + runs-on: ubuntu-latest + permissions: + contents: write + packages: write + + steps: + - name: 📥 Checkout code with full history and tags + uses: actions/checkout@v4 + with: + fetch-depth: 0 + + - name: Check if any tags exist + id: check_tags_exist + run: | + git fetch --tags + TAG_COUNT=$(git tag | wc -l) + if [ "$TAG_COUNT" -eq 0 ]; then + echo "has_tags=false" >> "$GITHUB_OUTPUT" + echo "latest_tag=v0.0.0" >> "$GITHUB_OUTPUT" + else + echo "has_tags=true" >> "$GITHUB_OUTPUT" + LATEST_TAG=$(git describe --tags --abbrev=0) + echo "latest_tag=$LATEST_TAG" >> "$GITHUB_OUTPUT" + fi + + - name: Check if meaningful commits exist since latest tag + id: check_commits + run: | + if [ "${{ steps.check_tags_exist.outputs.has_tags }}" = "false" ]; then + # No tags exist, so we should create first release + echo "commit_count=1" >> "$GITHUB_OUTPUT" + CHANGED_FILES=$(git ls-files | grep -v '^manifest.json$' || true) + if [ -n "$CHANGED_FILES" ]; then + echo "changed_files<> "$GITHUB_OUTPUT" + printf '%s\n' "$CHANGED_FILES" >> "$GITHUB_OUTPUT" + echo "EOF" >> "$GITHUB_OUTPUT" + else + echo "changed_files=Initial release" >> "$GITHUB_OUTPUT" + fi + else + LATEST_TAG="${{ steps.check_tags_exist.outputs.latest_tag }}" + CHANGED_FILES="$(git diff --name-only "${LATEST_TAG}..HEAD" | grep -v '^manifest.json$' || true)" + if [ -n "$CHANGED_FILES" ]; then + echo "commit_count=1" >> "$GITHUB_OUTPUT" + echo "changed_files<> "$GITHUB_OUTPUT" + printf '%s\n' "$CHANGED_FILES" >> "$GITHUB_OUTPUT" + echo "EOF" >> "$GITHUB_OUTPUT" + else + echo "commit_count=0" >> "$GITHUB_OUTPUT" + fi + fi + + - name: Get latest release tag (from GitHub API) + id: get_latest_release + run: | + LATEST_RELEASE_TAG=$(curl -sL -H "Accept: application/vnd.github+json" \ + -H "Authorization: Bearer ${{ secrets.GITHUB_TOKEN }}" \ + "https://api.github.com/repos/${GITHUB_REPOSITORY}/releases/latest" | jq -r .tag_name) + if [ -z "$LATEST_RELEASE_TAG" ] || [ "$LATEST_RELEASE_TAG" = "null" ]; then + LATEST_RELEASE_TAG="v1.0.0" + fi + echo "latest_release_tag=$LATEST_RELEASE_TAG" >> "$GITHUB_OUTPUT" + echo "latest_release_version=${LATEST_RELEASE_TAG#v}" >> "$GITHUB_OUTPUT" + + # ------------------------------- + # Sync manifest.json to last release version if behind (only when no meaningful commits) + # ------------------------------- + - name: 🛠 Ensure manifest.json matches latest release version + if: steps.check_commits.outputs.commit_count == '0' + run: | + if [ -f manifest.json ]; then + MANIFEST_VERSION=$(jq -r '.version // empty' manifest.json) + else + MANIFEST_VERSION="" + fi + LATEST_RELEASE_VERSION="${{ steps.get_latest_release.outputs.latest_release_version }}" + PYTHON_CODE="from packaging import version; \ + print(version.parse('$LATEST_RELEASE_VERSION') > version.parse('$MANIFEST_VERSION') if '$MANIFEST_VERSION' else True)" + NEED_UPDATE=$(python3 -c "$PYTHON_CODE") + if [ "$NEED_UPDATE" = "True" ]; then + echo "Updating manifest.json to version $LATEST_RELEASE_VERSION (sync with release)" + jq --arg v "$LATEST_RELEASE_VERSION" '.version = $v' manifest.json > tmp.json && mv tmp.json manifest.json + git config user.name "github-actions" + git config user.email "github-actions@github.com" + git add manifest.json + git commit -m "Sync manifest.json to release $LATEST_RELEASE_VERSION [🔄]" || echo "Nothing to commit" + git push origin main || true + else + echo "Manifest.json is already up-to-date with the latest release." + fi + + # ------------------------------- + # Continue normal workflow if commits exist + # ------------------------------- + - name: 📃 Get list of changed files (Markdown bullet list) + if: steps.check_commits.outputs.commit_count != '0' + id: changed_files + run: | + BULLET_LIST="$(printf '%s\n' "${{ steps.check_commits.outputs.changed_files }}" | sed 's/^/- /')" + echo "CHANGED<> "$GITHUB_OUTPUT" + printf '%s\n' "$BULLET_LIST" >> "$GITHUB_OUTPUT" + echo "EOF" >> "$GITHUB_OUTPUT" + COUNT="$(printf '%s\n' "${{ steps.check_commits.outputs.changed_files }}" | wc -l)" + echo "COUNT=$COUNT" >> "$GITHUB_OUTPUT" + + - name: Get manifest version + if: steps.check_commits.outputs.commit_count != '0' + id: get_manifest_version + run: | + if [ -f manifest.json ]; then + MANIFEST_VERSION=$(jq -r '.version // empty' manifest.json) + if [ -z "$MANIFEST_VERSION" ] || [ "$MANIFEST_VERSION" = "null" ]; then + MANIFEST_VERSION="1.0.0" + fi + else + MANIFEST_VERSION="1.0.0" + fi + echo "manifest_version=$MANIFEST_VERSION" >> "$GITHUB_OUTPUT" + + - name: Pick base version + if: steps.check_commits.outputs.commit_count != '0' + id: pick_base_version + run: | + LATEST_RELEASE="${{ steps.get_latest_release.outputs.latest_release_version }}" + MANIFEST="${{ steps.get_manifest_version.outputs.manifest_version }}" + BASE_VERSION=$(python3 -c "from packaging import version; \ + print(str(max(version.parse('$LATEST_RELEASE'), version.parse('$MANIFEST'))))") + echo "base_version=$BASE_VERSION" >> "$GITHUB_OUTPUT" + + - name: 🔢 Determine version + if: steps.check_commits.outputs.commit_count != '0' + id: version + run: | + BASE_VERSION="${{ steps.pick_base_version.outputs.base_version }}" + IFS='.' read -r MAJOR MINOR PATCH <<< "$BASE_VERSION" + COUNT="${{ steps.changed_files.outputs.COUNT }}" + if [ "$COUNT" -ge 5 ]; then + MAJOR=$((MAJOR + 1)) + MINOR=0 + PATCH=0 + elif [ "$COUNT" -ge 3 ]; then + MINOR=$((MINOR + 1)) + PATCH=0 + else + PATCH=$((PATCH + 1)) + fi + NEW_VERSION="${MAJOR}.${MINOR}.${PATCH}" + REPO_NAME="$(basename "$GITHUB_REPOSITORY")" + ZIP_NAME="${REPO_NAME}-${NEW_VERSION}.zip" + echo "VERSION=$NEW_VERSION" >> "$GITHUB_OUTPUT" + echo "ZIP_NAME=$ZIP_NAME" >> "$GITHUB_OUTPUT" + echo "REPO_NAME=$REPO_NAME" >> "$GITHUB_OUTPUT" + + - name: 🛠 Update or create manifest.json + if: steps.check_commits.outputs.commit_count != '0' + run: | + VERSION="${{ steps.version.outputs.VERSION }}" + AUTHOR="Ivan Carlos" + VERSION_FILE="manifest.json" + if [ -f "$VERSION_FILE" ]; then + jq --arg v "$VERSION" --arg a "$AUTHOR" \ + '.version = $v | .author = $a' "$VERSION_FILE" > tmp.json && mv tmp.json "$VERSION_FILE" + else + echo "{ \"version\": \"$VERSION\", \"author\": \"$AUTHOR\" }" > "$VERSION_FILE" + fi + + - name: 💾 Commit and push updated manifest.json + if: steps.check_commits.outputs.commit_count != '0' + run: | + git config user.name "github-actions" + git config user.email "github-actions@github.com" + git add manifest.json + git commit -m "Update manifest version to ${{ steps.version.outputs.VERSION }} [▶️]" || echo "Nothing to commit" + git push origin main + + - name: 📦 Create ZIP package (excluding certain files) + if: steps.check_commits.outputs.commit_count != '0' + run: | + ZIP_NAME="${{ steps.version.outputs.ZIP_NAME }}" + zip -r "$ZIP_NAME" . -x ".git/*" ".github/*" "docker/*" ".dockerignore" "CNAME" "Dockerfile" "README.md" "LICENSE" + + - name: 🚀 Create GitHub Release + if: steps.check_commits.outputs.commit_count != '0' + uses: softprops/action-gh-release@v2 + with: + tag_name: "v${{ steps.version.outputs.VERSION }}" + name: "${{ steps.version.outputs.REPO_NAME }} v${{ steps.version.outputs.VERSION }}" + body: | + ### Changelog + Files changed in this release: + ${{ steps.changed_files.outputs.CHANGED }} + files: ${{ steps.version.outputs.ZIP_NAME }} + + # ----- Docker steps ----- + - name: 🔍 Check if Dockerfile exists + if: steps.check_commits.outputs.commit_count != '0' + id: dockerfile_check + run: | + if [ -f Dockerfile ]; then + echo "exists=true" >> "$GITHUB_OUTPUT" + else + echo "exists=false" >> "$GITHUB_OUTPUT" + fi + + - name: 🛠 Set up Docker Buildx + if: steps.check_commits.outputs.commit_count != '0' && steps.dockerfile_check.outputs.exists == 'true' + uses: docker/setup-buildx-action@v3 + + - name: 🔐 Login to GitHub Container Registry + if: steps.check_commits.outputs.commit_count != '0' && steps.dockerfile_check.outputs.exists == 'true' + uses: docker/login-action@v3 + with: + registry: ghcr.io + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: 🐳 Build and Push Docker image + if: steps.check_commits.outputs.commit_count != '0' && steps.dockerfile_check.outputs.exists == 'true' + uses: docker/build-push-action@v5 + with: + context: . + push: true + tags: ghcr.io/${{ github.repository }}:latest diff --git a/.github/workflows/update_readme.yml b/.github/workflows/update_readme.yml new file mode 100644 index 0000000..b635451 --- /dev/null +++ b/.github/workflows/update_readme.yml @@ -0,0 +1,78 @@ +name: Update README + +# Allow GitHub Actions to commit and push changes +permissions: + contents: write + +on: + workflow_dispatch: + schedule: + - cron: '0 4 * * *' # Every day at 4 AM UTC + +jobs: + update-readme: + runs-on: ubuntu-latest + + env: + SOURCE_REPO: ivancarlosti/.github + SOURCE_BRANCH: main + + steps: + - name: Checkout current repository + uses: actions/checkout@v4 + + - name: Checkout source README template + uses: actions/checkout@v4 + with: + repository: ${{ env.SOURCE_REPO }} + ref: ${{ env.SOURCE_BRANCH }} + path: source_readme + + - name: Update README.md (buttons and footer) + run: | + set -e + REPO_NAME="${GITHUB_REPOSITORY##*/}" + + # --- Extract buttons block from source --- + BUTTONS=$(awk '//{flag=1;next}//{flag=0}flag' source_readme/README.md) + BUTTONS_UPDATED=$(echo "$BUTTONS" | sed "s/\.github/${REPO_NAME}/g") + + # --- Extract footer block from source (everything from onward) --- + FOOTER=$(awk '//{flag=1}flag' source_readme/README.md) + + # --- Replace buttons section in README.md --- + UPDATED=$(awk -v buttons="$BUTTONS_UPDATED" ' + BEGIN { skip=0 } + // { + print + print buttons + skip=1 + next + } + // && skip { + print + skip=0 + next + } + !skip { print } + ' README.md) + + # --- Replace everything after with FOOTER --- + echo "$UPDATED" | awk -v footer="$FOOTER" ' + // { + print footer + found=1 + exit + } + { print } + ' > README.tmp && mv README.tmp README.md + + - name: Remove source_readme from git index + run: git rm --cached -r source_readme || true + + - name: Commit and push changes + uses: stefanzweifel/git-auto-commit-action@v5 + with: + file_pattern: README.md + commit_message: "Sync README from template [▶️]" + branch: ${{ github.ref_name }} diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..3c1c4d9 --- /dev/null +++ b/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2025 Ivan Carlos de Almeida + +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. diff --git a/README.md b/README.md index 1200177..4d99025 100644 --- a/README.md +++ b/README.md @@ -1,2 +1,50 @@ -# windowsupdate +# Windows Update script +Script to perform Windows Update initialized by batch file + +[![Stars](https://img.shields.io/github/stars/ivancarlosti/windowsupdate?label=⭐%20Stars&color=gold&style=flat)](https://github.com/ivancarlosti/windowsupdate/stargazers) +[![Watchers](https://img.shields.io/github/watchers/ivancarlosti/windowsupdate?label=Watchers&style=flat&color=red)](https://github.com/sponsors/ivancarlosti) +[![Forks](https://img.shields.io/github/forks/ivancarlosti/windowsupdate?label=Forks&style=flat&color=ff69b4)](https://github.com/sponsors/ivancarlosti) +[![GitHub commit activity](https://img.shields.io/github/commit-activity/m/ivancarlosti/windowsupdate?label=Activity)](https://github.com/ivancarlosti/windowsupdate/pulse) +[![GitHub Issues](https://img.shields.io/github/issues/ivancarlosti/windowsupdate?label=Issues&color=orange)](https://github.com/ivancarlosti/windowsupdate/issues) +[![License](https://img.shields.io/github/license/ivancarlosti/windowsupdate?label=License)](LICENSE) +[![GitHub last commit](https://img.shields.io/github/last-commit/ivancarlosti/windowsupdate?label=Last%20Commit)](https://github.com/ivancarlosti/windowsupdate/commits) +[![Security](https://img.shields.io/badge/Security-View%20Here-purple)](https://github.com/ivancarlosti/windowsupdate/security) +[![Code of Conduct](https://img.shields.io/badge/Code%20of%20Conduct-2.1-4baaaa)](https://github.com/ivancarlosti/windowsupdate?tab=coc-ov-file) +[![GitHub Sponsors](https://img.shields.io/github/sponsors/ivancarlosti?label=GitHub%20Sponsors&color=ffc0cb)][sponsor] + + +## Inspiration +Inpired by [Windows Update Automation Script](https://github.com/TychoLoke/Windows-Update-Script) and improved, license preserved + +## Instructions +- This script is intended to be executed by administrators and may ask for privileged access. +- Download this repository ([here](https://github.com/ivancarlosti/windowsupdate/zipball/master)) +- Extract the files +- Execute `Run-WindowsUpdate.bat` +- The script will generate a `.log` file on script folder + + +--- + +## 🧑‍💻 Consulting and technical support +* For personal support and queries, please submit a new issue to have it addressed. +* For commercial related questions, please [**contact me**][ivancarlos] for consulting costs. + +## 🩷 Project support +| If you found this project helpful, consider | +| :---: | +[**buying me a coffee**][buymeacoffee], [**donate by paypal**][paypal], [**sponsor this project**][sponsor] or just [**leave a star**](../..)⭐ +|Thanks for your support, it is much appreciated!| + +[cc]: https://docs.github.com/en/communities/setting-up-your-project-for-healthy-contributions/adding-a-code-of-conduct-to-your-project +[contributing]: https://docs.github.com/en/articles/setting-guidelines-for-repository-contributors +[security]: https://docs.github.com/en/code-security/getting-started/adding-a-security-policy-to-your-repository +[support]: https://docs.github.com/en/articles/adding-support-resources-to-your-project +[it]: https://docs.github.com/en/communities/using-templates-to-encourage-useful-issues-and-pull-requests/configuring-issue-templates-for-your-repository#configuring-the-template-chooser +[prt]: https://docs.github.com/en/communities/using-templates-to-encourage-useful-issues-and-pull-requests/creating-a-pull-request-template-for-your-repository +[funding]: https://docs.github.com/en/articles/displaying-a-sponsor-button-in-your-repository +[ivancarlos]: https://ivancarlos.it +[buymeacoffee]: https://www.buymeacoffee.com/ivancarlos +[paypal]: https://icc.gg/donate +[sponsor]: https://github.com/sponsors/ivancarlosti diff --git a/Run-WindowsUpdate.bat b/Run-WindowsUpdate.bat new file mode 100644 index 0000000..e7637d5 --- /dev/null +++ b/Run-WindowsUpdate.bat @@ -0,0 +1,13 @@ +@echo off +:: This script will run your PowerShell script with bypass and keep the window open +:: Check if PowerShell exists +where powershell >nul 2>&1 +if %errorlevel% neq 0 ( + echo PowerShell not found! + pause + exit /b +) + +:: Run the PowerShell script with bypass and elevation +powershell.exe -NoProfile -ExecutionPolicy Bypass -Command "& {Start-Process powershell.exe -ArgumentList '-NoProfile -ExecutionPolicy Bypass -NoExit -File ""%~dp0Windows-Update.ps1""' -Verb RunAs -WindowStyle Normal}" +pause \ No newline at end of file diff --git a/Windows-Update.ps1 b/Windows-Update.ps1 new file mode 100644 index 0000000..5897aba --- /dev/null +++ b/Windows-Update.ps1 @@ -0,0 +1,161 @@ +# Bypass execution policy for current session +Set-ExecutionPolicy -ExecutionPolicy Bypass -Scope Process -Force -ErrorAction SilentlyContinue + +# Get the directory where the script is located +$ScriptDirectory = Split-Path -Path $MyInvocation.MyCommand.Definition -Parent + +# Define logging path (same directory as script) +$LogDirectory = $ScriptDirectory +$LogFile = Join-Path -Path $LogDirectory -ChildPath "windowsupdate.log" + +# Function for consistent error handling +function Handle-Error { + param ( + [string]$ErrorMessage, + [int]$ExitCode = 1 + ) + Write-Output "[ERROR] $ErrorMessage" + try { + Stop-Transcript -ErrorAction SilentlyContinue + } catch { + Write-Output "[WARNING] Failed to stop transcript: $_" + } + Exit $ExitCode +} + +# Ensure the log directory exists (script directory) +try { + if (!(Test-Path -Path $LogDirectory)) { + New-Item -ItemType Directory -Force -Path $LogDirectory | Out-Null + Write-Output "[INFO] Created log directory: $LogDirectory" + } +} catch { + Handle-Error -ErrorMessage "Failed to create log directory: $_" +} + +# Start logging +try { + Start-Transcript -Path $LogFile -Append -ErrorAction Stop + Write-Output "`n=========================" + Write-Output " Windows Update Script " + Write-Output "=========================`n" + Write-Output "[INFO] Logging to: $LogFile" +} catch { + Handle-Error -ErrorMessage "Failed to start transcript: $_" +} + +# Function to check and install missing modules +function Ensure-Module { + param ( + [string]$ModuleName, + [string]$ProviderName = $null + ) + try { + if (!(Get-Module -Name $ModuleName -ListAvailable)) { + Write-Output "[INFO] Installing module: $ModuleName" + + # Install NuGet provider if needed (with compatibility for all PS versions) + if ($ProviderName -and !(Get-PackageProvider -Name $ProviderName -ListAvailable -ErrorAction SilentlyContinue)) { + try { + # First try modern approach + $params = @{ + Name = $ProviderName + Force = $true + ErrorAction = 'Stop' + } + + # Only add SkipPublisherCheck if parameter exists + if (Get-Command Install-PackageProvider -ParameterName SkipPublisherCheck -ErrorAction SilentlyContinue) { + $params.SkipPublisherCheck = $true + } + + Install-PackageProvider @params + } catch { + # Fallback method if standard installation fails + try { + Write-Output "[INFO] Trying fallback provider installation method..." + [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12 + $sourceNugetExe = "https://dist.nuget.org/win-x86-commandline/latest/nuget.exe" + $targetNugetExe = "$env:TEMP\nuget.exe" + Invoke-WebRequest $sourceNugetExe -OutFile $targetNugetExe + & $targetNugetExe install NuGet.CommandLine -ExcludeVersion -OutputDirectory "$env:ProgramFiles\PackageManagement\ProviderAssemblies" + Write-Output "[SUCCESS] Provider installed via fallback method" + } catch { + Handle-Error -ErrorMessage "Failed to install package provider $($ProviderName): $($_)" + } + } + } + + # Install the module (with compatibility for all PS versions) + try { + $params = @{ + Name = $ModuleName + Force = $true + ErrorAction = 'Stop' + } + + # Only add SkipPublisherCheck if parameter exists + if (Get-Command Install-Module -ParameterName SkipPublisherCheck -ErrorAction SilentlyContinue) { + $params.SkipPublisherCheck = $true + } + + Install-Module @params + Write-Output "[SUCCESS] Module $ModuleName installed successfully" + } catch { + Handle-Error -ErrorMessage "Failed to install module $($ModuleName): $($_)" + } + } else { + Write-Output "[INFO] Module already installed: $ModuleName" + } + } catch { + Handle-Error -ErrorMessage "Module check failed for $($ModuleName): $($_)" + } +} + +# Ensure required modules are installed +Ensure-Module -ModuleName "PSWindowsUpdate" -ProviderName "NuGet" + +# Import the PSWindowsUpdate module +try { + Import-Module PSWindowsUpdate -Force -ErrorAction Stop + Write-Output "[SUCCESS] PSWindowsUpdate module imported." +} catch { + Handle-Error -ErrorMessage "Could not import PSWindowsUpdate module: $_" +} + +# Function to check and install Windows updates +function Run-WindowsUpdate { + try { + Write-Output "`n[INFO] Checking for Windows updates..." + $Updates = Get-WindowsUpdate -IgnoreReboot -ErrorAction Stop + + if ($Updates) { + Write-Output "[INFO] Found $($Updates.Count) updates available, proceeding with installation..." + try { + $installResult = Install-WindowsUpdate -AcceptAll -IgnoreReboot -ErrorAction Stop + Write-Output "[SUCCESS] Windows updates installed successfully!" + Write-Output ($installResult | Out-String) + } catch { + Handle-Error -ErrorMessage "Update installation failed: $_" + } + } else { + Write-Output "[INFO] No updates available." + } + } catch { + Handle-Error -ErrorMessage "Windows Update check failed: $_" + } +} + +# Run the Windows Update process +Run-WindowsUpdate + +# Stop logging +try { + Stop-Transcript + Write-Output "[INFO] Logging completed. Transcript saved to $LogFile" +} catch { + Write-Output "[WARNING] Failed to stop transcript properly: $_" + Exit 0 # This is non-critical, so we exit with success +} + +Exit 0 \ No newline at end of file diff --git a/manifest.json b/manifest.json new file mode 100644 index 0000000..78647af --- /dev/null +++ b/manifest.json @@ -0,0 +1,4 @@ +{ + "version": "1.0.25", + "author": "Ivan Carlos" +}