]> git.pld-linux.org Git - packages/pld-builder.git/blobdiff - pld-builder.spec
- err, uploaded to df
[packages/pld-builder.git] / pld-builder.spec
index 63a6c4d0acc3d872be8770f5cc577936d909ff1b..6ee525c85f846fa1960b92049034f378463a7474 100644 (file)
@@ -1,18 +1,19 @@
-%define                snap    20080713
+%define                snap    20090406
 Summary:       PLD RPM builder environment
 Summary(pl.UTF-8):     Środowisko budowniczego pakietów RPM dla PLD
 Name:          pld-builder
-Version:       0.0.%{snap}
-Release:       0.28
+Version:       0.3.%{snap}
+Release:       1
 License:       GPL
 Group:         Development/Building
-Source0:       %{name}.new-%{snap}.tar.bz2
-# Source0-md5: 954f612ed3c4d937d92090171f4eb4ed
+Source0:       %{name}-%{version}.tar.bz2
+# Source0-md5: 2284943fb952e32ecec8a0d7fd60ea8e
 Source1:       %{name}.init
 Source2:       %{name}.sysconfig
 URL:           http://cvs.pld-linux.org/cgi-bin/cvsweb/pld-builder.new/
+BuildRequires: python
 BuildRequires: rpm-pythonprov
-BuildRequires: rpmbuild(macros) >= 1.268
+BuildRequires: rpmbuild(macros) >= 1.469
 BuildRequires: sed >= 4.0
 Requires(post,preun):  /sbin/chkconfig
 Requires(postun):      /usr/sbin/userdel
@@ -20,10 +21,15 @@ Requires(pre):      /bin/id
 Requires(pre): /usr/bin/getgid
 Requires(pre): /usr/sbin/groupadd
 Requires(pre): /usr/sbin/useradd
+Requires:      bash
 Requires:      crondaemon
+Requires:      gnupg
 Requires:      libuuid
+Requires:      python
 Requires:      python-pld-builder = %{version}-%{release}
 Requires:      rc-scripts
+Provides:      group(builder)
+Provides:      user(builder)
 BuildArch:     noarch
 BuildRoot:     %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
 
@@ -59,41 +65,105 @@ PLD Builder Python code.
 %description -n python-pld-builder -l pl.UTF-8
 Kod pythonowy budowniczego PLD.
 
-%package client
-Summary:       PLD Builder client
-Summary(pl.UTF-8):     Klient budowniczych PLD
+%package chroot
+Summary:       PLD Builder chroot
+Summary(pl.UTF-8):     Środowisko chroot buildera PLD
 Group:         Development/Building
-Requires:      gnupg
-
-%description client
-This is the client to send build requests to builders, it is usually
-referred as STBR (Send To Builder Request).
-
-%description client -l pl.UTF-8
-To jest klient do wysyłania zleceń na buildery, zwykle określanych
-jako STBR (Send To Builder Request).
+Requires(postun):      /usr/sbin/userdel
+Requires(pre): /bin/id
+Requires(pre): /usr/bin/getgid
+Requires(pre): /usr/sbin/groupadd
+Requires(pre): /usr/sbin/useradd
+Requires:      bash
+Requires:      mount
+Requires:      poldek >= 0.21-0.20070703.00.16
+Requires:      rpm-build
+Requires:      tmpwatch
+Provides:      group(builder)
+Provides:      user(builder)
+# for srpm builder
+Requires:      cvs-client
+Requires:      rpm-build-tools
+
+%description chroot
+This is the package to be installed in builder chroot.
+
+%description chroot -l pl.UTF-8
+Ten pakiet należy zainstalować w środowisku chroot buildera.
 
 %prep
-%setup -q -n %{name}.new
-
-mv jak-wysy?a?-zlecenia.txt jak-wysylac-zlecenia.txt
-
+%setup -q
 %{__sed} -i -e '
        s,~/pld-builder.new/,%{_sharedstatedir}/%{name}/,
        /^conf_dir/s,=.*,= "%{_sysconfdir}/",
 
 ' PLD_Builder/path.py
 
