ood_packaging 0.1.3 → 0.3.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/bin/ood_packaging +3 -7
- data/lib/ood_packaging/build.rb +2 -2
- data/lib/ood_packaging/build_box/docker-image/Dockerfile.erb +6 -3
- data/lib/ood_packaging/build_box/docker-image/RPM-GPG-KEY-ondemand-SHA512 +64 -0
- data/lib/ood_packaging/build_box/docker-image/install.sh.erb +5 -1
- data/lib/ood_packaging/build_box.rb +5 -2
- data/lib/ood_packaging/package.rb +47 -23
- data/lib/ood_packaging/tasks.rb +3 -2
- data/lib/ood_packaging/utils.rb +1 -1
- data/lib/ood_packaging/version.rb +6 -6
- metadata +4 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: ff0ba6ed065c5bbebe100c74e3a2c317df604b074467e5c4f60004959131e268
|
4
|
+
data.tar.gz: e4dc858b35504018e10de2c526c93148c1face3396f5ccb77ef73cdb6506c5f3
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: eb65025fd83bcb216075b111cce2f14f8c7fc5b26b56eb8c0e40233cfad76a18c30998921d07b9fefb0fdc2d3ca0c15d11c0d56f9287a68010656dbe982155e7
|
7
|
+
data.tar.gz: 7da737ae95148ef3cb61dab6ebf96834983a793cb5a07814cf3aa9081b99eda0eca014a22e3a49856ddcb7863523a80e559ba062da059ac29199072123400b44
|
data/bin/ood_packaging
CHANGED
@@ -2,13 +2,9 @@
|
|
2
2
|
# frozen_string_literal: true
|
3
3
|
|
4
4
|
require 'optparse'
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
rescue LoadError
|
9
|
-
$LOAD_PATH.unshift(File.expand_path(File.join(__dir__, '../lib')))
|
10
|
-
require 'ood_packaging'
|
11
|
-
end
|
5
|
+
libdir = File.expand_path(File.join(__dir__, '../lib'))
|
6
|
+
$LOAD_PATH.unshift(libdir) if Dir.exist?(libdir)
|
7
|
+
require 'ood_packaging'
|
12
8
|
|
13
9
|
options = {}
|
14
10
|
OptionParser.new do |opts|
|
data/lib/ood_packaging/build.rb
CHANGED
@@ -221,7 +221,7 @@ class OodPackaging::Build
|
|
221
221
|
puts "\tBootstrap debian build files".blue
|
222
222
|
Dir.chdir(deb_work_dir) do
|
223
223
|
sh "dh_make -s -y --createorig -f ../#{deb_name}.tar.gz#{cmd_suffix} || true"
|
224
|
-
sh "dch -b -v #{deb_version} 'Release #{deb_version}'#{cmd_suffix}"
|
224
|
+
sh "dch -b -v #{deb_version} --controlmaint 'Release #{deb_version}'#{cmd_suffix}"
|
225
225
|
end
|
226
226
|
end
|
227
227
|
|
@@ -249,7 +249,7 @@ class OodPackaging::Build
|
|
249
249
|
sh "sudo apt update -y#{cmd_suffix}"
|
250
250
|
cmd = [
|
251
251
|
'mk-build-deps --install --remove --root-cmd sudo',
|
252
|
-
"--tool='apt-get -o Debug::pkgProblemResolver=yes --no-install-recommends --yes'"
|
252
|
+
"--tool='DEBIAN_FRONTEND=noninteractive apt-get -o Debug::pkgProblemResolver=yes --no-install-recommends --yes'"
|
253
253
|
]
|
254
254
|
Dir.chdir(deb_work_dir) do
|
255
255
|
sh "#{cmd.join(' ')}#{cmd_suffix}"
|
@@ -17,9 +17,13 @@ RUN rm -f /etc/yum.repos.d/CentOS-SCLo-scl-rh.repo /etc/yum.repos.d/CentOS-SCLo-
|
|
17
17
|
<% elsif dist =~ /^el/ -%>
|
18
18
|
RUN dnf update -y && dnf clean all && rm -rf /var/cache/dnf/*
|
19
19
|
RUN dnf install -y dnf-utils epel-release langpacks-en glibc-all-langpacks && dnf clean all && rm -rf /var/cache/dnf/*
|
20
|
+
<% if dist == 'el8' -%>
|
20
21
|
RUN dnf config-manager --set-enabled powertools && dnf clean all && rm -rf /var/cache/dnf/*
|
21
22
|
RUN dnf module enable -y ruby:<%= ruby_version %> nodejs:<%= nodejs_version %> && dnf clean all && rm -rf /var/cache/dnf/*
|
22
|
-
|
23
|
+
<% else -%>
|
24
|
+
RUN dnf config-manager --set-enabled crb && dnf clean all && rm -rf /var/cache/dnf/*
|
25
|
+
<% end -%>
|
26
|
+
RUN dnf install -y systemd ruby nodejs sudo which wget \
|
23
27
|
gcc-c++ gcc make patch \
|
24
28
|
rpm-build rpmdevtools rpm-sign scl-utils-build && \
|
25
29
|
dnf clean all && rm -rf /var/cache/dnf/*
|
@@ -30,8 +34,7 @@ RUN apt update -y && apt install -y locales && locale-gen $LANG && \
|
|
30
34
|
apt clean all -y
|
31
35
|
RUN apt update -y && apt install -y apt-transport-https ca-certificates \
|
32
36
|
init debhelper devscripts dh-make build-essential lintian equivs \
|
33
|
-
sudo rake wget curl ruby && \
|
34
|
-
ln -snf /bin/bundle2.7 /bin/bundle && \
|
37
|
+
sudo rake wget curl ruby bundler && \
|
35
38
|
apt clean all -y
|
36
39
|
RUN echo "deb https://deb.nodesource.com/node_<%= nodejs_version %>.x <%= codename %> main" > /etc/apt/sources.list.d/nodesource.list
|
37
40
|
RUN curl -s https://deb.nodesource.com/gpgkey/nodesource.gpg.key | gpg --dearmor > /etc/apt/trusted.gpg.d/nodesource.gpg
|
@@ -0,0 +1,64 @@
|
|
1
|
+
-----BEGIN PGP PUBLIC KEY BLOCK-----
|
2
|
+
|
3
|
+
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
|
62
|
+
WAS7M0V6x6GPiX+zI1M=
|
63
|
+
=wRIy
|
64
|
+
-----END PGP PUBLIC KEY BLOCK-----
|
@@ -24,7 +24,11 @@ baseurl=https://yum.osc.edu/ondemand/build/<%= ondemand_repo_version %>/web/el\$
|
|
24
24
|
enabled=1
|
25
25
|
gpgcheck=0
|
26
26
|
EOF
|
27
|
+
<% if scl? -%>
|
27
28
|
run rpm --import /build/RPM-GPG-KEY-ondemand
|
29
|
+
<% else -%>
|
30
|
+
run rpm --import /build/RPM-GPG-KEY-ondemand-SHA512
|
31
|
+
<% end -%>
|
28
32
|
<% end -%>
|
29
33
|
|
30
34
|
header "Creating users"
|
@@ -72,7 +76,7 @@ echo "allow-loopback-pinentry" >> <%= ctr_gpg_dir %>/gpg-agent.conf
|
|
72
76
|
<%- end -%>
|
73
77
|
|
74
78
|
header "Install ood_packaging gem"
|
75
|
-
<%- if
|
79
|
+
<%- if scl? -%>
|
76
80
|
run scl enable <%= scl_ruby %> -- gem install --no-doc --bindir <%= ctr_scripts_dir %> --install-dir <%= ctr_gems_dir %> /build/*.gem
|
77
81
|
<%- else -%>
|
78
82
|
run gem install --no-doc --bindir <%= ctr_scripts_dir %> --install-dir <%= ctr_gems_dir %> /build/*.gem
|
@@ -12,11 +12,14 @@ class OodPackaging::BuildBox
|
|
12
12
|
BASE_IMAGES = {
|
13
13
|
'el7' => 'centos:7',
|
14
14
|
'el8' => 'rockylinux/rockylinux:8',
|
15
|
-
'
|
15
|
+
'el9' => 'almalinux:9',
|
16
|
+
'ubuntu-20.04' => 'ubuntu:20.04',
|
17
|
+
'ubuntu-22.04' => 'ubuntu:22.04'
|
16
18
|
}.freeze
|
17
19
|
|
18
20
|
CODENAMES = {
|
19
|
-
'ubuntu-20.04' => 'focal'
|
21
|
+
'ubuntu-20.04' => 'focal',
|
22
|
+
'ubuntu-22.04' => 'jammy'
|
20
23
|
}.freeze
|
21
24
|
|
22
25
|
def initialize(config = {})
|
@@ -21,8 +21,6 @@ class OodPackaging::Package
|
|
21
21
|
@config = config
|
22
22
|
@config[:dist] = 'el8' if tar_only?
|
23
23
|
@build_box = OodPackaging::BuildBox.new(config)
|
24
|
-
@clean_work_dir = config[:clean_work_dir].nil? ? true : config[:clean_work_dir]
|
25
|
-
@clean_output_dir = config[:clean_output_dir].nil? ? true : config[:clean_output_dir]
|
26
24
|
raise ArgumentError, 'Package is required' if package.nil?
|
27
25
|
raise ArgumentError, 'Version is required' if version.nil?
|
28
26
|
raise ArgumentError, "Package #{package} is not a directory" unless Dir.exist?(package)
|
@@ -33,12 +31,18 @@ class OodPackaging::Package
|
|
33
31
|
@container_name ||= SecureRandom.uuid
|
34
32
|
end
|
35
33
|
|
36
|
-
def debug
|
34
|
+
def debug?
|
37
35
|
return true if ENV['OOD_PACKAGING_DEBUG'] == 'true'
|
38
36
|
|
39
37
|
@config[:debug].nil? ? false : @config[:debug]
|
40
38
|
end
|
41
39
|
|
40
|
+
def cmd_suffix
|
41
|
+
return '' if debug?
|
42
|
+
|
43
|
+
' 2>/dev/null 1>/dev/null'
|
44
|
+
end
|
45
|
+
|
42
46
|
def attach?
|
43
47
|
return true if ENV['OOD_PACKAGING_ATTACH'] == 'true'
|
44
48
|
|
@@ -49,10 +53,22 @@ class OodPackaging::Package
|
|
49
53
|
@work_dir ||= File.expand_path(@config[:work_dir])
|
50
54
|
end
|
51
55
|
|
56
|
+
def clean_work_dir
|
57
|
+
return false if ENV['OOD_PACKAGING_CLEAN_WORK_DIR'] == 'false'
|
58
|
+
|
59
|
+
@config[:clean_work_dir].nil? ? true : @config[:clean_work_dir]
|
60
|
+
end
|
61
|
+
|
52
62
|
def output_dir
|
53
63
|
@output_dir ||= File.expand_path(@config[:output_dir])
|
54
64
|
end
|
55
65
|
|
66
|
+
def clean_output_dir
|
67
|
+
return false if ENV['OOD_PACKAGING_CLEAN_OUTPUT_DIR'] == 'false'
|
68
|
+
|
69
|
+
@config[:clean_output_dir].nil? ? true : @config[:clean_output_dir]
|
70
|
+
end
|
71
|
+
|
56
72
|
def package
|
57
73
|
@config[:package]
|
58
74
|
end
|
@@ -90,8 +106,6 @@ class OodPackaging::Package
|
|
90
106
|
|
91
107
|
def gpg_files
|
92
108
|
[
|
93
|
-
OpenStruct.new(private_key: File.join(proj_root, 'ondemand.sec'), passphrase: File.join(proj_root, '.gpgpass')),
|
94
|
-
OpenStruct.new(private_key: File.join(package, 'ondemand.sec'), passphrase: File.join(package, '.gpgpass')),
|
95
109
|
OpenStruct.new(private_key: @config[:gpg_private_key], passphrase: @config[:gpg_passphrase]),
|
96
110
|
OpenStruct.new(private_key: ENV['OOD_PACKAGING_GPG_PRIVATE_KEY'],
|
97
111
|
passphrase: ENV['OOD_PACKAGING_GPG_PASSPHRASE'])
|
@@ -109,8 +123,14 @@ class OodPackaging::Package
|
|
109
123
|
!gpg_files.nil?
|
110
124
|
end
|
111
125
|
|
126
|
+
def default_gpg_name
|
127
|
+
return 'OnDemand Release Signing Key' if build_box.scl?
|
128
|
+
|
129
|
+
'OnDemand Release Signing Key (SHA512)'
|
130
|
+
end
|
131
|
+
|
112
132
|
def gpg_name
|
113
|
-
@config[:gpg_name].nil? ?
|
133
|
+
@config[:gpg_name].nil? ? default_gpg_name : @config[:gpg_name]
|
114
134
|
end
|
115
135
|
|
116
136
|
def container_init
|
@@ -174,7 +194,7 @@ class OodPackaging::Package
|
|
174
194
|
cmd.concat exec_launchers if docker_runtime?
|
175
195
|
cmd.concat ['scl', 'enable', scl_ruby, '--'] if podman_runtime? && build_box.scl?
|
176
196
|
cmd.concat [File.join(ctr_scripts_dir, 'rake')]
|
177
|
-
cmd.concat ['-q'] unless debug
|
197
|
+
cmd.concat ['-q'] unless debug?
|
178
198
|
cmd.concat ['-f', File.join(ctr_scripts_dir, 'Rakefile'), 'ood_packaging:package:build']
|
179
199
|
cmd
|
180
200
|
end
|
@@ -200,13 +220,13 @@ class OodPackaging::Package
|
|
200
220
|
end
|
201
221
|
|
202
222
|
def clean!
|
203
|
-
sh "rm -rf #{work_dir}", verbose: debug if
|
204
|
-
sh "rm -rf #{output_dir}", verbose: debug if
|
223
|
+
sh "rm -rf #{work_dir}", verbose: debug? if clean_work_dir
|
224
|
+
sh "rm -rf #{output_dir}", verbose: debug? if clean_output_dir
|
205
225
|
end
|
206
226
|
|
207
227
|
def bootstrap!
|
208
|
-
sh "mkdir -p #{work_dir}", verbose: debug
|
209
|
-
sh "mkdir -p #{output_dir}", verbose: debug
|
228
|
+
sh "mkdir -p #{work_dir}", verbose: debug?
|
229
|
+
sh "mkdir -p #{output_dir}", verbose: debug?
|
210
230
|
end
|
211
231
|
|
212
232
|
def tar!
|
@@ -224,7 +244,7 @@ class OodPackaging::Package
|
|
224
244
|
sh "rm #{tar_file}" if File.exist?(tar_file)
|
225
245
|
puts "Create tar archive #{tar_file}".blue
|
226
246
|
Dir.chdir(tar_path) do
|
227
|
-
sh cmd.join(' '), verbose: debug
|
247
|
+
sh cmd.join(' '), verbose: debug?
|
228
248
|
end
|
229
249
|
end
|
230
250
|
|
@@ -238,19 +258,19 @@ class OodPackaging::Package
|
|
238
258
|
tar! if tar?
|
239
259
|
container_start!
|
240
260
|
container_exec!(exec_rake)
|
261
|
+
puts "Build SUCCESS: package=#{package} dist=#{build_box.dist}".green
|
241
262
|
rescue RuntimeError
|
242
|
-
# ret = 1
|
243
263
|
puts "Build FAILED package=#{package} dist=#{build_box.dist}".red
|
244
264
|
raise
|
245
|
-
else
|
246
|
-
puts "Build SUCCESS: package=#{package} dist=#{build_box.dist}".green
|
247
265
|
ensure
|
248
266
|
container_exec!(exec_attach, ['-i', '-t']) if attach?
|
249
|
-
container_kill! if container_running?
|
267
|
+
container_kill! if container_running? && !attach?
|
250
268
|
end
|
251
269
|
|
252
270
|
def container_running?
|
253
|
-
|
271
|
+
cmd = "#{container_runtime} inspect #{container_name} 2>/dev/null 1>/dev/null"
|
272
|
+
puts cmd if debug?
|
273
|
+
`#{cmd}`
|
254
274
|
$CHILD_STATUS.success?
|
255
275
|
end
|
256
276
|
|
@@ -261,9 +281,9 @@ class OodPackaging::Package
|
|
261
281
|
cmd.concat container_mounts
|
262
282
|
cmd.concat [build_box.image_tag]
|
263
283
|
cmd.concat [container_init]
|
264
|
-
cmd.concat ['1>/dev/null'] unless debug
|
284
|
+
cmd.concat ['1>/dev/null'] unless debug?
|
265
285
|
puts "Starting container #{container_name} using image #{build_box.image_tag}".blue
|
266
|
-
sh cmd.join(' '), verbose: debug
|
286
|
+
sh cmd.join(' '), verbose: debug?
|
267
287
|
end
|
268
288
|
|
269
289
|
def container_exec!(exec_cmd, extra_args = [])
|
@@ -275,14 +295,18 @@ class OodPackaging::Package
|
|
275
295
|
cmd.concat [container_name]
|
276
296
|
cmd.concat exec_cmd
|
277
297
|
puts "Build STARTED: package=#{package} dist=#{build_box.dist} exec=#{exec_cmd[-1]}".blue
|
278
|
-
sh cmd.join(' '), verbose: debug
|
298
|
+
sh cmd.join(' '), verbose: debug?
|
299
|
+
true
|
300
|
+
rescue RuntimeError
|
301
|
+
container_kill! if container_running? && attach?
|
302
|
+
raise
|
279
303
|
end
|
280
304
|
|
281
305
|
def container_kill!
|
282
306
|
puts "Killing container #{container_name}".blue
|
283
307
|
cmd = [container_runtime, 'kill', container_name]
|
284
|
-
cmd.concat [
|
285
|
-
sh cmd.join(' '), verbose: debug
|
308
|
+
cmd.concat [cmd_suffix] unless debug?
|
309
|
+
sh cmd.join(' '), verbose: debug?
|
286
310
|
end
|
287
311
|
|
288
312
|
def container_env
|
@@ -296,7 +320,7 @@ class OodPackaging::Package
|
|
296
320
|
'SKIP_DOWNLOAD' => @config[:skip_download],
|
297
321
|
'OOD_UID' => Process.uid,
|
298
322
|
'OOD_GID' => Process.gid,
|
299
|
-
'DEBUG' => debug
|
323
|
+
'DEBUG' => debug?
|
300
324
|
}
|
301
325
|
env['GPG_PUBKEY'] = '/gpg.pub' if @config[:gpg_pubkey]
|
302
326
|
env
|
data/lib/ood_packaging/tasks.rb
CHANGED
@@ -44,8 +44,9 @@ namespace :ood_packaging do
|
|
44
44
|
OodPackaging::RakeTask.new(:internal, [:package, :dist]) do |t, args|
|
45
45
|
name = args[:package].split(':').last
|
46
46
|
t.package = File.join(proj_root, 'packages', name)
|
47
|
-
|
48
|
-
t.
|
47
|
+
dist = args[:dist] || ENV['OOD_PACKAGING_DIST']
|
48
|
+
t.dist = dist
|
49
|
+
t.version = OodPackaging.package_version(name, dist)
|
49
50
|
t.work_dir = File.join(proj_root, 'tmp/work')
|
50
51
|
t.output_dir = File.join(proj_root, 'tmp/output')
|
51
52
|
end
|
data/lib/ood_packaging/utils.rb
CHANGED
@@ -2,17 +2,17 @@
|
|
2
2
|
|
3
3
|
# Version code for OodPackaging
|
4
4
|
module OodPackaging
|
5
|
-
VERSION = '0.
|
5
|
+
VERSION = '0.3.0'
|
6
6
|
PACKAGE_VERSION = {
|
7
7
|
'ondemand-release' => {
|
8
8
|
'(ubuntu|debian)' => '2.1.0',
|
9
|
-
'default' => '2.1'
|
9
|
+
'default' => '2.1.0'
|
10
10
|
},
|
11
11
|
'ondemand-release-latest' => {
|
12
12
|
'(ubuntu|debian)' => '1',
|
13
|
-
'default' => '1-
|
13
|
+
'default' => '1-7'
|
14
14
|
},
|
15
|
-
'ondemand-runtime' => '2.1',
|
15
|
+
'ondemand-runtime' => '2.1.1',
|
16
16
|
'passenger' => '6.0.14',
|
17
17
|
'cjose' => '0.6.1',
|
18
18
|
'mod_auth_openidc' => '2.4.5',
|
@@ -20,9 +20,9 @@ module OodPackaging
|
|
20
20
|
'ondemand_exporter' => '0.9.0',
|
21
21
|
'ondemand-compute' => {
|
22
22
|
'(ubuntu|debian)' => '2.1.0',
|
23
|
-
'default' => '2.1'
|
23
|
+
'default' => '2.1.0'
|
24
24
|
},
|
25
|
-
'python-websockify' => '0.
|
25
|
+
'python-websockify' => '0.10.0',
|
26
26
|
'turbovnc' => '2.2.5'
|
27
27
|
}.freeze
|
28
28
|
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: ood_packaging
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.3.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Trey Dockendorf
|
@@ -9,7 +9,7 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2022-
|
12
|
+
date: 2022-06-22 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: rake
|
@@ -83,6 +83,7 @@ files:
|
|
83
83
|
- lib/ood_packaging/build_box.rb
|
84
84
|
- lib/ood_packaging/build_box/docker-image/Dockerfile.erb
|
85
85
|
- lib/ood_packaging/build_box/docker-image/RPM-GPG-KEY-ondemand
|
86
|
+
- lib/ood_packaging/build_box/docker-image/RPM-GPG-KEY-ondemand-SHA512
|
86
87
|
- lib/ood_packaging/build_box/docker-image/Rakefile
|
87
88
|
- lib/ood_packaging/build_box/docker-image/inituidgid.sh.erb
|
88
89
|
- lib/ood_packaging/build_box/docker-image/install.sh.erb
|
@@ -113,7 +114,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
113
114
|
- !ruby/object:Gem::Version
|
114
115
|
version: '0'
|
115
116
|
requirements: []
|
116
|
-
rubygems_version: 3.
|
117
|
+
rubygems_version: 3.2.33
|
117
118
|
signing_key:
|
118
119
|
specification_version: 4
|
119
120
|
summary: Open OnDemand packaging library
|