mirror of
https://github.com/shivammathur/setup-php.git
synced 2024-11-22 20:01:06 +07:00
Add ini_file input to set base php.ini
This commit is contained in:
parent
147905fd60
commit
a0a791cada
@ -398,6 +398,12 @@ Disable coverage for these reasons:
|
|||||||
- Shared extensions prefixed with `:` are disabled.
|
- Shared extensions prefixed with `:` are disabled.
|
||||||
- See [PHP extension support](#heavy_plus_sign-php-extension-support) for more info.
|
- See [PHP extension support](#heavy_plus_sign-php-extension-support) for more info.
|
||||||
|
|
||||||
|
#### `ini-file` (optional)
|
||||||
|
|
||||||
|
- Specify the base `php.ini` file.
|
||||||
|
- Accepts `production`, `development` or `none`.
|
||||||
|
- By default, production `php.ini` file is used.
|
||||||
|
|
||||||
#### `ini-values` (optional)
|
#### `ini-values` (optional)
|
||||||
|
|
||||||
- Specify the values you want to add to `php.ini`.
|
- Specify the values you want to add to `php.ini`.
|
||||||
|
@ -22,6 +22,9 @@ jest.mock('../src/install', () => ({
|
|||||||
const version: string = await utils.parseVersion(
|
const version: string = await utils.parseVersion(
|
||||||
await utils.getInput('php-version', true)
|
await utils.getInput('php-version', true)
|
||||||
);
|
);
|
||||||
|
const ini_file: string = await utils.parseIniFile(
|
||||||
|
await utils.getInput('ini-file', false)
|
||||||
|
);
|
||||||
const tool = await utils.scriptTool(os_version);
|
const tool = await utils.scriptTool(os_version);
|
||||||
const filename = os_version + (await utils.scriptExtension(os_version));
|
const filename = os_version + (await utils.scriptExtension(os_version));
|
||||||
return [
|
return [
|
||||||
@ -29,6 +32,7 @@ jest.mock('../src/install', () => ({
|
|||||||
tool,
|
tool,
|
||||||
filename,
|
filename,
|
||||||
version,
|
version,
|
||||||
|
ini_file,
|
||||||
__dirname
|
__dirname
|
||||||
].join(' ');
|
].join(' ');
|
||||||
})
|
})
|
||||||
@ -48,6 +52,7 @@ function setEnv(
|
|||||||
version: string | number,
|
version: string | number,
|
||||||
os: string,
|
os: string,
|
||||||
extension_csv: string,
|
extension_csv: string,
|
||||||
|
ini_file: string,
|
||||||
ini_values_csv: string,
|
ini_values_csv: string,
|
||||||
coverage_driver: string,
|
coverage_driver: string,
|
||||||
tools: string
|
tools: string
|
||||||
@ -55,6 +60,7 @@ function setEnv(
|
|||||||
process.env['php-version'] = version.toString();
|
process.env['php-version'] = version.toString();
|
||||||
process.env['RUNNER_OS'] = os;
|
process.env['RUNNER_OS'] = os;
|
||||||
process.env['extensions'] = extension_csv;
|
process.env['extensions'] = extension_csv;
|
||||||
|
process.env['ini-file'] = ini_file;
|
||||||
process.env['ini-values'] = ini_values_csv;
|
process.env['ini-values'] = ini_values_csv;
|
||||||
process.env['coverage'] = coverage_driver;
|
process.env['coverage'] = coverage_driver;
|
||||||
process.env['tools'] = tools;
|
process.env['tools'] = tools;
|
||||||
@ -62,25 +68,26 @@ function setEnv(
|
|||||||
|
|
||||||
describe('Install', () => {
|
describe('Install', () => {
|
||||||
it.each`
|
it.each`
|
||||||
version | os | extension_csv | ini_values_csv | coverage_driver | tools | output
|
version | os | extension_csv | ini_file | ini_values_csv | coverage_driver | tools | output
|
||||||
${'7.3'} | ${'darwin'} | ${''} | ${''} | ${''} | ${''} | ${'initial script bash darwin.sh 7.3 ' + __dirname}
|
${'7.3'} | ${'darwin'} | ${''} | ${'production'} | ${''} | ${''} | ${''} | ${'initial script bash darwin.sh 7.3 production ' + __dirname}
|
||||||
${'7.3'} | ${'darwin'} | ${'a, b'} | ${'a=b'} | ${'x'} | ${''} | ${'initial script install extensions set coverage driver edit php.ini bash darwin.sh 7.3 ' + __dirname}
|
${'7.3'} | ${'darwin'} | ${'a, b'} | ${'development'} | ${'a=b'} | ${'x'} | ${''} | ${'initial script install extensions set coverage driver edit php.ini bash darwin.sh 7.3 development ' + __dirname}
|
||||||
${'7.4.1'} | ${'darwin'} | ${''} | ${''} | ${''} | ${''} | ${'initial script bash darwin.sh 7.4 ' + __dirname}
|
${'7.4.1'} | ${'darwin'} | ${''} | ${'none'} | ${''} | ${''} | ${''} | ${'initial script bash darwin.sh 7.4 none ' + __dirname}
|
||||||
${'8'} | ${'darwin'} | ${''} | ${''} | ${''} | ${''} | ${'initial script bash darwin.sh 8.0 ' + __dirname}
|
${'8'} | ${'darwin'} | ${''} | ${''} | ${''} | ${''} | ${''} | ${'initial script bash darwin.sh 8.0 production ' + __dirname}
|
||||||
${'8.0'} | ${'darwin'} | ${''} | ${''} | ${''} | ${''} | ${'initial script bash darwin.sh 8.0 ' + __dirname}
|
${'8.0'} | ${'darwin'} | ${''} | ${'development'} | ${''} | ${''} | ${''} | ${'initial script bash darwin.sh 8.0 development ' + __dirname}
|
||||||
${'8.1'} | ${'darwin'} | ${''} | ${''} | ${''} | ${''} | ${'initial script bash darwin.sh 8.1 ' + __dirname}
|
${'8.1'} | ${'darwin'} | ${''} | ${'none'} | ${''} | ${''} | ${''} | ${'initial script bash darwin.sh 8.1 none ' + __dirname}
|
||||||
${'7.3'} | ${'linux'} | ${''} | ${''} | ${''} | ${''} | ${'initial script bash linux.sh 7.3 ' + __dirname}
|
${'7.3'} | ${'linux'} | ${''} | ${'invalid'} | ${''} | ${''} | ${''} | ${'initial script bash linux.sh 7.3 production ' + __dirname}
|
||||||
${'7.3'} | ${'linux'} | ${'a, b'} | ${'a=b'} | ${'x'} | ${'phpunit'} | ${'initial script install extensions add_tool set coverage driver edit php.ini bash linux.sh 7.3 ' + __dirname}
|
${'7.3'} | ${'linux'} | ${'a, b'} | ${'development'} | ${'a=b'} | ${'x'} | ${'phpunit'} | ${'initial script install extensions add_tool set coverage driver edit php.ini bash linux.sh 7.3 development ' + __dirname}
|
||||||
${'latest'} | ${'linux'} | ${''} | ${''} | ${''} | ${''} | ${'initial script bash linux.sh 8.1 ' + __dirname}
|
${'latest'} | ${'linux'} | ${''} | ${'none'} | ${''} | ${''} | ${''} | ${'initial script bash linux.sh 8.1 none ' + __dirname}
|
||||||
${'7.0'} | ${'win32'} | ${''} | ${''} | ${''} | ${''} | ${'initial script pwsh win32.ps1 7.0 ' + __dirname}
|
${'7.0'} | ${'win32'} | ${''} | ${'production'} | ${''} | ${''} | ${''} | ${'initial script pwsh win32.ps1 7.0 production ' + __dirname}
|
||||||
${'7.3'} | ${'win32'} | ${''} | ${''} | ${''} | ${''} | ${'initial script pwsh win32.ps1 7.3 ' + __dirname}
|
${'7.3'} | ${'win32'} | ${''} | ${'development'} | ${''} | ${''} | ${''} | ${'initial script pwsh win32.ps1 7.3 development ' + __dirname}
|
||||||
${'7.3'} | ${'win32'} | ${'a, b'} | ${'a=b'} | ${'x'} | ${''} | ${'initial script install extensions set coverage driver edit php.ini pwsh win32.ps1 7.3 ' + __dirname}
|
${'7.3'} | ${'win32'} | ${'a, b'} | ${'none'} | ${'a=b'} | ${'x'} | ${''} | ${'initial script install extensions set coverage driver edit php.ini pwsh win32.ps1 7.3 none ' + __dirname}
|
||||||
`(
|
`(
|
||||||
'Test install on $os for $version with extensions=$extension_csv, ini_values=$ini_values_csv, coverage_driver=$coverage_driver, tools=$tools',
|
'Test install on $os for $version with extensions=$extension_csv, ini_values=$ini_values_csv, coverage_driver=$coverage_driver, tools=$tools',
|
||||||
async ({
|
async ({
|
||||||
version,
|
version,
|
||||||
os,
|
os,
|
||||||
extension_csv,
|
extension_csv,
|
||||||
|
ini_file,
|
||||||
ini_values_csv,
|
ini_values_csv,
|
||||||
coverage_driver,
|
coverage_driver,
|
||||||
tools,
|
tools,
|
||||||
@ -90,6 +97,7 @@ describe('Install', () => {
|
|||||||
version,
|
version,
|
||||||
os,
|
os,
|
||||||
extension_csv,
|
extension_csv,
|
||||||
|
ini_file,
|
||||||
ini_values_csv,
|
ini_values_csv,
|
||||||
coverage_driver,
|
coverage_driver,
|
||||||
tools
|
tools
|
||||||
|
@ -71,6 +71,15 @@ describe('Utils tests', () => {
|
|||||||
expect(await utils.parseVersion('4.x')).toBe(undefined);
|
expect(await utils.parseVersion('4.x')).toBe(undefined);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('checking parseIniFile', async () => {
|
||||||
|
expect(await utils.parseIniFile('production')).toBe('production');
|
||||||
|
expect(await utils.parseIniFile('development')).toBe('development');
|
||||||
|
expect(await utils.parseIniFile('none')).toBe('none');
|
||||||
|
expect(await utils.parseIniFile('php.ini-production')).toBe('production');
|
||||||
|
expect(await utils.parseIniFile('php.ini-development')).toBe('development');
|
||||||
|
expect(await utils.parseIniFile('invalid')).toBe('production');
|
||||||
|
})
|
||||||
|
|
||||||
it('checking asyncForEach', async () => {
|
it('checking asyncForEach', async () => {
|
||||||
const array: Array<string> = ['a', 'b', 'c'];
|
const array: Array<string> = ['a', 'b', 'c'];
|
||||||
let concat = '';
|
let concat = '';
|
||||||
|
@ -12,6 +12,10 @@ inputs:
|
|||||||
extensions:
|
extensions:
|
||||||
description: 'Setup PHP extensions.'
|
description: 'Setup PHP extensions.'
|
||||||
required: false
|
required: false
|
||||||
|
ini-file:
|
||||||
|
description: 'Set base ini file.'
|
||||||
|
default: 'production'
|
||||||
|
required: false
|
||||||
ini-values:
|
ini-values:
|
||||||
description: 'Add values to php.ini.'
|
description: 'Add values to php.ini.'
|
||||||
required: false
|
required: false
|
||||||
|
16
dist/index.js
vendored
16
dist/index.js
vendored
@ -472,12 +472,13 @@ async function run() {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const version = await utils.parseVersion(await utils.getInput('php-version', true));
|
const version = await utils.parseVersion(await utils.getInput('php-version', true));
|
||||||
|
const ini_file = await utils.parseIniFile(await utils.getInput('ini-file', false));
|
||||||
if (version) {
|
if (version) {
|
||||||
const os_version = process.platform;
|
const os_version = process.platform;
|
||||||
const tool = await utils.scriptTool(os_version);
|
const tool = await utils.scriptTool(os_version);
|
||||||
const script = os_version + (await utils.scriptExtension(os_version));
|
const script = os_version + (await utils.scriptExtension(os_version));
|
||||||
const location = await getScript(script, version, os_version);
|
const location = await getScript(script, version, os_version);
|
||||||
await (0, exec_1.exec)(await utils.joins(tool, location, version, __dirname));
|
await (0, exec_1.exec)(await utils.joins(tool, location, version, ini_file, __dirname));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
core.setFailed('Unable to get the PHP version');
|
core.setFailed('Unable to get the PHP version');
|
||||||
@ -911,7 +912,7 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|||||||
return result;
|
return result;
|
||||||
};
|
};
|
||||||
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
||||||
exports.parseExtensionSource = exports.customPackage = exports.scriptTool = exports.scriptExtension = exports.joins = exports.getCommand = exports.getUnsupportedLog = exports.suppressOutput = exports.getExtensionPrefix = exports.CSVArray = exports.extensionArray = exports.writeScript = exports.readFile = exports.addLog = exports.stepLog = exports.log = exports.color = exports.asyncForEach = exports.parseVersion = exports.getManifestURL = exports.fetch = exports.getInput = exports.readEnv = void 0;
|
exports.parseExtensionSource = exports.customPackage = exports.scriptTool = exports.scriptExtension = exports.joins = exports.getCommand = exports.getUnsupportedLog = exports.suppressOutput = exports.getExtensionPrefix = exports.CSVArray = exports.extensionArray = exports.writeScript = exports.readFile = exports.addLog = exports.stepLog = exports.log = exports.color = exports.asyncForEach = exports.parseIniFile = exports.parseVersion = exports.getManifestURL = exports.fetch = exports.getInput = exports.readEnv = void 0;
|
||||||
const fs = __importStar(__nccwpck_require__(147));
|
const fs = __importStar(__nccwpck_require__(147));
|
||||||
const https = __importStar(__nccwpck_require__(687));
|
const https = __importStar(__nccwpck_require__(687));
|
||||||
const path = __importStar(__nccwpck_require__(17));
|
const path = __importStar(__nccwpck_require__(17));
|
||||||
@ -992,6 +993,17 @@ async function parseVersion(version) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
exports.parseVersion = parseVersion;
|
exports.parseVersion = parseVersion;
|
||||||
|
async function parseIniFile(ini_file) {
|
||||||
|
switch (true) {
|
||||||
|
case /^(production|development|none)$/.test(ini_file):
|
||||||
|
return ini_file;
|
||||||
|
case /php\.ini-(production|development)$/.test(ini_file):
|
||||||
|
return ini_file.split('-')[1];
|
||||||
|
default:
|
||||||
|
return 'production';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
exports.parseIniFile = parseIniFile;
|
||||||
async function asyncForEach(array, callback) {
|
async function asyncForEach(array, callback) {
|
||||||
for (let index = 0; index < array.length; index++) {
|
for (let index = 0; index < array.length; index++) {
|
||||||
await callback(array[index], index, array);
|
await callback(array[index], index, array);
|
||||||
|
@ -57,12 +57,17 @@ export async function run(): Promise<void> {
|
|||||||
const version: string = await utils.parseVersion(
|
const version: string = await utils.parseVersion(
|
||||||
await utils.getInput('php-version', true)
|
await utils.getInput('php-version', true)
|
||||||
);
|
);
|
||||||
|
const ini_file: string = await utils.parseIniFile(
|
||||||
|
await utils.getInput('ini-file', false)
|
||||||
|
);
|
||||||
if (version) {
|
if (version) {
|
||||||
const os_version: string = process.platform;
|
const os_version: string = process.platform;
|
||||||
const tool = await utils.scriptTool(os_version);
|
const tool = await utils.scriptTool(os_version);
|
||||||
const script = os_version + (await utils.scriptExtension(os_version));
|
const script = os_version + (await utils.scriptExtension(os_version));
|
||||||
const location = await getScript(script, version, os_version);
|
const location = await getScript(script, version, os_version);
|
||||||
await exec(await utils.joins(tool, location, version, __dirname));
|
await exec(
|
||||||
|
await utils.joins(tool, location, version, ini_file, __dirname)
|
||||||
|
);
|
||||||
} else {
|
} else {
|
||||||
core.setFailed('Unable to get the PHP version');
|
core.setFailed('Unable to get the PHP version');
|
||||||
}
|
}
|
||||||
|
@ -195,6 +195,18 @@ php_extra_version() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Function to set php.ini
|
||||||
|
add_php_config() {
|
||||||
|
if ! [ -e "$ini_dir"/php.ini-development ]; then
|
||||||
|
sudo cp "$ini_dir"/php.ini "$ini_dir"/php.ini-development
|
||||||
|
fi
|
||||||
|
if [[ "$ini" = "production" || "$ini" = "development" ]]; then
|
||||||
|
sudo cp "$ini_dir"/php.ini-"$ini" "$ini_dir"/php.ini
|
||||||
|
elif [ "$ini" = "none" ]; then
|
||||||
|
echo '' | sudo tee "${ini_file[@]}" >/dev/null 2>&1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
# Function to Setup PHP.
|
# Function to Setup PHP.
|
||||||
setup_php() {
|
setup_php() {
|
||||||
step_log "Setup PHP"
|
step_log "Setup PHP"
|
||||||
@ -234,8 +246,9 @@ setup_php() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
# Variables
|
# Variables
|
||||||
version=$1
|
version=${1:-'8.1'}
|
||||||
dist=$2
|
ini=${2:-'production'}
|
||||||
|
dist=$3
|
||||||
php_formula=shivammathur/php/php@"$version"
|
php_formula=shivammathur/php/php@"$version"
|
||||||
brew_path="$(command -v brew)"
|
brew_path="$(command -v brew)"
|
||||||
brew_path_dir="$(dirname "$brew_path")"
|
brew_path_dir="$(dirname "$brew_path")"
|
||||||
|
@ -178,6 +178,27 @@ php_extra_version() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Function to set php.ini
|
||||||
|
add_php_config() {
|
||||||
|
php_lib_dir=/usr/lib/php/"$version"
|
||||||
|
current_ini="$php_lib_dir"/php.ini-current
|
||||||
|
current=$(cat "$current_ini" 2>/dev/null)
|
||||||
|
if [ "$current" = "$ini" ]; then
|
||||||
|
return;
|
||||||
|
fi
|
||||||
|
if [[ "$ini" = "production" && "x$current" != "xproduction" ]]; then
|
||||||
|
echo "${ini_file[@]}" | xargs -n 1 -P 6 sudo cp "$php_lib_dir"/php.ini-production
|
||||||
|
if [ -e "$php_lib_dir"/php.ini-production.cli ]; then
|
||||||
|
sudo cp "$php_lib_dir"/php.ini-production.cli "$ini_dir"/php.ini
|
||||||
|
fi
|
||||||
|
elif [ "$ini" = "development" ]; then
|
||||||
|
echo "${ini_file[@]}" | xargs -n 1 -P 6 sudo cp "$php_lib_dir"/php.ini-development
|
||||||
|
elif [ "$ini" = "none" ]; then
|
||||||
|
echo '' | sudo tee "${ini_file[@]}" >/dev/null 2>&1
|
||||||
|
fi
|
||||||
|
echo "$ini" | sudo tee "$current_ini" >/dev/null 2>&1
|
||||||
|
}
|
||||||
|
|
||||||
# Function to Setup PHP
|
# Function to Setup PHP
|
||||||
setup_php() {
|
setup_php() {
|
||||||
step_log "Setup PHP"
|
step_log "Setup PHP"
|
||||||
@ -226,8 +247,9 @@ setup_php() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
# Variables
|
# Variables
|
||||||
version=$1
|
version=${1:-'8.1'}
|
||||||
dist=$2
|
ini=${2:-'production'}
|
||||||
|
dist=$3
|
||||||
debconf_fix="DEBIAN_FRONTEND=noninteractive"
|
debconf_fix="DEBIAN_FRONTEND=noninteractive"
|
||||||
apt_install="sudo $debconf_fix apt-fast install -y --no-install-recommends"
|
apt_install="sudo $debconf_fix apt-fast install -y --no-install-recommends"
|
||||||
scripts="${dist}"/../src/scripts
|
scripts="${dist}"/../src/scripts
|
||||||
|
@ -135,6 +135,7 @@ self_hosted_setup() {
|
|||||||
|
|
||||||
# Function to configure PHP
|
# Function to configure PHP
|
||||||
configure_php() {
|
configure_php() {
|
||||||
|
add_php_config
|
||||||
ini_config_dir="${dist:?}"/../src/configs/ini
|
ini_config_dir="${dist:?}"/../src/configs/ini
|
||||||
ini_files=("$ini_config_dir"/php.ini)
|
ini_files=("$ini_config_dir"/php.ini)
|
||||||
[[ "$version" =~ $jit_versions ]] && ini_files+=("$ini_config_dir"/jit.ini)
|
[[ "$version" =~ $jit_versions ]] && ini_files+=("$ini_config_dir"/jit.ini)
|
||||||
|
@ -8,6 +8,11 @@ param (
|
|||||||
[ValidateNotNull()]
|
[ValidateNotNull()]
|
||||||
[ValidateLength(1, [int]::MaxValue)]
|
[ValidateLength(1, [int]::MaxValue)]
|
||||||
[string]
|
[string]
|
||||||
|
$ini = 'production',
|
||||||
|
[Parameter(Position = 2, Mandatory = $true)]
|
||||||
|
[ValidateNotNull()]
|
||||||
|
[ValidateLength(1, [int]::MaxValue)]
|
||||||
|
[string]
|
||||||
$dist
|
$dist
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -166,10 +171,18 @@ Function Add-PhpCAInfo {
|
|||||||
|
|
||||||
# Function to set PHP config.
|
# Function to set PHP config.
|
||||||
Function Add-PhpConfig {
|
Function Add-PhpConfig {
|
||||||
|
$current = Get-Content -Path $php_dir\php.ini-current -ErrorAction SilentlyContinue
|
||||||
|
if($ini -eq 'development' -or ($ini -eq 'production' -and $current -and $current -ne 'production')) {
|
||||||
|
Copy-Item -Path $php_dir\php.ini-$ini -Destination $php_dir\php.ini -Force
|
||||||
|
} elseif ($ini -eq 'none') {
|
||||||
|
Set-Content -Path $php_dir\php.ini -Value ''
|
||||||
|
}
|
||||||
|
Set-Content -Path $php_dir\php.ini-current -Value $ini
|
||||||
$ini_config_dir = "$dist\..\src\configs\ini"
|
$ini_config_dir = "$dist\..\src\configs\ini"
|
||||||
$ini_files = @("$ini_config_dir\php.ini")
|
$ini_files = @("$ini_config_dir\php.ini")
|
||||||
$version -match $jit_versions -and ($ini_files += ("$ini_config_dir\jit.ini")) > $null 2>&1
|
$version -match $jit_versions -and ($ini_files += ("$ini_config_dir\jit.ini")) > $null 2>&1
|
||||||
$version -match $xdebug3_versions -and ($ini_files += ("$ini_config_dir\xdebug.ini")) > $null 2>&1
|
$version -match $xdebug3_versions -and ($ini_files += ("$ini_config_dir\xdebug.ini")) > $null 2>&1
|
||||||
|
Add-Content -Path $ini_config_dir\php.ini -Value extension_dir=$ext_dir
|
||||||
Get-Content -Path $ini_files | Add-Content -Path $php_dir\php.ini
|
Get-Content -Path $ini_files | Add-Content -Path $php_dir\php.ini
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -257,17 +270,18 @@ if ($null -eq $installed -or -not("$($installed.Version).".StartsWith(($version
|
|||||||
$extra_version = " ($( Get-Content $php_dir\COMMIT ))"
|
$extra_version = " ($( Get-Content $php_dir\COMMIT ))"
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Install-Php -Version $version -Architecture $arch -ThreadSafe $ts -InstallVC -Path $php_dir -TimeZone UTC -InitialPhpIni Production -Force > $null 2>&1
|
Install-Php -Version $version -Architecture $arch -ThreadSafe $ts -InstallVC -Path $php_dir -TimeZone UTC -InitialPhpIni production -Force > $null 2>&1
|
||||||
}
|
}
|
||||||
|
Add-PhpConfig
|
||||||
} catch { }
|
} catch { }
|
||||||
} else {
|
} else {
|
||||||
Set-PhpIniKey -Key 'extension_dir' -Value $ext_dir -Path $php_dir
|
|
||||||
if($env:update -eq 'true') {
|
if($env:update -eq 'true') {
|
||||||
Update-Php $php_dir >$null 2>&1
|
Update-Php $php_dir >$null 2>&1
|
||||||
$status = "Updated to"
|
$status = "Updated to"
|
||||||
} else {
|
} else {
|
||||||
$status = "Found"
|
$status = "Found"
|
||||||
}
|
}
|
||||||
|
Add-PhpConfig
|
||||||
}
|
}
|
||||||
|
|
||||||
$installed = Get-Php -Path $php_dir
|
$installed = Get-Php -Path $php_dir
|
||||||
@ -282,7 +296,6 @@ if($version -lt "5.5") {
|
|||||||
}
|
}
|
||||||
Enable-PhpExtension -Extension $enable_extensions -Path $php_dir
|
Enable-PhpExtension -Extension $enable_extensions -Path $php_dir
|
||||||
Add-PhpCAInfo
|
Add-PhpCAInfo
|
||||||
Add-PhpConfig
|
|
||||||
Copy-Item -Path $dist\..\src\configs\pm\*.json -Destination $env:RUNNER_TOOL_CACHE
|
Copy-Item -Path $dist\..\src\configs\pm\*.json -Destination $env:RUNNER_TOOL_CACHE
|
||||||
Write-Output "::set-output name=php-version::$($installed.FullVersion)"
|
Write-Output "::set-output name=php-version::$($installed.FullVersion)"
|
||||||
Add-Log $tick "PHP" "$status PHP $($installed.FullVersion)$extra_version"
|
Add-Log $tick "PHP" "$status PHP $($installed.FullVersion)$extra_version"
|
||||||
|
16
src/utils.ts
16
src/utils.ts
@ -114,6 +114,22 @@ export async function parseVersion(version: string): Promise<string> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to parse ini file.
|
||||||
|
*
|
||||||
|
* @param ini_file
|
||||||
|
*/
|
||||||
|
export async function parseIniFile(ini_file: string): Promise<string> {
|
||||||
|
switch (true) {
|
||||||
|
case /^(production|development|none)$/.test(ini_file):
|
||||||
|
return ini_file;
|
||||||
|
case /php\.ini-(production|development)$/.test(ini_file):
|
||||||
|
return ini_file.split('-')[1];
|
||||||
|
default:
|
||||||
|
return 'production';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Async foreach loop
|
* Async foreach loop
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user