-%{__sed} -i -e 's,pld-linux\.org,example.org,g' config/builder.conf
+%{__sed} -i -e '
+       s,pld-linux\.org,example.org,g
+       s,/spools/ready,/var/cache/%{name}/ready,
+' config/builder.conf
+
+cat <<'EOF' > poldek.conf
+# locally cached rpms
+[source]
+name = ready
+pri  = -1
+type = pndir
+path = /var/cache/%{name}/ready
+EOF
+
+cat <<'EOF' > crontab
+SHELL=/bin/sh
+MAILTO=root
+
+#* * * * * builder exec nice -n 19 %{_datadir}/bin/request-fetcher.sh
+#* * * * * builder exec nice -n 19 %{_datadir}/bin/load-balancer.sh
+#* * * * * builder exec nice -n 19 %{_datadir}/bin/file-sender.sh
+
+#0 0 * * * chroot /home/users/builder/chroot-ac nice -n 19 tmpwatch -m 240 /var/cache/%{name}/ready
+EOF
+
+cat <<'EOF' > procmailrc
+LOGFILE=procmail.log
+
+#:0 c
+#mail.copy
+
+:0
+* ^X-New-PLD-Builder:
+| %{_datadir}/bin/request-handler.sh
+
+:0
+* ^FROM_MAILER
+/dev/null
+
+#:0
+#!root@example.org
+EOF
+
+cat <<'EOF' > rpm.macros
+# rpm macros for pld builder chroot
+
+# A colon separated list of desired locales to be installed;
+# "all" means install all locale specific files.
+%%_install_langs en_US
+
+# If non-zero, all erasures will be automagically repackaged.
+%%_repackage_all_erasures    0
+
+# Boolean (i.e. 1 == "yes", 0 == "no") that controls whether files
+# marked as %doc should be installed.
+# FIXME: excludedocs breaks kde build
+#%%_excludedocs   1
+EOF
 
 %build
 %{__make}
+%py_lint PLD_Builder
 
 %install
 rm -rf $RPM_BUILD_ROOT
-# client
-install -d $RPM_BUILD_ROOT%{_bindir}
-install client/make-request.sh $RPM_BUILD_ROOT%{_bindir}/%{name}-make-request
 
 # python
 install -d $RPM_BUILD_ROOT%{py_scriptdir}/PLD_Builder
