#!/usr/bin/env pwsh #350 check if windows user run as admin # this allows us to call ps1 files, which allows us to have spaces in filenames # ('powershell "$Env:USERPROFILE\test.ps1" foo' will fail if it has a space in # the path but '& "$Env:USERPROFILE\test.ps1" foo' will work even with a space) Set-ExecutionPolicy -Scope Process Bypass # If a command returns an error, halt the script. $ErrorActionPreference = 'Stop' # Ignore progress events from cmdlets so Invoke-WebRequest is not painfully slow $ProgressPreference = 'SilentlyContinue' $Env:WEBI_HOST = 'https://webi.run' $Env:WEBI_PKG = 'ollama@0.20.6-rc1' $Env:PKG_NAME = 'ollama' $Env:WEBI_VERSION = '0.20.6-rc1' $Env:WEBI_GIT_TAG = '' $Env:WEBI_PKG_URL = 'https://ghfast.top/https://github.com/ollama/ollama/releases/download/v0.20.6-rc1/ollama-windows-amd64-mlx.zip' $Env:WEBI_PKG_FILE = 'ollama-windows-amd64-mlx.zip' $Env:WEBI_PKG_PATHNAME = 'ollama-windows-amd64-mlx.zip' # Switch to userprofile Push-Location $Env:USERPROFILE # Make paths New-Item -Path "$Env:USERPROFILE\Downloads" -ItemType Directory -Force | Out-Null New-Item -Path "$Env:USERPROFILE\.local\bin" -ItemType Directory -Force | Out-Null New-Item -Path "$Env:USERPROFILE\.local\opt" -ItemType Directory -Force | Out-Null # {{ baseurl }} # {{ version }} # See # - # - $Esc = [char]27 $TTask = "${Esc}[36m" $TName = "${Esc}[1m${Esc}[32m" $TUrl = "${Esc}[2m" $TPath = "${Esc}[2m${Esc}[32m" $TCmd = "${Esc}[2m${Esc}[35m" $TDim = "${Esc}[2m" $TReset = "${Esc}[0m" function Invoke-DownloadUrl { Param ( [string]$URL, [string]$Params, [string]$Path, [switch]$Force ) IF (Test-Path -Path "$Path") { IF (-Not $Force.IsPresent) { Write-Host " ${TDim}Found${TReset} $Path" return } Write-Host " Updating ${TDim}${Path}${TDim}" } $TmpPath = "${Path}.part" Remove-Item -Path $TmpPath -Force -ErrorAction Ignore Write-Host " Downloading ${TDim}from${TReset}" Write-Host " ${TDim}${URL}${TReset}" IF ($Params.Length -ne 0) { Write-Host " ?$Params" $URL = "${URL}?${Params}" } curl.exe '-#' -f -sS -A $Env:WEBI_UA -L $URL | Out-File $TmpPath Remove-Item -Path $Path -Force -ErrorAction Ignore Move-Item $TmpPath $Path Write-Host " Saved ${TPath}${Path}${TReset}" } function Get-UserAgent { # This is the canonical CPU arch when the process is emulated $my_arch = "$Env:PROCESSOR_ARCHITEW6432" IF ($my_arch -eq $null -or $my_arch -eq "") { # This is the canonical CPU arch when the process is native $my_arch = "$Env:PROCESSOR_ARCHITECTURE" } IF ($my_arch -eq "AMD64") { # Because PowerShell is sometimes AMD64 on Windows 10 ARM # See https://oofhours.com/2020/02/04/powershell-on-windows-10-arm64/ $my_os_arch = (Get-CimInstance -ClassName Win32_OperatingSystem).OSArchitecture # Using -clike because of the trailing newline IF ($my_os_arch -clike "ARM 64*") { $my_arch = "ARM64" } } "PowerShell+curl Windows/10+ $my_arch msvc" } function webi_path_add($pathname) { # C:\Users\me => C:/Users/me $my_home = $Env:UserProfile $my_home = $my_home.replace('\\', '/') $my_home_re = [regex]::escape($my_home) # ~/bin => %USERPROFILE%/bin $pathname = $pathname.replace('~/', "$Env:UserProfile/") # C:\Users\me\bin => %USERPROFILE%/bin $my_pathname = $pathname.replace('\\', '/') $my_pathname = $my_pathname -ireplace $my_home_re, "%USERPROFILE%" $all_user_paths = [Environment]::GetEnvironmentVariable("Path", "User") $user_paths = "${all_user_paths}".Trim(';').Split(';') $exists_in_path = $false foreach ($user_path in $user_paths) { # C:\Users\me\bin => %USERPROFILE%/bin $my_user_path = $user_path.replace('\\', '/') $my_user_path = $my_user_path -ireplace $my_home_re, "%USERPROFILE%" if ($my_user_path -ieq $my_pathname) { $exists_in_path = $true } } if (-Not $exists_in_path) { $all_user_paths = "${pathname};${all_user_paths}".Trim(';') [Environment]::SetEnvironmentVariable("Path", $all_user_paths, "User") $null = Sync-EnvPath } } function Sync-EnvPath { $UserPath = [Environment]::GetEnvironmentVariable("Path", "User").Trim(';') $MachinePath = [Environment]::GetEnvironmentVariable("Path", "Machine").Trim(';') $Env:Path = "${UserPath};${MachinePath}" [Environment]::SetEnvironmentVariable("Path", $Env:Path) $Env:Path } $Env:WEBI_UA = Get-UserAgent #$has_local_bin = echo "$Env:PATH" | Select-String -Pattern '\.local.bin' #if (!$has_local_bin) #{ webi_path_add ~/.local/bin #} #!/usr/bin/env pwsh ################## # Install ollama # ################## # Every package should define these variables $pkg_cmd_name = "ollama" $pkg_dst_cmd = "$Env:USERPROFILE\.local\opt\ollama\ollama.exe" $pkg_dst_bin = "$Env:USERPROFILE\.local\opt\ollama" $pkg_dst_dir = "$Env:USERPROFILE\.local\opt\ollama" $pkg_dst = "$pkg_dst_dir" $pkg_src_cmd = "$Env:USERPROFILE\.local\opt\ollama-v$Env:WEBI_VERSION\ollama.exe" $pkg_src_bin = "$Env:USERPROFILE\.local\opt\ollama-v$Env:WEBI_VERSION" $pkg_src_dir = "$Env:USERPROFILE\.local\opt\ollama-v$Env:WEBI_VERSION" $pkg_src = "$pkg_src_dir" $pkg_download_dir = "$Env:USERPROFILE\Downloads\webi\$pkg_cmd_name\$Env:WEBI_VERSION" $pkg_download_file = "$pkg_download_dir\$Env:WEBI_PKG_FILE" # Fetch archive IF (!(Test-Path -Path "$pkg_download_file")) { New-Item "$pkg_download_dir" -ItemType Directory -Force | Out-Null Write-Output " Downloading $pkg_cmd_name v$Env:WEBI_VERSION from $Env:WEBI_PKG_URL to $pkg_download_file" & curl.exe -A "$Env:WEBI_UA" -fsSL "$Env:WEBI_PKG_URL" -o "$pkg_download_file.part" & Move-Item "$pkg_download_file.part" "$pkg_download_file" } IF (!(Test-Path -Path "$pkg_src_cmd")) { Write-Output " Installing ollama v$Env:WEBI_VERSION" # Remove any leftover tmp cruft, recreate location, push into it Remove-Item -Path ".local\tmp\ollama-v$Env:WEBI_VERSION" -Recurse -ErrorAction Ignore New-Item ".local\tmp\ollama-v$Env:WEBI_VERSION" -ItemType Directory -Force | Out-Null Push-Location ".\.local\tmp\" # Unpack archive file into this temporary directory Push-Location ".\ollama-v$Env:WEBI_VERSION\" # Windows BSD-tar handles zip. Imagine that. Write-Output " Unpacking $pkg_download_file" & tar xf "$pkg_download_file" Pop-Location # Settle unpacked archive into place Write-Output " Install Location: $pkg_src_cmd" Move-Item -Path ".\ollama-v$Env:WEBI_VERSION" -Destination "$pkg_src_dir" # Remove any leftover tmp cruft & exit tmp Remove-Item -Path ".local\tmp\ollama-v$Env:WEBI_VERSION" -Recurse -ErrorAction Ignore Pop-Location } Write-Output " Copying into '$pkg_dst_dir' from '$pkg_src_dir'" Remove-Item -Path "$pkg_dst_dir" -Recurse -ErrorAction Ignore | Out-Null Copy-Item -Path "$pkg_src" -Destination "$pkg_dst" -Recurse webi_path_add "$pkg_dst_bin" $version_output = & "$pkg_dst_cmd" --version $version_line = $version_output | ForEach-Object { $_.Split(':')[1].Trim() } | Where-Object { $_ -match "version" } Write-Output " Installed Ollama: $version_line" webi_path_add ~/.local/bin # Done Pop-Location