Skip to content

Commit

Permalink
Add download option to jenkins module
Browse files Browse the repository at this point in the history
This allows forcing HTTP 1.1 per official suggestion[1], since HTTP 2
regularly fails when downloading.

cURL on RHEL7 doesn't support HTTP 2 and thus does not have a --http1.1
switch.

[1]: jenkins-infra/helpdesk#3078 (comment)
  • Loading branch information
CyberLine authored and evgeni committed Apr 24, 2024
1 parent 3eed223 commit cb975d4
Showing 1 changed file with 25 additions and 20 deletions.
45 changes: 25 additions & 20 deletions manifests/plugin.pp
Original file line number Diff line number Diff line change
Expand Up @@ -45,17 +45,21 @@
# Pin the plugin to a specific version. This prevents the updater from
# updating it.
#
# @param download_options
# Add options to Archive's curl
#
define jenkins::plugin (
Optional[String] $version = undef,
Optional[String] $config_filename = undef,
Optional[String] $config_content = undef,
Optional[String] $update_url = undef,
Optional[String] $source = undef,
Enum['hpi', 'jpi'] $extension = 'hpi',
Optional[String] $digest_string = undef,
Boolean $enabled = true,
String $digest_type = 'sha1',
Boolean $pin = false,
Optional[String] $version = undef,
Optional[String] $config_filename = undef,
Optional[String] $config_content = undef,
Optional[String] $update_url = undef,
Optional[String] $source = undef,
Enum['hpi', 'jpi'] $extension = 'hpi',
Optional[String] $digest_string = undef,
Boolean $enabled = true,
String $digest_type = 'sha1',
Boolean $pin = false,
Array[String[1]] $download_options = ($facts['os']['family'] == 'RedHat' and $facts['os']['release']['major'] == '7') ? { true => [], default => ['--http1.1'] },
) {
include jenkins

Expand Down Expand Up @@ -186,16 +190,17 @@
command => "/bin/rm -rf ${jenkins::plugin_dir}/${plugin}",
}
-> archive { $plugin:
source => $download_url,
path => "${jenkins::plugin_dir}/${plugin}",
checksum_verify => $checksum_verify,
checksum => $checksum,
checksum_type => $checksum_type,
proxy_server => $jenkins::proxy::url,
cleanup => false,
extract => false,
require => $plugindir,
notify => $notify,
source => $download_url,
path => "${jenkins::plugin_dir}/${plugin}",
checksum_verify => $checksum_verify,
checksum => $checksum,
checksum_type => $checksum_type,
proxy_server => $jenkins::proxy::url,
cleanup => false,
extract => false,
require => $plugindir,
notify => $notify,
download_options => $download_options,
}
$archive_require = Archive[$plugin]
} else {
Expand Down

0 comments on commit cb975d4

Please sign in to comment.