@@ -105,7 +175,6 @@ cp -a config/{rsync-passwords,*.conf} $RPM_BUILD_ROOT%{_sysconfdir}
 install -d $RPM_BUILD_ROOT%{_datadir}/{bin,admin}
 for a in bin/*.sh; do
 sed -e '
-#      s,cd ~/pld-builder.new,cd %{py_scriptdir},
        /cd ~\/pld-builder.new/d
        s,python \(PLD_Builder.*.py\),python %{py_scriptdir}/\1c,
 ' $a > $RPM_BUILD_ROOT%{_datadir}/bin/$(basename $a)
@@ -114,13 +183,32 @@ cp -a admin/*.sh $RPM_BUILD_ROOT%{_datadir}/admin
 
 # dirs
 install -d $RPM_BUILD_ROOT{%{_sharedstatedir}/%{name}/{spool/{buildlogs,builds,ftp,notify},lock,www/{s,}rpms},/etc/{sysconfig,rc.d/init.d}}
+install -d $RPM_BUILD_ROOT/home/services/builder/.gnupg
+install -d $RPM_BUILD_ROOT/home/services/builder/.ssh
+install -d $RPM_BUILD_ROOT/home/services/builder/rpm/{BUILD,RPMS,SRPMS,{SOURCES,SPECS}/CVS}
+install -d $RPM_BUILD_ROOT/var/cache/%{name}/ready
+ln -s %{_bindir}/builder $RPM_BUILD_ROOT/home/services/builder/rpm/SPECS
+
+echo "SPECS" > $RPM_BUILD_ROOT/home/services/builder/rpm/SPECS/CVS/Repository
+echo ":pserver:cvs@cvs.pld-linux.org:/cvsroot" > $RPM_BUILD_ROOT/home/services/builder/rpm/SPECS/CVS/Root
+touch $RPM_BUILD_ROOT/home/services/builder/rpm/SPECS/CVS/Entries{,.Static}
+
+install -d $RPM_BUILD_ROOT/etc/poldek/repos.d
+cp -a poldek.conf $RPM_BUILD_ROOT/etc/poldek/repos.d/%{name}.conf
+
+install -d $RPM_BUILD_ROOT/etc/rpm
+cp -a rpm.macros $RPM_BUILD_ROOT/etc/rpm/macros.builder
+
+# crontab
+install -d $RPM_BUILD_ROOT/etc/cron.d
+cp -a crontab $RPM_BUILD_ROOT/etc/cron.d/%{name}
 
 install %{SOURCE1} $RPM_BUILD_ROOT/etc/rc.d/init.d/pld-builder
 install %{SOURCE2} $RPM_BUILD_ROOT/etc/sysconfig/pld-builder
 
 # from admin/fresh-queue.sh
 cd $RPM_BUILD_ROOT%{_sharedstatedir}/%{name}
-mkdir -p spool/{builds,buildlogs,notify,ftp} www/srpms lock
+install -d spool/{builds,buildlogs,notify,ftp} www/srpms lock
 echo 0 > www/max_req_no
 echo 0 > spool/last_req_no
 echo -n > spool/processed_ids
@@ -137,10 +225,12 @@ fi
 rm -rf $RPM_BUILD_ROOT
 
 %pre
-%groupadd -g 181 pld-builder
-%useradd -u 181 -g pld-builder -c "srpms builder" srpms_builder
-%useradd -u 182 -g pld-builder -c "bin builder" bin_builder
-%useradd -u 183 -g daemon -c "ftpac" ftpac
+%groupadd -g 181 builder
+%useradd -u 182 -g builder -c "bin builder" -s /bin/bash -d /home/services/builder builder
+
+%pre chroot
+%groupadd -g 181 builder
+%useradd -u 182 -g builder -c "bin builder" -s /bin/bash -d /home/services/builder builder
 
 %post
 /sbin/chkconfig --add %{name}
@@ -154,10 +244,14 @@ fi
 
 %postun
 if [ "$1" = "0" ]; then
-       %userremove srpms_builder
-       %userremove bin_builder
-       %userremove ftpac
-       %groupremove pld-builder
+       %userremove builder
+       %groupremove builder
+fi
+
+%postun chroot
+if [ "$1" = "0" ]; then
+       %userremove builder
+       %groupremove builder
 fi
 
 %files
@@ -169,6 +263,8 @@ fi
 %attr(754,root,root) /etc/rc.d/init.d/pld-builder
 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/pld-builder
 
+%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/cron.d/%{name}
+
 %dir %{_sysconfdir}
 %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/*
 
@@ -180,28 +276,54 @@ fi
 
 %dir %{_sharedstatedir}/%{name}
 
-%dir %attr(775,root,pld-builder) %{_sharedstatedir}/%{name}/spool
-%dir %attr(775,root,pld-builder) %{_sharedstatedir}/%{name}/spool/buildlogs
-%dir %{_sharedstatedir}/%{name}/spool/builds
-%dir %{_sharedstatedir}/%{name}/spool/ftp
-%dir %attr(775,root,pld-builder) %{_sharedstatedir}/%{name}/spool/notify
+%dir %attr(775,root,builder) %{_sharedstatedir}/%{name}/spool
+%dir %attr(775,root,builder) %{_sharedstatedir}/%{name}/spool/buildlogs
+%dir %attr(775,root,builder) %{_sharedstatedir}/%{name}/spool/builds
+%dir %attr(775,root,builder) %{_sharedstatedir}/%{name}/spool/ftp
+%dir %attr(775,root,builder) %{_sharedstatedir}/%{name}/spool/notify
 
-%config(noreplace) %verify(not md5 mtime size) %{_sharedstatedir}/%{name}/spool/got_lock
-%config(noreplace) %verify(not md5 mtime size) %{_sharedstatedir}/%{name}/spool/last_req_no
-%config(noreplace) %verify(not md5 mtime size) %{_sharedstatedir}/%{name}/spool/processed_ids
-%config(noreplace) %verify(not md5 mtime size) %{_sharedstatedir}/%{name}/spool/queue
-%config(noreplace) %verify(not md5 mtime size) %{_sharedstatedir}/%{name}/spool/req_queue
+%attr(644,builder,builder) %config(noreplace) %verify(not md5 mtime size) %{_sharedstatedir}/%{name}/spool/got_lock
+%attr(644,builder,builder) %config(noreplace) %verify(not md5 mtime size) %{_sharedstatedir}/%{name}/spool/last_req_no
+%attr(644,builder,builder) %config(noreplace) %verify(not md5 mtime size) %{_sharedstatedir}/%{name}/spool/processed_ids
+%attr(644,builder,builder) %config(noreplace) %verify(not md5 mtime size) %{_sharedstatedir}/%{name}/spool/queue
+%attr(644,builder,builder) %config(noreplace) %verify(not md5 mtime size) %{_sharedstatedir}/%{name}/spool/req_queue
 
-%dir %attr(775,root,pld-builder) %{_sharedstatedir}/%{name}/lock
+%dir %attr(775,root,builder) %{_sharedstatedir}/%{name}/lock
 
 %dir %{_sharedstatedir}/%{name}/www
 %dir %{_sharedstatedir}/%{name}/www/rpms
 %dir %{_sharedstatedir}/%{name}/www/srpms
-%config(noreplace) %verify(not md5 mtime size) %{_sharedstatedir}/%{name}/www/max_req_no
+%attr(644,builder,builder) %config(noreplace) %verify(not md5 mtime size) %{_sharedstatedir}/%{name}/www/max_req_no
+
+%dir %attr(750,builder,builder) /home/services/builder
+%dir %attr(750,builder,builder) /home/services/builder/.gnupg
+%dir %attr(700,builder,builder) /home/services/builder/.ssh
 
-%files client
+%files chroot
 %defattr(644,root,root,755)
-%attr(755,root,root) %{_bindir}/%{name}-make-request
+%dir %attr(750,builder,builder) /home/services/builder
+%dir %attr(750,builder,builder) /home/services/builder/rpm
+%dir %attr(750,builder,builder) /home/services/builder/rpm/BUILD
+%dir %attr(750,builder,builder) /home/services/builder/rpm/RPMS
+%dir %attr(750,builder,builder) /home/services/builder/rpm/SRPMS
+%dir %attr(750,builder,builder) /home/services/builder/rpm/SOURCES
+%dir %attr(750,builder,builder) /home/services/builder/rpm/SPECS
+
+# for srpm builder
+%attr(750,builder,builder) /home/services/builder/rpm/SPECS/builder
+%dir %attr(750,builder,builder) /home/services/builder/rpm/SPECS/CVS
+%attr(640,builder,builder) %config(noreplace) %verify(not md5 mtime size) /home/services/builder/rpm/SPECS/CVS/Repository
+%attr(640,builder,builder) %config(noreplace) %verify(not md5 mtime size) /home/services/builder/rpm/SPECS/CVS/Root
+%attr(640,builder,builder) %config(noreplace) %verify(not md5 mtime size) /home/services/builder/rpm/SPECS/CVS/Entries
+%attr(640,builder,builder) %config(noreplace) %verify(not md5 mtime size) /home/services/builder/rpm/SPECS/CVS/Entries.Static
+
+# minimal but sane defaults for rpm inside chroot
+%config(noreplace) %verify(not md5 mtime size) /etc/rpm/macros.builder
+
+# locally cached rpms from bin-builder
+%config(noreplace) %verify(not md5 mtime size) /etc/poldek/repos.d/%{name}.conf
+%dir /var/cache/%{name}
+%dir %attr(775,root,builder) /var/cache/%{name}/ready
 
 %files -n python-pld-builder
 %defattr(644,root,root,755)
This page took 0.080694 seconds and 4 git commands to generate.