mirror of
https://github.com/fleetdm/fleet
synced 2026-05-01 18:37:37 +00:00
Introduces Telegram as a maintained app for both macOS and Windows platforms. Adds input definitions, install/uninstall scripts, output manifests, icon component, and app icon asset. Updates the apps.json output to include Telegram with appropriate metadata and descriptions. <!-- Add the related story/sub-task/bug number, like Resolves #123, or remove if NA --> **Related issue:** Resolves # # Checklist for submitter If some of the following don't apply, delete the relevant line. - [ ] Changes file added for user-visible changes in `changes/`, `orbit/changes/` or `ee/fleetd-chrome/changes`. See [Changes files](https://github.com/fleetdm/fleet/blob/main/docs/Contributing/guides/committing-changes.md#changes-files) for more information. - [ ] Input data is properly validated, `SELECT *` is avoided, SQL injection is prevented (using placeholders for values in statements) - [ ] If paths of existing endpoints are modified without backwards compatibility, checked the frontend/CLI for any necessary changes ## Testing - [ ] Added/updated automated tests - [ ] Where appropriate, [automated tests simulate multiple hosts and test for host isolation](https://github.com/fleetdm/fleet/blob/main/docs/Contributing/reference/patterns-backend.md#unit-testing) (updates to one hosts's records do not affect another) - [ ] QA'd all new/changed functionality manually For unreleased bug fixes in a release candidate, one of: - [ ] Confirmed that the fix is not expected to adversely impact load test results - [ ] Alerted the release DRI if additional load testing is needed ## Database migrations - [ ] Checked schema for all modified table for columns that will auto-update timestamps during migration. - [ ] Confirmed that updating the timestamps is acceptable, and will not cause unwanted side effects. - [ ] Ensured the correct collation is explicitly set for character columns (`COLLATE utf8mb4_unicode_ci`). ## New Fleet configuration settings - [ ] Setting(s) is/are explicitly excluded from GitOps If you didn't check the box above, follow this checklist for GitOps-enabled settings: - [ ] Verified that the setting is exported via `fleetctl generate-gitops` - [ ] Verified the setting is documented in a separate PR to [the GitOps documentation](https://github.com/fleetdm/fleet/blob/main/docs/Configuration/yaml-files.md#L485) - [ ] Verified that the setting is cleared on the server if it is not supplied in a YAML file (or that it is documented as being optional) - [ ] Verified that any relevant UI is disabled when GitOps mode is enabled ## fleetd/orbit/Fleet Desktop - [ ] Verified compatibility with the latest released version of Fleet (see [Must rule](https://github.com/fleetdm/fleet/blob/main/docs/Contributing/workflows/fleetd-development-and-release-strategy.md)) - [ ] If the change applies to only one platform, confirmed that `runtime.GOOS` is used as needed to isolate changes - [ ] Verified that fleetd runs on macOS, Linux and Windows - [ ] Verified auto-update works from the released version of component to the new version (see [tools/tuf/test](../tools/tuf/test/README.md))
68 lines
2.1 KiB
PowerShell
68 lines
2.1 KiB
PowerShell
# Learn more about .exe install scripts:
|
|
# http://fleetdm.com/learn-more-about/exe-install-scripts
|
|
|
|
$exeFilePath = "${env:INSTALLER_PATH}"
|
|
|
|
try {
|
|
# Verify installer file exists
|
|
if (-not (Test-Path $exeFilePath)) {
|
|
Write-Host "Error: Installer file not found at: $exeFilePath"
|
|
Exit 1
|
|
}
|
|
|
|
Write-Host "Installing Telegram Desktop from: $exeFilePath"
|
|
|
|
# Add arguments to install silently
|
|
# Telegram uses an Inno Setup-based installer
|
|
# Try /VERYSILENT first (more reliable for Inno Setup), fall back to /S if needed
|
|
$processOptions = @{
|
|
FilePath = "$exeFilePath"
|
|
ArgumentList = "/VERYSILENT /SUPPRESSMSGBOXES /NORESTART"
|
|
PassThru = $true
|
|
Wait = $true
|
|
NoNewWindow = $true
|
|
}
|
|
|
|
# Start process and track exit code
|
|
Write-Host "Starting installation with arguments: $($processOptions.ArgumentList)"
|
|
$process = Start-Process @processOptions
|
|
|
|
if ($null -eq $process) {
|
|
Write-Host "Error: Failed to start installer process"
|
|
Exit 1
|
|
}
|
|
|
|
$exitCode = $process.ExitCode
|
|
|
|
# Prints the exit code
|
|
Write-Host "Install exit code: $exitCode"
|
|
|
|
if ($exitCode -ne 0) {
|
|
Write-Host "Warning: Installer exited with non-zero code: $exitCode"
|
|
# Try with /S as fallback for user-scope installs
|
|
Write-Host "Attempting fallback with /S switch..."
|
|
$fallbackOptions = @{
|
|
FilePath = "$exeFilePath"
|
|
ArgumentList = "/S"
|
|
PassThru = $true
|
|
Wait = $true
|
|
NoNewWindow = $true
|
|
}
|
|
$fallbackProcess = Start-Process @fallbackOptions
|
|
if ($null -ne $fallbackProcess) {
|
|
$fallbackExitCode = $fallbackProcess.ExitCode
|
|
Write-Host "Fallback install exit code: $fallbackExitCode"
|
|
Exit $fallbackExitCode
|
|
}
|
|
}
|
|
|
|
Exit $exitCode
|
|
|
|
} catch {
|
|
Write-Host "Error: $_"
|
|
Write-Host "Error details: $($_.Exception.Message)"
|
|
if ($_.Exception.InnerException) {
|
|
Write-Host "Inner exception: $($_.Exception.InnerException.Message)"
|
|
}
|
|
Exit 1
|
|
}
|