Add Windows install with IIS (#114)

* Windows install script

Created

* Add Windows option

* Update

* Enable ODBC

* IIS Identity and mod_lua

* Update

* Update

* Merge remote-tracking branch 'upstream/master'

# Please enter a commit message to explain why this merge is necessary,
# especially if it merges an updated upstream into a topic branch.
#
# Lines starting with '#' will be ignored, and an empty message aborts
# the commit.

* Update

* WIndows install

Works with IIS.
Need to create nginx install
This commit is contained in:
sergey-mz 2017-08-22 15:20:50 -04:00 committed by FusionPBX
parent 1a23b6822f
commit 09e52c60e5
5 changed files with 507 additions and 0 deletions

View File

@ -39,3 +39,15 @@ CentOS operating system is a requirement for some companies. Don't expect video
wget -O - https://raw.githubusercontent.com/fusionpbx/fusionpbx-install.sh/master/centos/pre-install.sh | sh
cd /usr/src/fusionpbx-install.sh/centos && ./install.sh
```
### Windows
Don't expect everything to work. Testing is required.
mod_lua is missing from builds after 1.6.14. Script will download it from github.
Open PowerShell as Administrator and run commands
```sh
Set-Location "$env:PUBLIC\Downloads"
Invoke-WebRequest https://raw.githubusercontent.com/fusionpbx/fusionpbx-install.sh/master/windows/install.ps1 -OutFile install.ps1
#run the script
.\install.ps1
```

490
windows/install.ps1 Normal file
View File

@ -0,0 +1,490 @@
# 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.*
#$switch_source = $false # true or false
#$switch_package = $true # true or false
# Database Settings
$database_password = "random" # random or a custom value
#$database_backup = $false # true or false
# Web server
$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) {
([char[]]([char]'A'..[char]'Z') + [char[]]([char]'a'..[char]'z') + 0..9 | Sort-Object {Get-Random})[0..$length] -join ''
}
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() {
if (Get-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) ) {
$cpu = Get-CPU
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() {
$url = "https://ftp.postgresql.org/pub/odbc/versions/msi/"
$link = Get-Link $url -pattern "*" + (Get-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 (Get-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\9.6\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=fusionpbxadmin;password=despatch4u"
$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-9.6.3-3-windows.exe"
}
else {
$url = "https://get.enterprisedb.com/postgresql/postgresql-9.6.3-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.6.4.windows.1/Git-2.6.4-32-bit.exe"
}
else {
$url = "https://github.com/git-for-windows/git/releases/download/v2.6.4.windows.1/Git-2.6.4-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 anonimous 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
}
Install-PostgreSQL
Install-PostgresODBC
Test-ODBC fusionpbx postgres $database_password
Install-FreeSWITCH
Install-Git
Install-FusionPBX
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

5
windows/pre-install.ps1 Normal file
View File

@ -0,0 +1,5 @@
#get the install script
Set-Location "$env:PUBLIC\Downloads"
Invoke-WebRequest https://raw.github.com/fusionpbx/fusionpbx-install.sh/master/windows/install.ps1 -OutFile install.ps1
#run the script
.\install.ps1

Binary file not shown.

Binary file not shown.