Update the Windows install.
This commit is contained in:
parent
4829f22abf
commit
74abcb8196
|
|
@ -1,493 +1,34 @@
|
|||
# FusionPBX Settings
|
||||
$domain_name = "hostname" # hostname, ip_address or a custom value
|
||||
$system_username = "admin" # default username admin
|
||||
$system_password = "random" # random or a custom value
|
||||
$system_branch = "master" # master, stable
|
||||
$system_directory = "${env:SystemDrive}\inetpub\FusionPBX"
|
||||
# Install FusionPBX
|
||||
# Installs PostreSQL, PostgreSQL ODBC driver, PHP 7.1, GIT, Web Platform Installer,
|
||||
# Configures ODBC, IIS, and FusionPBX
|
||||
|
||||
# FreeSWITCH Settings
|
||||
$switch_version = "1.6" # *1.6.*
|
||||
#$switch_source = $false # true or false
|
||||
#$switch_package = $true # true or false
|
||||
# includes
|
||||
. .\resources\config.ps1
|
||||
. .\resources\get-file.ps1
|
||||
. .\resources\get-link.ps1
|
||||
. .\resources\get-installed-app.ps1
|
||||
. .\resources\install-postgresql.ps1
|
||||
. .\resources\install-postgresql-odbc.ps1
|
||||
. .\resources\install-freeswitch.ps1
|
||||
. .\resources\install-git.ps1
|
||||
. .\resources\install-fusionpbx.ps1
|
||||
. .\resources\install-webplatform.ps1
|
||||
. .\resources\install-iis.ps1
|
||||
|
||||
# Database Settings
|
||||
$database_password = "random" # random or a custom value
|
||||
#$database_backup = $false # true or false
|
||||
|
||||
# General Settings
|
||||
$php_version = 7 # PHP version 5 or 7
|
||||
$web_server = "IIS" # nginx or IIS
|
||||
$iis_identity = "LocalSystem" # localSystem or NetworkService
|
||||
|
||||
# Download file to current folder using default or provided name. Return saved file name
|
||||
Function Get-File([string]$url, [string]$filename) {
|
||||
#Get filename from path
|
||||
if ($filename.Length -eq 0) {
|
||||
$filename = Split-Path -Path $url -Leaf
|
||||
}
|
||||
#Download if local copy doesn't exist
|
||||
if (-not (Test-Path $filename)) {
|
||||
Invoke-WebRequest $url -OutFile $filename
|
||||
}
|
||||
return $filename
|
||||
}
|
||||
|
||||
# Get page with links, filter, and select latest version using pattern. Return file download URL.
|
||||
Function Get-Link([string]$url, [string]$pattern) {
|
||||
$link = (Invoke-WebRequest $url).Links | Where-Object {$_.href -like $pattern} | Select-Object -Last 1
|
||||
Write-Host $link.href -ForegroundColor Gray
|
||||
|
||||
#Use System.URI to combine url parts
|
||||
$uri = New-Object -TypeName System.URI -ArgumentList ([System.URI]$url),($link.href)
|
||||
return $uri.AbsoluteUri
|
||||
}
|
||||
|
||||
Function Get-CPU() {
|
||||
if ($env:PROCESSOR_ARCHITECTURE -eq "x86") {
|
||||
Return "x86"
|
||||
}
|
||||
else {
|
||||
Return "x64"
|
||||
}
|
||||
}
|
||||
|
||||
Function Write-Log([string]$message) {
|
||||
Add-Content -Path "install.log" -Value $message
|
||||
Write-Host $message -ForegroundColor Cyan
|
||||
}
|
||||
|
||||
Function New-Password([int32]$length) {
|
||||
$password = ""
|
||||
$chars = "abcdefghijkmnopqrstuvwxyzABCEFGHJKLMNPQRSTUVWXYZ23456789!#%&?".ToCharArray()
|
||||
1..$length | ForEach { $password += $chars | Get-Random }
|
||||
return $password
|
||||
}
|
||||
|
||||
Function Get-InstalledApp([string]$name) {
|
||||
Get-ItemProperty HKLM:\Software\Microsoft\Windows\CurrentVersion\Uninstall\* | Where-Object DisplayName -like $name | Select-Object DisplayName, DisplayVersion, Publisher, InstallDate,UninstallString | Format-Table –AutoSize
|
||||
}
|
||||
|
||||
#Download and install latest version on FreeSWITCH 1.6.
|
||||
#Set it to auto start
|
||||
Function Install-FreeSWITCH() {
|
||||
$cpu = Get-CPU
|
||||
if ($cpu -eq "x86") {
|
||||
$url = "http://files.freeswitch.org/windows/installer/x86/"
|
||||
}
|
||||
else {
|
||||
$url = "http://files.freeswitch.org/windows/installer/x64/"
|
||||
}
|
||||
$link = Get-Link $url "*${switch_version}*"
|
||||
Write-Host Download FreeSWITCH from $link -ForegroundColor Cyan
|
||||
$filename = Get-File $link
|
||||
|
||||
Write-Host "Install Freeswitch" -ForegroundColor Cyan
|
||||
|
||||
#Remove FreeSWITCH
|
||||
Start-Process MsiExec.exe "/x {B004A325-1272-47E5-A415-A74E9FC99865} /passive /qb" -Wait
|
||||
#Install new version
|
||||
Start-Process msiexec "/i $filename /passive /qb" -Wait
|
||||
#Configure service to auto start
|
||||
Start-Process sc "config FreeSWITCH start= auto" -Wait -NoNewWindow
|
||||
#Start-Service FreeSWITCH
|
||||
|
||||
#Set permissions to folder "c:\Program Files\FreeSWITCH" for PHP (IIS)
|
||||
if ($iis_identity -ne "LocalSystem") {
|
||||
Icacls "c:\Program Files\FreeSWITCH" /grant "NetworkService:(OI)(CI)M"
|
||||
}
|
||||
|
||||
#mod_lua.dll is missing from recent windows builds
|
||||
$lua = "C:\Program Files\FreeSWITCH\mod\mod_lua.dll"
|
||||
if ( -not (Test-Path $lua) ) {
|
||||
Get-File "https://raw.github.com/sergey-mz/fusionpbx-install.sh/master/windows/resources/$cpu/mod_lua.dll"
|
||||
Copy-Item ".\mod_lua.dll" -Destination $lua
|
||||
}
|
||||
}
|
||||
|
||||
Function Install-7zip() {
|
||||
if (-not (Test-Path "c:\Program Files\7-Zip\7z.exe")) {
|
||||
Write-Host "Downloading and Installing 7-Zip" -ForegroundColor Cyan
|
||||
if ($env:PROCESSOR_ARCHITECTURE -eq "x86") {
|
||||
$zip7 = Get-File http://www.7-zip.org/a/7z1604.msi
|
||||
}
|
||||
else {
|
||||
$zip7 = Get-File http://www.7-zip.org/a/7z1604-x64.msi
|
||||
}
|
||||
Start-Process msiexec "/i $zip7 /passive /qb" -Wait
|
||||
}
|
||||
}
|
||||
|
||||
Function Expand-ZIP([string]$filename) {
|
||||
#Extract archive
|
||||
if ($PSVersionTable.PSVersion.Major -ge 5) {
|
||||
Expand-Archive $filename -DestinationPath .
|
||||
}
|
||||
elseif ( [System.Reflection.Assembly]::LoadWithPartialName("System.IO.Compression.FileSystem") ) {
|
||||
$path = Get-Location
|
||||
[System.IO.Compression.ZipFile]::ExtractToDirectory("$path\$filename",$path)
|
||||
}
|
||||
else {
|
||||
#Check if 7zip is installed and install it if needed
|
||||
Install-7zip
|
||||
#Extract all files
|
||||
Start-Process "c:\Program Files\7-Zip\7z.exe" "e -y $filename"
|
||||
}
|
||||
}
|
||||
|
||||
Function Install-PostgresODBC() {
|
||||
$cpu = Get-CPU
|
||||
$url = "https://ftp.postgresql.org/pub/odbc/versions/msi/"
|
||||
$link = Get-Link $url -pattern "*" + ($cpu) + "*"
|
||||
Write-Host Download ODBC from $link -ForegroundColor Cyan
|
||||
$filename = Get-File $link
|
||||
Expand-ZIP $filename
|
||||
|
||||
Write-Host Install postgresql-odbc
|
||||
$filename = Get-Item psqlodbc*.exe
|
||||
if ($filename) {
|
||||
Start-Process $filename -Wait
|
||||
}
|
||||
|
||||
$filename = Get-Item psqlodbc*.msi
|
||||
if ($filename) {
|
||||
Start-Process msiexec "/i $filename /passive /qb" -Wait
|
||||
}
|
||||
|
||||
#if ((Get-Command Get-OdbcDsn -ErrorAction SilentlyContinue)) {
|
||||
# #Get or create DSN
|
||||
# $dsn = Get-OdbcDsn FusionPBX -ErrorAction SilentlyContinue
|
||||
# Remove-OdbcDsn FusionPBX -DsnType System
|
||||
# if ($dsn.length -eq 0) {
|
||||
# # Get ODBC Driver name
|
||||
# $driver = (Get-OdbcDriver -Name "PostgreSQL Unicode*").Name
|
||||
# $dsn = Add-OdbcDsn -DsnType System -Name fusionpbx -DriverName $driver -SetPropertyValue "servername=localhost","port=5432","database=fusionpbx","GssAuthUseGSS=0"
|
||||
# }
|
||||
# $dsn | Set-OdbcDsn -SetPropertyValue Username=postgres
|
||||
# $dsn | Set-OdbcDsn -SetPropertyValue password=$database_password
|
||||
#}
|
||||
#else {
|
||||
# Configure DSN with ODBC Administrator
|
||||
Write-Host The ODBC Administrator window will open. -ForegroundColor Yellow
|
||||
if ($cpu -eq "x86") {
|
||||
$driver="PostgreSQL Unicode"
|
||||
}
|
||||
else {
|
||||
$driver="PostgreSQL Unicode(x64)"
|
||||
}
|
||||
#ODBCCONF.EXE /Lv dsn_log.txt CONFIGSYSDSN "$driver" "DSN=fusionpbx|server=localhost|port=5432|database=fusionpbx|Username=postgres|password=$database_password"
|
||||
ODBCCONF.EXE /Lv dsn_log.txt CONFIGSYSDSN "$driver" "DSN=fusionpbx|server=localhost|port=5432|database=fusionpbx|Username=postgres|password=$database_password|GssAuthUseGSS=false"
|
||||
#}
|
||||
#Start-Process odbcad32.exe -Wait
|
||||
}
|
||||
|
||||
Function Start-PSQL([string]$command) {
|
||||
$location = Get-Location
|
||||
Set-Location "C:\Program Files\PostgreSQL\10\bin"
|
||||
.\psql.exe --username=postgres -c "$command"
|
||||
Set-Location $location
|
||||
}
|
||||
|
||||
Function Test-ODBC([string]$DSN,[string]$username,[string]$password) {
|
||||
$connection_string = "DSN=$DSN;"
|
||||
if ($username) {
|
||||
$connection_string += "username=$username;"
|
||||
}
|
||||
if ($password) {
|
||||
$connection_string += "password=$password;"
|
||||
}
|
||||
$conn = New-Object System.Data.Odbc.OdbcConnection
|
||||
$conn.ConnectionString = $connection_string
|
||||
$conn.open()
|
||||
$result = ($conn.State -eq "Open")
|
||||
if ($result) {
|
||||
$conn.Close()
|
||||
}
|
||||
return $result
|
||||
}
|
||||
|
||||
Function Start-ODBC([string]$query) {
|
||||
$conn = New-Object System.Data.Odbc.OdbcConnection
|
||||
$conn.ConnectionString = "DSN=fusionpbx;username=fusionpbx;password=$database_password"
|
||||
$conn.open()
|
||||
if ($conn.State -eq "Open") {
|
||||
$cmd = New-object System.Data.Odbc.OdbcCommand($query,$conn)
|
||||
$cmd.ExecuteScalar()
|
||||
$conn.Close()
|
||||
}
|
||||
}
|
||||
|
||||
#Start-ODBC "select username from v_users"
|
||||
|
||||
Function Install-PostgreSQL() {
|
||||
if (Get-InstalledApp "PostgreSQL*") {
|
||||
Write-Host PostgreSQL is already installed
|
||||
return
|
||||
}
|
||||
if ($env:PROCESSOR_ARCHITECTURE -eq "x86") {
|
||||
$url = "https://get.enterprisedb.com/postgresql/postgresql-10.1-3-windows.exe"
|
||||
}
|
||||
else {
|
||||
$url = "https://get.enterprisedb.com/postgresql/postgresql-10.1-3-windows-x64.exe"
|
||||
}
|
||||
|
||||
Write-Host Download PostgreSQL from $url -ForegroundColor Cyan
|
||||
$filename = Get-File $url
|
||||
Write-Host Install Postgresql -ForegroundColor Cyan
|
||||
|
||||
Start-Process $filename "--mode unattended --superpassword $database_password" -Wait
|
||||
#Get-Service postgre*
|
||||
|
||||
Write-Host "Create the database and users" -ForegroundColor Cyan
|
||||
Start-PSQL "CREATE DATABASE fusionpbx;";
|
||||
Start-PSQL "CREATE DATABASE freeswitch;";
|
||||
Start-PSQL "CREATE ROLE fusionpbx WITH SUPERUSER LOGIN PASSWORD '$database_password';"
|
||||
Start-PSQL "CREATE ROLE freeswitch WITH SUPERUSER LOGIN PASSWORD '$database_password';"
|
||||
Start-PSQL "GRANT ALL PRIVILEGES ON DATABASE fusionpbx to fusionpbx;"
|
||||
Start-PSQL "GRANT ALL PRIVILEGES ON DATABASE freeswitch to fusionpbx;"
|
||||
Start-PSQL "GRANT ALL PRIVILEGES ON DATABASE freeswitch to freeswitch;"
|
||||
}
|
||||
|
||||
Function Install-Git(){
|
||||
if ($env:PROCESSOR_ARCHITECTURE -eq "x86") {
|
||||
$url = "https://github.com/git-for-windows/git/releases/download/v2.15.1.windows.2/Git-2.15.1.2-32-bit.exe"
|
||||
}
|
||||
else {
|
||||
$url = "https://github.com/git-for-windows/git/releases/download/v2.15.1.windows.2/Git-2.15.1.2-64-bit.exe"
|
||||
}
|
||||
|
||||
Write-Host Download Git from $url -ForegroundColor Cyan
|
||||
$filename = Get-File $url
|
||||
Write-Host Install git -ForegroundColor Cyan
|
||||
Start-Process $filename /quiet -Wait
|
||||
Remove-Item $filename
|
||||
}
|
||||
|
||||
Function Install-FusionPBX() {
|
||||
#Set directory
|
||||
if (-not (Test-Path $system_directory)) {
|
||||
New-Item $system_directory -ItemType Directory
|
||||
}
|
||||
|
||||
<# #Clean default files
|
||||
if (Test-Path "$system_directory\iisstart.htm") {
|
||||
Get-ChildItem "$system_directory\*" -Recurse | Remove-Item -Force
|
||||
}
|
||||
#>
|
||||
#Clone FusionPBX GIT from Master or 4.2
|
||||
if ($system_branch -eq "stable") { $branch = "4.2" }
|
||||
else { $branch = ""}
|
||||
Start-Process "C:\Program Files\Git\bin\git.exe" "clone $branch https://github.com/fusionpbx/fusionpbx.git $system_directory" -Wait
|
||||
|
||||
#Grant permissions to FusionPBX folder
|
||||
if ($iis_identity -ne "LocalSystem") {
|
||||
Icacls $system_directory /grant "${iis_identity}:(OI)(CI)M"
|
||||
}
|
||||
|
||||
#Copy configuration
|
||||
Move-Item -Path "c:\Program Files\FreeSWITCH\conf" -Destination "c:\Program Files\FreeSWITCH\conf-orig"
|
||||
Copy-Item "$system_directory\resources\templates\conf" "c:\Program Files\FreeSWITCH" -recurse
|
||||
|
||||
#Update xml_cdr url, user and password
|
||||
$filename = "C:\Program Files\FreeSWITCH\conf\autoload_configs\xml_cdr.conf.xml"
|
||||
(Get-Content $filename) -replace "{v_http_protocol}","http" `
|
||||
-replace "{domain_name}",$domain_name `
|
||||
-replace "{v_project_path}","" `
|
||||
-replace "{v_user}:{v_pass}",((New-Password 8) + ":" + (New-Password 8)) | Out-File $filename
|
||||
}
|
||||
|
||||
Function Install-IIS([string]$path) {
|
||||
[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.Web.Administration")
|
||||
$iis = new-object Microsoft.Web.Administration.ServerManager
|
||||
|
||||
#Create or set application pool
|
||||
if (-not ($iis.ApplicationPools.Item("PHP"))) {
|
||||
$pool = $iis.ApplicationPools.Add("PHP")
|
||||
}
|
||||
$pool = $iis.ApplicationPools.Item("PHP")
|
||||
$pool.ProcessModel.IdentityType = "NetworkService"
|
||||
$pool.ProcessModel.IdleTimeout = "00:30:00"
|
||||
|
||||
#Grant permissions to path
|
||||
if ($iis_identity -ne "LocalSystem") {
|
||||
Icacls $path /grant "${iis_identity}:(OI)(CI)M"
|
||||
}
|
||||
|
||||
$site= $iis.Sites | Where-Object Bindings -Like "*:80:*"
|
||||
#Get site
|
||||
if ($site) {
|
||||
$site.Name = "FusionPBX"
|
||||
}
|
||||
elseif ($iis.sites.Item("FusionPBX")) {
|
||||
$site = $iis.Sites.Item("FusionPBX")
|
||||
}
|
||||
else {
|
||||
$site = $iis.Sites.Add("FusionPBX",$path,80)
|
||||
}
|
||||
|
||||
#$site.Bindings | Format-Table protocol,EndPoint,Host,SslFlags -AutoSize
|
||||
|
||||
#$cert = (Get-ChildItem –Path cert:\LocalMachine\My | Sort-Object NotAfter | Select-Object -Last 1).Thumbprint
|
||||
#netsh http delete sslcert ipport=0.0.0.0:443
|
||||
#netsh http add sslcert ipport=0.0.0.0:443 certhash=$cert "appid={4dc3e181-e14b-4a21-b022-59fc669b0914}"
|
||||
#netsh http show sslcert
|
||||
|
||||
#Set anonymous authentication to application pool identity
|
||||
$config = $iis.GetApplicationHostConfiguration()
|
||||
$auth = $config.GetSection("system.webServer/security/authentication/anonymousAuthentication", "FusionPBX/")
|
||||
$auth.SetAttributeValue("userName","")
|
||||
|
||||
#Set application pool
|
||||
$app = $site.Applications | Where-Object -Property Path -eq '/'
|
||||
$app.ApplicationPoolName = $pool.Name
|
||||
|
||||
#Set physical path
|
||||
$vd = $app.VirtualDirectories | Where-Object -Property Path -eq '/'
|
||||
$vd.PhysicalPath = $path
|
||||
|
||||
#Save
|
||||
$iis.CommitChanges()
|
||||
}
|
||||
|
||||
Function Start-WebPlatform() {
|
||||
if (-not (Test-Path "${env:ProgramFiles}\Microsoft\Web Platform Installer\WebPlatformInstaller.exe")) {
|
||||
$filename = Get-File http://download.microsoft.com/download/F/4/2/F42AB12D-C935-4E65-9D98-4E56F9ACBC8E/wpilauncher.exe
|
||||
Start-Process $filename -Wait
|
||||
}
|
||||
else {
|
||||
Start-Process "C:\Program Files\Microsoft\Web Platform Installer\WebPlatformInstaller.exe" -Wait
|
||||
}
|
||||
}
|
||||
|
||||
Function Install-Nginx() {
|
||||
Write-Host Going to install NGINX
|
||||
$filename = Get-File http://nginx.org/download/nginx-1.12.1.zip
|
||||
. "C:\Program Files\7-Zip\7z.exe" "e $filename -oc:\Nginx"
|
||||
# needed for php7.0
|
||||
$filename = Get-File https://download.microsoft.com/download/9/3/F/93FCF1E7-E6A4-478B-96E7-D4B285925B00/vc_redist.x64.exe
|
||||
Start-Process vc_redist.x64.exe /quiet -Wait
|
||||
Write-Host Going to install PHP 7.0
|
||||
Get-File http://windows.php.net/downloads/releases/php-7.0.1-nts-Win32-VC14-x64.zip -OutFile php-7.0.1-nts-Win32-VC14-x64.zip
|
||||
|
||||
$url = "http://windows.php.net/downloads/releases"
|
||||
#php-7.0.1-nts-Win32-VC14-x64.zip
|
||||
$link = Get-Link $url "*php-7.0*x64*"
|
||||
Write-Host Download PHP from $link -ForegroundColor Cyan
|
||||
$filename = Get-File $link
|
||||
Start-Process "C:\Program Files\7-Zip\7z.exe" "e $filename" -Wait
|
||||
|
||||
Set-Location "C:/nginx"
|
||||
}
|
||||
|
||||
#[System.Environment]::OSVersion.Version.Major
|
||||
|
||||
#Display installed applications
|
||||
Get-InstalledApp "FreeSWITCH*"
|
||||
Get-InstalledApp "PHP*"
|
||||
Get-InstalledApp "PostgreSQL*"
|
||||
#Get-InstalledApp "psqlodbc*"
|
||||
#Get-InstalledApp "7*"
|
||||
|
||||
Write-Host "This will install/update and configure FusionPBX, FreeSWITCH, PostgreSQL, PHP, 7-Zip."
|
||||
|
||||
# Create folder and make it current
|
||||
if (-not (Test-Path "$env:PUBLIC\Downloads\FusionPBX")) {
|
||||
mkdir "$env:PUBLIC\Downloads\FusionPBX"
|
||||
}
|
||||
Set-Location "$env:PUBLIC\Downloads\FusionPBX"
|
||||
|
||||
#Required for FreeSWITCH
|
||||
if ( ([System.Environment]::OSVersion.Version.Build -lt 9600) -and -not (Get-InstalledApp "FreeSWITCH*") -and -not (Get-HotFix -id KB2999226)) {
|
||||
Write-Host Install update KB2999226
|
||||
Return
|
||||
}
|
||||
|
||||
#System Password
|
||||
if ($system_password -eq 'random') {
|
||||
$system_password = New-Password 20
|
||||
}
|
||||
elseif ($system_password -eq '') {
|
||||
$system_password = Read-Host -Prompt "Enter system password"
|
||||
}
|
||||
|
||||
#Database Password
|
||||
if ($env:PGPASSWORD) {
|
||||
$database_password = $env:PGPASSWORD
|
||||
}
|
||||
if ($database_password -eq 'random') {
|
||||
$database_password = New-Password 20
|
||||
}
|
||||
elseif ($database_password -eq '') {
|
||||
$database_password = Read-Host -Prompt "Enter database superuser (postgres) password"
|
||||
}
|
||||
#Set DB password
|
||||
$env:PGPASSWORD = "$database_password"
|
||||
|
||||
#Set the domain name
|
||||
$cert = Get-ChildItem –Path cert:\LocalMachine\My | Where-Object -Property Subject -Like "CN=${env:COMPUTERNAME}*" | Sort-Object NotAfter | Select-Object -Last 1
|
||||
if ( $cert -and ($domain_name -eq "hostname") ) {
|
||||
$domain_name = $cert.Subject.Substring(3)
|
||||
}
|
||||
elseif ($domain_name -eq "hostname") {
|
||||
$domain_name = $env:COMPUTERNAME
|
||||
#$dns = [System.Net.Dns]::GetHostByName(($env:computerName))
|
||||
#$domain_name = $dns.HostName
|
||||
#$dns.addresslist.IPAddressToString
|
||||
}
|
||||
else {
|
||||
$domain_name = [System.Net.Dns]::GetHostByName(($env:computerName)).AddressList.IPAddressToString
|
||||
}
|
||||
# installed applications
|
||||
Get-Installed-App "FreeSWITCH*"
|
||||
Get-Installed-App "PHP*"
|
||||
Get-Installed-App "PostgreSQL*"
|
||||
Get-Installed-App "psqlODBC*"
|
||||
Get-Installed-App "7zip"
|
||||
|
||||
Install-PostgreSQL
|
||||
Install-PostgresODBC
|
||||
Test-ODBC fusionpbx postgres $database_password
|
||||
|
||||
Install-FreeSWITCH
|
||||
Install-Git
|
||||
Install-FusionPBX
|
||||
Install-WebPlatform
|
||||
Install-IIS
|
||||
|
||||
if ($web_server -eq "IIS") {
|
||||
#Run IIS platform installer
|
||||
Write-Host "Install PHP 7.1, PHP Manager for IIS and URL Rewrite using Web Platform Installer" -ForegroundColor Yellow
|
||||
Start-WebPlatform
|
||||
|
||||
#Run IIS manager and create FusionPBX app
|
||||
Write-Host "Create web site in IIS" -ForegroundColor Yellow
|
||||
Write-Host "Enable extensions php_pgsql and php_pdo_pgsql" in IIS -ForegroundColor Yellow
|
||||
Write-Host "Use URL Rewrite to import rules from .htaccess file" -ForegroundColor Yellow
|
||||
Start-Process "${env:SystemRoot}\system32\inetsrv\InetMgr.exe"
|
||||
|
||||
Install-IIS -path $system_directory -port 80
|
||||
iisreset
|
||||
|
||||
#Remove current configuration
|
||||
#Remove-Item c:\inetpub\FusionPBX\resources\config.php
|
||||
}
|
||||
|
||||
#Update schema
|
||||
."C:\Program Files\PHP\v7.1\php.exe" "$system_directory/core/upgrade/upgrade_schema.php"
|
||||
|
||||
[string]$domain_uuid = [System.Guid]::NewGuid()
|
||||
Start-PSQL "insert into v_domains (domain_uuid, domain_name, domain_enabled) values('$domain_uuid', '$domain_name', 'true');"
|
||||
."C:\Program Files\PHP\v7.1\php.exe" "$system_directory/core/upgrade/upgrade_domains.php"
|
||||
|
||||
Write-Log ""
|
||||
Write-Log " Use a web browser to continue setup."
|
||||
Write-Log " domain name: https://$domain_name"
|
||||
Write-Log " username: $system_username"
|
||||
Write-Log " password: $system_password"
|
||||
Write-Log ""
|
||||
Write-Log " The domain name in the browser is used by default as part of the authentication."
|
||||
Write-Log " If you need to login to a different domain then use username@domain."
|
||||
Write-Log " username: $system_username@$domain_name";
|
||||
Write-Log ""
|
||||
Write-Log " Database:"
|
||||
Write-Log " username: postgres"
|
||||
Write-Log " password: $database_password"
|
||||
Write-Log ""
|
||||
Write-Log " Additional information."
|
||||
Write-Log " https://fusionpbx.com/support.php"
|
||||
Write-Log " https://www.fusionpbx.com"
|
||||
Write-Log " http://docs.fusionpbx.com"
|
||||
|
||||
#Start login page
|
||||
Start-Process http://$domain_name
|
||||
# Finish the install
|
||||
. .\resources\finish.ps1
|
||||
|
|
|
|||
|
|
@ -0,0 +1,18 @@
|
|||
|
||||
# FusionPBX Settings
|
||||
$domain_name = "hostname" # hostname, ip_address or a custom value
|
||||
$system_username = "admin" # default username admin
|
||||
$system_password = "random" # random or a custom value
|
||||
$system_branch = "master" # master, stable
|
||||
$system_directory = "${env:SystemDrive}\inetpub\FusionPBX"
|
||||
|
||||
# FreeSWITCH Settings
|
||||
$switch_version = "1.6" # *1.6.*
|
||||
|
||||
# Database Settings
|
||||
$database_password = "random" # random or a custom value
|
||||
|
||||
# General Settings
|
||||
$php_version = 7 # PHP version 7
|
||||
$web_server = "IIS" # nginx or IIS
|
||||
$iis_identity = "LocalSystem" # localSystem or NetworkService
|
||||
|
|
@ -0,0 +1,15 @@
|
|||
#Set the domain name
|
||||
$cert = Get-ChildItem -Path cert:\LocalMachine\My | Where-Object -Property Subject -Like "CN=${env:COMPUTERNAME}*" | Sort-Object NotAfter | Select-Object -Last 1
|
||||
if ( $cert -and ($domain_name -eq "hostname") ) {
|
||||
$domain_name = $cert.Subject.Substring(3)
|
||||
}
|
||||
elseif ($domain_name -eq "hostname") {
|
||||
$domain_name = $env:COMPUTERNAME
|
||||
#$dns = [System.Net.Dns]::GetHostByName(($env:computerName))
|
||||
#$domain_name = $dns.HostName
|
||||
#$dns.addresslist.IPAddressToString
|
||||
}
|
||||
else {
|
||||
$domain_name = [System.Net.Dns]::GetHostByName(($env:computerName)).AddressList.IPAddressToString
|
||||
}
|
||||
Write-Host "Domain Name is $domain_name"
|
||||
|
|
@ -0,0 +1,17 @@
|
|||
Function Expand-ZIP([string]$filename) {
|
||||
#Extract archive
|
||||
if ($PSVersionTable.PSVersion.Major -ge 5) {
|
||||
Expand-Archive $filename -DestinationPath .
|
||||
}
|
||||
elseif ( [System.Reflection.Assembly]::LoadWithPartialName("System.IO.Compression.FileSystem") ) {
|
||||
$path = Get-Location
|
||||
[System.IO.Compression.ZipFile]::ExtractToDirectory("$path\$filename",$path)
|
||||
}
|
||||
else {
|
||||
#Check if 7zip is installed and install it if needed
|
||||
. .\resources\install-7zip.ps1
|
||||
Install-7zip
|
||||
#Extract all files
|
||||
Start-Process "c:\Program Files\7-Zip\7z.exe" "e -y $filename"
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,72 @@
|
|||
#Includes
|
||||
. .\resources\config.ps1
|
||||
. .\resources\write-log.ps1
|
||||
. .\resources\domain_name.ps1
|
||||
. .\resources\get-database_password.ps1
|
||||
. .\resources\get-system_password.ps1
|
||||
. .\resources\start-pgsql.ps1
|
||||
|
||||
#add the config.php
|
||||
Copy-Item "fusionpbx/config.php" "$system_directory/resources"
|
||||
$filename = "$system_directory/resources/config.php"
|
||||
(Get-Content $filename) -replace "{database_username}","fusionpbx" `
|
||||
-replace "{database_password}",$database_password | Out-File $filename
|
||||
|
||||
#add the database schema
|
||||
."C:\Program Files\PHP\v7.1\php.exe" "$system_directory/core/upgrade/upgrade_schema.php"
|
||||
|
||||
#get the domain_uuid
|
||||
[string]$domain_uuid = [System.Guid]::NewGuid()
|
||||
|
||||
#add the domain name
|
||||
Start-PSQL "insert into v_domains (domain_uuid, domain_name, domain_enabled) values('$domain_uuid', '$domain_name', 'true');"
|
||||
|
||||
#app defaults
|
||||
."C:\Program Files\PHP\v7.1\php.exe" "$system_directory/core/upgrade/upgrade_domains.php"
|
||||
|
||||
#add the user
|
||||
[string]$user_uuid = [System.Guid]::NewGuid()
|
||||
[string]$user_salt = [System.Guid]::NewGuid()
|
||||
user_name=$system_username
|
||||
if ($system_password -eq 'random') {
|
||||
$user_password = New-Password 20
|
||||
}
|
||||
else {
|
||||
$user_password=$system_password
|
||||
}
|
||||
$password_hash = ."C:\Program Files\PHP\v7.1\php.exe" "-r echo md5('$user_salt$user_password');"
|
||||
Start-PSQL "insert into v_users (user_uuid, domain_uuid, username, password, salt, user_enabled) values('$user_uuid', '$domain_uuid', '$user_name', '$password_hash', '$user_salt', 'true');"
|
||||
|
||||
#get the superadmin group_uuid
|
||||
group_uuid=Start-PSQL "select group_uuid from v_groups where group_name = 'superadmin';"
|
||||
|
||||
#add the user to the group
|
||||
[string]$group_user_uuid = [System.Guid]::NewGuid()
|
||||
$group_name="superadmin"
|
||||
Start-PSQL "insert into v_group_users (group_user_uuid, domain_uuid, group_name, group_uuid, user_uuid) values('$group_user_uuid', '$domain_uuid', '$group_name', '$group_uuid', '$user_uuid');"
|
||||
|
||||
#app defaults
|
||||
."C:\Program Files\PHP\v7.1\php.exe" "$system_directory/core/upgrade/upgrade_domains.php"
|
||||
|
||||
#welcome message
|
||||
Write-Log ""
|
||||
Write-Log " Use a web browser to continue setup."
|
||||
Write-Log " domain name: https://$domain_name"
|
||||
Write-Log " username: $system_username"
|
||||
Write-Log " password: $system_password"
|
||||
Write-Log ""
|
||||
Write-Log " The domain name in the browser is used by default as part of the authentication."
|
||||
Write-Log " If you need to login to a different domain then use username@domain."
|
||||
Write-Log " username: $system_username@$domain_name";
|
||||
Write-Log ""
|
||||
Write-Log " Database:"
|
||||
Write-Log " username: postgres"
|
||||
Write-Log " password: $database_password"
|
||||
Write-Log ""
|
||||
Write-Log " Additional information."
|
||||
Write-Log " https://fusionpbx.com/support.php"
|
||||
Write-Log " https://www.fusionpbx.com"
|
||||
Write-Log " http://docs.fusionpbx.com"
|
||||
|
||||
#Start login page
|
||||
#Start-Process http://$domain_name
|
||||
|
|
@ -0,0 +1,45 @@
|
|||
<?php
|
||||
/*
|
||||
FusionPBX
|
||||
Version: MPL 1.1
|
||||
|
||||
The contents of this file are subject to the Mozilla Public License Version
|
||||
1.1 (the "License"); you may not use this file except in compliance with
|
||||
the License. You may obtain a copy of the License at
|
||||
http://www.mozilla.org/MPL/
|
||||
|
||||
Software distributed under the License is distributed on an "AS IS" basis,
|
||||
WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
||||
for the specific language governing rights and limitations under the
|
||||
License.
|
||||
|
||||
The Original Code is FusionPBX
|
||||
|
||||
The Initial Developer of the Original Code is
|
||||
Mark J Crane <markjcrane@fusionpbx.com>
|
||||
Portions created by the Initial Developer are Copyright (C) 2008-2016
|
||||
the Initial Developer. All Rights Reserved.
|
||||
|
||||
Contributor(s):
|
||||
Mark J Crane <markjcrane@fusionpbx.com>
|
||||
*/
|
||||
|
||||
//set the database type
|
||||
$db_type = 'pgsql'; //sqlite, mysql, pgsql, others with a manually created PDO connection
|
||||
|
||||
//sqlite: the db_name and db_path are automatically assigned however the values can be overidden by setting the values here.
|
||||
//$db_name = 'fusionpbx.db'; //host name/ip address + '.db' is the default database filename
|
||||
//$db_path = '/var/www/fusionpbx/secure'; //the path is determined by a php variable
|
||||
|
||||
//pgsql: database connection information
|
||||
$db_host = 'localhost'; //set the host only if the database is not local
|
||||
$db_port = '5432';
|
||||
$db_name = 'fusionpbx';
|
||||
$db_username = '{database_username}';
|
||||
$db_password = '{database_password}';
|
||||
|
||||
//show errors
|
||||
ini_set('display_errors', '1');
|
||||
//error_reporting (E_ALL); // Report everything
|
||||
error_reporting (E_ALL ^ E_NOTICE); // hide notices
|
||||
//error_reporting(E_ALL ^ E_NOTICE ^ E_WARNING ); //hide notices and warnings
|
||||
|
|
@ -0,0 +1,8 @@
|
|||
Function Get-CPU() {
|
||||
if ($env:PROCESSOR_ARCHITECTURE -eq "x86") {
|
||||
Return "x86"
|
||||
}
|
||||
else {
|
||||
Return "x64"
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,15 @@
|
|||
#includes
|
||||
. .\resources\new-password.ps1
|
||||
|
||||
#Database Password
|
||||
if ($env:PGPASSWORD) {
|
||||
$database_password = $env:PGPASSWORD
|
||||
}
|
||||
if ($database_password -eq 'random') {
|
||||
$database_password = New-Password 20
|
||||
}
|
||||
elseif ($database_password -eq '') {
|
||||
$database_password = Read-Host -Prompt "Enter database superuser (postgres) password"
|
||||
}
|
||||
#Set DB password
|
||||
$env:PGPASSWORD = "$database_password"
|
||||
|
|
@ -0,0 +1,13 @@
|
|||
|
||||
# Download file to current folder using default or provided name. Return saved file name
|
||||
Function Get-File([string]$url, [string]$filename) {
|
||||
#Get filename from path
|
||||
if ($filename.Length -eq 0) {
|
||||
$filename = Split-Path -Path $url -Leaf
|
||||
}
|
||||
#Download if local copy doesn't exist
|
||||
if (-not (Test-Path $filename)) {
|
||||
Invoke-WebRequest $url -OutFile $filename
|
||||
}
|
||||
return $filename
|
||||
}
|
||||
|
|
@ -0,0 +1,3 @@
|
|||
Function Get-Installed-App([string]$name) {
|
||||
Get-ItemProperty HKLM:\Software\Microsoft\Windows\CurrentVersion\Uninstall\* | Where-Object DisplayName -like $name | Select-Object DisplayName, DisplayVersion, Publisher, InstallDate,UninstallString | Format-Table -AutoSize
|
||||
}
|
||||
|
|
@ -0,0 +1,10 @@
|
|||
|
||||
# Get page with links, filter, and select latest version using pattern. Return file download URL.
|
||||
Function Get-Link([string]$url, [string]$pattern) {
|
||||
$link = (Invoke-WebRequest $url).Links | Where-Object {$_.href -like $pattern} | Select-Object -Last 1
|
||||
Write-Host $link.href -ForegroundColor Gray
|
||||
|
||||
#Use System.URI to combine url parts
|
||||
$uri = New-Object -TypeName System.URI -ArgumentList ([System.URI]$url),($link.href)
|
||||
return $uri.AbsoluteUri
|
||||
}
|
||||
|
|
@ -0,0 +1,7 @@
|
|||
#System Password
|
||||
if ($system_password -eq 'random') {
|
||||
$system_password = New-Password 20
|
||||
}
|
||||
elseif ($system_password -eq '') {
|
||||
$system_password = Read-Host -Prompt "Enter system password"
|
||||
}
|
||||
|
|
@ -0,0 +1,12 @@
|
|||
. .\resources\get-file.ps1
|
||||
if (-not (Test-Path "c:\Program Files\7-Zip\7z.exe")) {
|
||||
$cpu = $env:PROCESSOR_ARCHITECTURE
|
||||
Write-Host "Downloading and Installing 7-Zip for $cpu" -ForegroundColor Cyan
|
||||
if ($cpu -eq "x86") {
|
||||
$zip7 = Get-File http://www.7-zip.org/a/7z1604.msi
|
||||
}
|
||||
else {
|
||||
$zip7 = Get-File http://www.7-zip.org/a/7z1604-x64.msi
|
||||
}
|
||||
Start-Process msiexec "/i $zip7 /passive /qb" -Wait
|
||||
}
|
||||
|
|
@ -0,0 +1,51 @@
|
|||
#Download and install latest version on FreeSWITCH 1.6.
|
||||
#Set it to auto start
|
||||
Function Install-FreeSWITCH() {
|
||||
. .\resources\get-link.ps1
|
||||
. .\resources\get-file.ps1
|
||||
. .\resources\get-cpu.ps1
|
||||
|
||||
if (Get-Installed-App "FreeSWITCH*") {
|
||||
Write-Host FreeSWITCH is already installed
|
||||
return
|
||||
}
|
||||
|
||||
$cpu = Get-CPU
|
||||
if ($cpu -eq "x86") {
|
||||
$url = "http://files.freeswitch.org/windows/installer/x86/"
|
||||
}
|
||||
else {
|
||||
$url = "http://files.freeswitch.org/windows/installer/x64/"
|
||||
}
|
||||
$link = Get-Link $url "*${switch_version}*"
|
||||
Write-Host Download FreeSWITCH from $link -ForegroundColor Cyan
|
||||
$filename = Get-File $link
|
||||
|
||||
#Required for FreeSWITCH
|
||||
if ( ([System.Environment]::OSVersion.Version.Build -lt 9600) -and -not (Get-Installed-App "FreeSWITCH*") -and -not (Get-HotFix -id KB2999226)) {
|
||||
Write-Host Install update KB2999226
|
||||
Return
|
||||
}
|
||||
|
||||
Write-Host "Install Freeswitch" -ForegroundColor Cyan
|
||||
|
||||
#Remove FreeSWITCH
|
||||
Start-Process MsiExec.exe "/x {B004A325-1272-47E5-A415-A74E9FC99865} /passive /qb" -Wait
|
||||
#Install new version
|
||||
Start-Process msiexec "/i $filename /passive /qb" -Wait
|
||||
#Configure service to auto start
|
||||
Start-Process sc "config FreeSWITCH start= auto" -Wait -NoNewWindow
|
||||
#Start-Service FreeSWITCH
|
||||
|
||||
#Set permissions to folder "c:\Program Files\FreeSWITCH" for PHP (IIS)
|
||||
if ($iis_identity -ne "LocalSystem") {
|
||||
Icacls "c:\Program Files\FreeSWITCH" /grant "NetworkService:(OI)(CI)M"
|
||||
}
|
||||
|
||||
#mod_lua.dll is missing from recent windows builds
|
||||
$lua = "C:\Program Files\FreeSWITCH\mod\mod_lua.dll"
|
||||
if ( -not (Test-Path $lua) ) {
|
||||
Get-File "https://raw.github.com/sergey-mz/fusionpbx-install.sh/master/windows/resources/$cpu/mod_lua.dll"
|
||||
Copy-Item ".\mod_lua.dll" -Destination $lua
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,44 @@
|
|||
Function Install-FusionPBX() {
|
||||
|
||||
#includes
|
||||
. .\resources\new-password.ps1
|
||||
. .\resources\domain_name.ps1
|
||||
|
||||
#Set directory
|
||||
if (-not (Test-Path $system_directory)) {
|
||||
New-Item $system_directory -ItemType Directory
|
||||
}
|
||||
|
||||
# Create folder and make it current
|
||||
#if (-not (Test-Path "$env:PUBLIC\Downloads\FusionPBX")) {
|
||||
# mkdir "$env:PUBLIC\Downloads\FusionPBX"
|
||||
#}
|
||||
#Set-Location "$env:PUBLIC\Downloads\FusionPBX"
|
||||
|
||||
<# #Clean default files
|
||||
if (Test-Path "$system_directory\iisstart.htm") {
|
||||
Get-ChildItem "$system_directory\*" -Recurse | Remove-Item -Force
|
||||
}
|
||||
#>
|
||||
#Clone FusionPBX GIT from Master or 4.2
|
||||
if ($system_branch -eq "stable") { $branch = "4.2" }
|
||||
else { $branch = ""}
|
||||
Start-Process "C:\Program Files\Git\bin\git.exe" "clone $branch https://github.com/fusionpbx/fusionpbx.git $system_directory" -Wait
|
||||
|
||||
#Grant permissions to FusionPBX folder
|
||||
if ($iis_identity -ne "LocalSystem") {
|
||||
Icacls $system_directory /grant "${iis_identity}:(OI)(CI)M"
|
||||
}
|
||||
|
||||
#Copy configuration
|
||||
Move-Item -Path "c:\Program Files\FreeSWITCH\conf" -Destination "c:\Program Files\FreeSWITCH\conf-orig"
|
||||
Copy-Item "$system_directory\resources\templates\conf" "c:\Program Files\FreeSWITCH" -recurse
|
||||
|
||||
#Update xml_cdr url, user and password
|
||||
$filename = "C:\Program Files\FreeSWITCH\conf\autoload_configs\xml_cdr.conf.xml"
|
||||
(Get-Content $filename) -replace "{v_http_protocol}","http" `
|
||||
-replace "{domain_name}",$domain_name `
|
||||
-replace "{v_project_path}","" `
|
||||
-replace "{v_user}:{v_pass}",((New-Password 8) + ":" + (New-Password 8)) | Out-File $filename
|
||||
|
||||
}
|
||||
|
|
@ -0,0 +1,32 @@
|
|||
Function Install-Git(){
|
||||
|
||||
if (Get-Installed-App "Git*") {
|
||||
Write-Host "Git is already installed"
|
||||
return
|
||||
}
|
||||
|
||||
#install Git for Windows
|
||||
if ($env:PROCESSOR_ARCHITECTURE -eq "x86") {
|
||||
$url = "https://github.com/git-for-windows/git/releases/download/v2.15.1.windows.2/Git-2.15.1.2-32-bit.exe"
|
||||
}
|
||||
else {
|
||||
$url = "https://github.com/git-for-windows/git/releases/download/v2.15.1.windows.2/Git-2.15.1.2-64-bit.exe"
|
||||
}
|
||||
|
||||
Write-Host Download Git from $url -ForegroundColor Cyan
|
||||
$filename = Get-File $url
|
||||
Write-Host Install git -ForegroundColor Cyan
|
||||
Start-Process $filename /silent -Wait
|
||||
Remove-Item $filename
|
||||
|
||||
#install TortoiseGit
|
||||
if ($env:PROCESSOR_ARCHITECTURE -eq "x86") {
|
||||
$url = "https://download.tortoisegit.org/tgit/2.5.0.0/TortoiseGit-2.5.0.0-32bit.msi"
|
||||
}
|
||||
else {
|
||||
$url = "https://download.tortoisegit.org/tgit/2.5.0.0/TortoiseGit-2.5.0.0-64bit.msi"
|
||||
}
|
||||
$filename = Get-File $url
|
||||
Start-Process $filename /passive -Wait
|
||||
|
||||
}
|
||||
|
|
@ -0,0 +1,65 @@
|
|||
Function Install-IIS([string]$path) {
|
||||
|
||||
#Run IIS manager and create FusionPBX app
|
||||
Write-Host "Create web site in IIS" -ForegroundColor Yellow
|
||||
Write-Host "Enable extensions php_pgsql and php_pdo_pgsql" in IIS -ForegroundColor Yellow
|
||||
Write-Host "Use URL Rewrite to import rules from .htaccess file" -ForegroundColor Yellow
|
||||
Start-Process "${env:SystemRoot}\system32\inetsrv\InetMgr.exe"
|
||||
|
||||
Install-IIS -path $system_directory -port 80
|
||||
iisreset
|
||||
|
||||
#Remove current configuration
|
||||
#Remove-Item c:\inetpub\FusionPBX\resources\config.php
|
||||
|
||||
[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.Web.Administration")
|
||||
$iis = new-object Microsoft.Web.Administration.ServerManager
|
||||
|
||||
#Create or set application pool
|
||||
if (-not ($iis.ApplicationPools.Item("PHP"))) {
|
||||
$pool = $iis.ApplicationPools.Add("PHP")
|
||||
}
|
||||
$pool = $iis.ApplicationPools.Item("PHP")
|
||||
$pool.ProcessModel.IdentityType = "NetworkService"
|
||||
$pool.ProcessModel.IdleTimeout = "00:30:00"
|
||||
|
||||
#Grant permissions to path
|
||||
if ($iis_identity -ne "LocalSystem") {
|
||||
Icacls $path /grant "${iis_identity}:(OI)(CI)M"
|
||||
}
|
||||
|
||||
$site= $iis.Sites | Where-Object Bindings -Like "*:80:*"
|
||||
#Get site
|
||||
if ($site) {
|
||||
$site.Name = "FusionPBX"
|
||||
}
|
||||
elseif ($iis.sites.Item("FusionPBX")) {
|
||||
$site = $iis.Sites.Item("FusionPBX")
|
||||
}
|
||||
else {
|
||||
$site = $iis.Sites.Add("FusionPBX",$path,80)
|
||||
}
|
||||
|
||||
#$site.Bindings | Format-Table protocol,EndPoint,Host,SslFlags -AutoSize
|
||||
|
||||
#$cert = (Get-ChildItem –Path cert:\LocalMachine\My | Sort-Object NotAfter | Select-Object -Last 1).Thumbprint
|
||||
#netsh http delete sslcert ipport=0.0.0.0:443
|
||||
#netsh http add sslcert ipport=0.0.0.0:443 certhash=$cert "appid={4dc3e181-e14b-4a21-b022-59fc669b0914}"
|
||||
#netsh http show sslcert
|
||||
|
||||
#Set anonymous authentication to application pool identity
|
||||
$config = $iis.GetApplicationHostConfiguration()
|
||||
$auth = $config.GetSection("system.webServer/security/authentication/anonymousAuthentication", "FusionPBX/")
|
||||
$auth.SetAttributeValue("userName","")
|
||||
|
||||
#Set application pool
|
||||
$app = $site.Applications | Where-Object -Property Path -eq '/'
|
||||
$app.ApplicationPoolName = $pool.Name
|
||||
|
||||
#Set physical path
|
||||
$vd = $app.VirtualDirectories | Where-Object -Property Path -eq '/'
|
||||
$vd.PhysicalPath = $path
|
||||
|
||||
#Save
|
||||
$iis.CommitChanges()
|
||||
}
|
||||
|
|
@ -0,0 +1,21 @@
|
|||
Function Install-Nginx() {
|
||||
. .\resources\get-file.ps1
|
||||
. .\resources\get-link.ps1
|
||||
Write-Host Going to install NGINX
|
||||
$filename = Get-File http://nginx.org/download/nginx-1.12.1.zip
|
||||
. "C:\Program Files\7-Zip\7z.exe" "e $filename -oc:\Nginx"
|
||||
# needed for php7.0
|
||||
$filename = Get-File https://download.microsoft.com/download/9/3/F/93FCF1E7-E6A4-478B-96E7-D4B285925B00/vc_redist.x64.exe
|
||||
Start-Process vc_redist.x64.exe /quiet -Wait
|
||||
Write-Host Going to install PHP 7.0
|
||||
Get-File http://windows.php.net/downloads/releases/php-7.0.1-nts-Win32-VC14-x64.zip -OutFile php-7.0.1-nts-Win32-VC14-x64.zip
|
||||
|
||||
$url = "http://windows.php.net/downloads/releases"
|
||||
#php-7.0.1-nts-Win32-VC14-x64.zip
|
||||
$link = Get-Link $url "*php-7.0*x64*"
|
||||
Write-Host Download PHP from $link -ForegroundColor Cyan
|
||||
$filename = Get-File $link
|
||||
Start-Process "C:\Program Files\7-Zip\7z.exe" "e $filename" -Wait
|
||||
|
||||
Set-Location "C:/nginx"
|
||||
}
|
||||
|
|
@ -0,0 +1,63 @@
|
|||
Function Install-PostgresODBC() {
|
||||
. .\resources\get-cpu.ps1
|
||||
. .\resources\get-link.ps1
|
||||
. .\resources\get-file.ps1
|
||||
. .\resources\expand-zip.ps1
|
||||
. .\resources\get-database_password
|
||||
|
||||
if (Get-Installed-App "psqlODBC*") {
|
||||
Write-Host PostgreSQL ODBC is already installed
|
||||
return
|
||||
}
|
||||
|
||||
$cpu = Get-CPU
|
||||
if ($cpu -eq "x86") {
|
||||
$url = "https://ftp.postgresql.org/pub/odbc/versions/msi/psqlodbc_10_01_0000-x86.zip"
|
||||
}
|
||||
else {
|
||||
$url = "https://ftp.postgresql.org/pub/odbc/versions/msi/psqlodbc_10_01_0000-x64.zip"
|
||||
}
|
||||
Write-Host Download ODBC from $url -ForegroundColor Cyan
|
||||
$filename = Get-File $url -Force
|
||||
Expand-ZIP $filename
|
||||
|
||||
Write-Host Install postgresql-odbc
|
||||
$filename = Get-Item psqlodbc*.exe
|
||||
if ($filename) {
|
||||
Start-Process $filename -Wait
|
||||
}
|
||||
|
||||
$filename = Get-Item psqlodbc*.msi
|
||||
if ($filename) {
|
||||
Start-Process msiexec "/i $filename /passive /qb" -Wait
|
||||
}
|
||||
|
||||
#if ((Get-Command Get-OdbcDsn)) { # -ErrorAction SilentlyContinue
|
||||
#Get or create DSN
|
||||
# $dsn = Get-OdbcDsn FusionPBX -ErrorAction SilentlyContinue
|
||||
# Remove-OdbcDsn FusionPBX -DsnType System
|
||||
# if ($dsn.length -eq 0) {
|
||||
# Get ODBC Driver name
|
||||
# $driver = (Get-OdbcDriver -Name "PostgreSQL Unicode*").Name
|
||||
# $dsn = Add-OdbcDsn -DsnType System -Name fusionpbx -DriverName $driver -SetPropertyValue "servername=localhost","port=5432","database=fusionpbx","GssAuthUseGSS=0"
|
||||
# }
|
||||
# $dsn | Set-OdbcDsn -SetPropertyValue Username=postgres
|
||||
# $dsn | Set-OdbcDsn -SetPropertyValue password=$database_password
|
||||
#}
|
||||
#else {
|
||||
# Configure DSN with ODBC Administrator
|
||||
Write-Host The ODBC Administrator window will open. -ForegroundColor Yellow
|
||||
if ($cpu -eq "x86") {
|
||||
$driver="PostgreSQL Unicode"
|
||||
}
|
||||
else {
|
||||
$driver="PostgreSQL Unicode(x64)"
|
||||
}
|
||||
#ODBCCONF.EXE /Lv dsn_log.txt CONFIGSYSDSN "$driver" "DSN=fusionpbx|server=localhost|port=5432|database=fusionpbx|Username=postgres|password=$database_password"
|
||||
ODBCCONF.EXE /Lv dsn_log.txt CONFIGSYSDSN "$driver" "DSN=fusionpbx|server=localhost|port=5432|database=fusionpbx|Username=postgres|password=$database_password|GssAuthUseGSS=false"
|
||||
#}
|
||||
#Start-Process odbcad32.exe -Wait
|
||||
}
|
||||
|
||||
#. .\resources\get-database_password
|
||||
#Test-ODBC fusionpbx postgres $database_password
|
||||
|
|
@ -0,0 +1,34 @@
|
|||
Function Install-PostgreSQL() {
|
||||
|
||||
. .\resources\get-file.ps1
|
||||
. .\resources\get-database_password.ps1
|
||||
. .\resources\start-pgsql.ps1
|
||||
. .\resources\get-installed-app.ps1
|
||||
|
||||
if (Get-Installed-App "PostgreSQL*") {
|
||||
Write-Host PostgreSQL is already installed
|
||||
return
|
||||
}
|
||||
if ($env:PROCESSOR_ARCHITECTURE -eq "x86") {
|
||||
$url = "https://get.enterprisedb.com/postgresql/postgresql-10.1-3-windows.exe"
|
||||
}
|
||||
else {
|
||||
$url = "https://get.enterprisedb.com/postgresql/postgresql-10.1-3-windows-x64.exe"
|
||||
}
|
||||
|
||||
Write-Host Download PostgreSQL from $url -ForegroundColor Cyan
|
||||
$filename = Get-File $url
|
||||
Write-Host Install Postgresql -ForegroundColor Cyan
|
||||
|
||||
Start-Process $filename "--mode unattended --superpassword $database_password" -Wait
|
||||
#Get-Service postgre*
|
||||
|
||||
Write-Host "Create the database and users" -ForegroundColor Cyan
|
||||
Start-PSQL "CREATE DATABASE fusionpbx;";
|
||||
Start-PSQL "CREATE DATABASE freeswitch;";
|
||||
Start-PSQL "CREATE ROLE fusionpbx WITH SUPERUSER LOGIN PASSWORD '$database_password';"
|
||||
Start-PSQL "CREATE ROLE freeswitch WITH SUPERUSER LOGIN PASSWORD '$database_password';"
|
||||
Start-PSQL "GRANT ALL PRIVILEGES ON DATABASE fusionpbx to fusionpbx;"
|
||||
Start-PSQL "GRANT ALL PRIVILEGES ON DATABASE freeswitch to fusionpbx;"
|
||||
Start-PSQL "GRANT ALL PRIVILEGES ON DATABASE freeswitch to freeswitch;"
|
||||
}
|
||||
|
|
@ -0,0 +1,37 @@
|
|||
Function Install-WebPlatform() {
|
||||
#includes
|
||||
. .\resources\get-file.ps1
|
||||
. .\resources\get-cpu.ps1
|
||||
|
||||
#send message
|
||||
if (Get-Installed-App "*Web Platform*") {
|
||||
Write-Host "Web Platform Installer is already installed"
|
||||
return
|
||||
}
|
||||
|
||||
#download and install the web platform installer
|
||||
if (-not (Test-Path "${env:ProgramFiles}\Microsoft\Web Platform Installer\WebPlatformInstaller.exe")) {
|
||||
$url = "http://download.microsoft.com/download/F/4/2/F42AB12D-C935-4E65-9D98-4E56F9ACBC8E/wpilauncher.exe"
|
||||
$filename = Get-File $url
|
||||
Start-Process $filename -Wait
|
||||
}
|
||||
else {
|
||||
Start-Process "C:\Program Files\Microsoft\Web Platform Installer\WebPlatformInstaller.exe" -Wait
|
||||
}
|
||||
|
||||
# list available applications - All, Available
|
||||
# WebpiCmd-x64.exe /list /listoption:Available
|
||||
|
||||
# install PHP 7.1 on IIS
|
||||
if (-not (Test-Path "${env:ProgramFiles}\PHP\v7.1\php.exe")) {
|
||||
$cpu = Get-CPU
|
||||
if ($cpu -eq "x86") {
|
||||
$command = "WebpiCmd.exe /install /Products:PHP71 /AcceptEula"
|
||||
}
|
||||
else {
|
||||
$command = "WebpiCmd-x64.exe /install /Products:PHP71x64 /AcceptEula"
|
||||
}
|
||||
Start-Process $command -Wait
|
||||
}
|
||||
|
||||
}
|
||||
|
|
@ -0,0 +1,7 @@
|
|||
|
||||
Function New-Password([int32]$length) {
|
||||
$password = ""
|
||||
$chars = "abcdefghijkmnopqrstuvwxyzABCEFGHJKLMNPQRSTUVWXYZ23456789".ToCharArray()
|
||||
1..$length | ForEach { $password += $chars | Get-Random }
|
||||
return $password
|
||||
}
|
||||
|
|
@ -0,0 +1,13 @@
|
|||
|
||||
Function Start-ODBC([string]$query) {
|
||||
. .\resources\get-database_password
|
||||
$conn = New-Object System.Data.Odbc.OdbcConnection
|
||||
$conn.ConnectionString = "DSN=fusionpbx;username=fusionpbx;password=$database_password"
|
||||
$conn.open()
|
||||
if ($conn.State -eq "Open") {
|
||||
$cmd = New-object System.Data.Odbc.OdbcCommand($query,$conn)
|
||||
$cmd.ExecuteScalar()
|
||||
$conn.Close()
|
||||
}
|
||||
}
|
||||
#Start-ODBC "select username from v_users"
|
||||
|
|
@ -0,0 +1,7 @@
|
|||
Function Start-PSQL([string]$command) {
|
||||
$location = Get-Location
|
||||
Set-Location "C:\Program Files\PostgreSQL\10\bin"
|
||||
$result = .\psql.exe --username=postgres -c "$command"
|
||||
Set-Location $location
|
||||
return $result
|
||||
}
|
||||
|
|
@ -0,0 +1,17 @@
|
|||
Function Test-ODBC([string]$DSN,[string]$username,[string]$password) {
|
||||
$connection_string = "DSN=$DSN;"
|
||||
if ($username) {
|
||||
$connection_string += "username=$username;"
|
||||
}
|
||||
if ($password) {
|
||||
$connection_string += "password=$password;"
|
||||
}
|
||||
$conn = New-Object System.Data.Odbc.OdbcConnection
|
||||
$conn.ConnectionString = $connection_string
|
||||
$conn.open()
|
||||
$result = ($conn.State -eq "Open")
|
||||
if ($result) {
|
||||
$conn.Close()
|
||||
}
|
||||
return $result
|
||||
}
|
||||
|
|
@ -0,0 +1,4 @@
|
|||
Function Write-Log([string]$message) {
|
||||
Add-Content -Path "install.log" -Value $message
|
||||
Write-Host $message -ForegroundColor Cyan
|
||||
}
|
||||
Loading…
Reference in New Issue