/[adm]/puppet/modules/buildsystem/manifests/init.pp
ViewVC logotype

Contents of /puppet/modules/buildsystem/manifests/init.pp

Parent Directory Parent Directory | Revision Log Revision Log


Revision 503 - (show annotations) (download)
Sun Dec 5 22:40:31 2010 UTC (13 years, 4 months ago) by blino
File size: 4730 byte(s)
mga-committers should be able to write in /home/schedbot/repsys/tmp

1 class buildsystem {
2
3 class base {
4 $build_login = "iurt"
5 $build_home_dir = "/home/$build_login"
6 $sched_login = "schedbot"
7 $sched_home_dir = "/home/$sched_login"
8
9 include ssh::auth
10 ssh::auth::key { $build_login: } # declare a key for build bot: RSA, 2048 bits
11 ssh::auth::key { $sched_login: } # declare a key for sched bot: RSA, 2048 bits
12 }
13
14 class mainnode inherits base {
15 include iurtuser
16
17 sshuser { $sched_login:
18 homedir => $sched_home_dir,
19 comment => "System user used to schedule builds",
20 }
21
22 ssh::auth::client { $sched_login: }
23 ssh::auth::server { $build_login: }
24
25 $package_list = ['task-bs-cluster-main', 'iurt']
26 package { $package_list:
27 ensure => "installed"
28 }
29
30 apache::vhost_other_app { "repository.$domain":
31 vhost_file => "buildsystem/vhost_repository.conf",
32 }
33
34 apache::vhost_other_app { "pkgsubmit.$domain":
35 vhost_file => "buildsystem/vhost_pkgsubmit.conf",
36 }
37
38 include scheduler
39 include gatherer
40 include repsys
41 }
42
43 class buildnode inherits base {
44 include iurt
45 }
46
47 class scheduler {
48 # ulri
49 include iurtupload
50 }
51
52 class gatherer {
53 # emi
54 include iurtupload
55 }
56
57 class iurtupload {
58 file { "/etc/iurt/upload.conf":
59 ensure => present,
60 owner => $build_login,
61 group => $build_login,
62 mode => 644,
63 require => File["/etc/iurt"],
64 content => template("buildsystem/upload.conf")
65 }
66 }
67
68 class repsys {
69 package { 'repsys':
70
71 }
72
73 file { "repsys.conf":
74 path => "/etc/repsys.conf",
75 owner => root,
76 group => root,
77 mode => 644,
78 content => template("buildsystem/repsys.conf")
79 }
80
81 file { "$sched_home_dir/repsys":
82 ensure => "directory",
83 require => File[$sched_home_dir],
84 }
85
86 file { "$sched_home_dir/repsys/tmp":
87 ensure => "directory",
88 group => "mga-committers",
89 mode => 775,
90 require => File["$sched_home_dir/repsys"],
91 }
92
93 file { "$sched_home_dir/repsys/srpms":
94 ensure => "directory",
95 require => File["$sched_home_dir/repsys"],
96 }
97 }
98
99 define sshuser($homedir, $comment) {
100 group {"$title":
101 ensure => present,
102 }
103
104 user {"$title":
105 ensure => present,
106 comment => $comment,
107 managehome => true,
108 gid => $title,
109 shell => "/bin/bash",
110 notify => Exec["unlock$title"],
111 require => Group[$title],
112 }
113
114 # set password to * to unlock the account but forbid login through login
115 exec { "unlock$title":
116 command => "usermod -p '*' $title",
117 refreshonly => true,
118 }
119
120 file { $homedir:
121 ensure => "directory",
122 require => User[$title],
123 }
124
125 file { "$homedir/.ssh":
126 ensure => "directory",
127 mode => 600,
128 owner => $title,
129 group => $title,
130 require => File[$homedir],
131 }
132 }
133
134 class iurtuser {
135 sshuser { $build_login:
136 homedir => $build_home_dir,
137 comment => "System user used to run build bots",
138 }
139
140 file { "/etc/iurt":
141 ensure => "directory",
142 }
143 }
144
145 class iurt {
146 include sudo
147 include iurtuser
148 ssh::auth::client { $build_login: }
149 ssh::auth::server { $sched_login: user => $build_login }
150
151 # build node common settings
152 # we could have the following skip list to use less space:
153 # '/(drakx-installer-binaries|drakx-installer-advertising|gfxboot|drakx-installer-stage2|mandriva-theme)/'
154 $package_list = ['task-bs-cluster-chroot', 'iurt']
155 package { $package_list:
156 ensure => installed;
157 }
158
159 file { "/etc/iurt/build":
160 ensure => "directory",
161 require => File["/etc/iurt"],
162 }
163
164 file { "/etc/iurt/build/cauldron.conf":
165 ensure => present,
166 owner => $build_login,
167 group => $build_login,
168 mode => 644,
169 require => File["/etc/iurt/build"],
170 content => template("buildsystem/iurt.cauldron.conf")
171 }
172
173 file { "/etc/sudoers.d/iurt":
174 ensure => present,
175 owner => root,
176 group => root,
177 mode => 440,
178 content => template("buildsystem/sudoers.iurt")
179 }
180 }
181 }

  ViewVC Help
Powered by ViewVC 1.1.30