[[Category:Fedora ARM Secondary Architecture]]
<u>'''Koji Hub Configuration'''</u>
This is an exert from Paul Whalen's http://paulfedora.wordpress.com/2010/04/12/koji-hub-configuration/
It was agreed that all parts of our Koji build system would reside on Hong Kong. After successfully installing and configuring Postgresql the next step is the Koji Hub. In order for the Koji Hub to work Apache should be installed as well as a few additional modules. Run the following command as root:
yum install koji-hub httpd mod_ssl mod_python'''
Then edit the Apache conf file – ‘'''[root@hongkong ~]# yum install koji-hub /etc/httpd mod_ssl mod_python/conf/httpd.conf'''’ and change the '''“MaxRequestsPerChild”'''to 100. On Hong Kong these setting were already in place as Apache was running and configured.
Then edit the Apache conf file – ‘'''/etc/httpd/conf/httpd.conf'''’ and change the '''“MaxRequestsPerChild”''' to 100 . On Hong Kong these setting were already in place as Apache was running and configured.
Next edit the ‘'''/etc/koji-hub/hub.conf'''’ file and add the following lines:
''' DBName = koji''' ''' DBUser = koji''' ''' DBHost = localhost''' ''' KojiDir = /mnt/koji''' ''' LoginCreatesUser = On''' ''' KojiWebURL = http://hongkong.proximity.on.ca/koji'''
Since we are using SSL for authentication, also add:
DNUsernameComponent = CN
ProxyDNs = "/C=CA/ST=Ontario/O=Seneca CDOT/OU=/CN=kojiweb/emailAddress="
'''DNUsernameComponent = CN'''And in the ‘/etc/httpd/conf.d/kojihub.conf’ uncomment the following lines:
'''ProxyDNs = " <Location /C=CAkojihub> SSLOptions +StdEnvVars </ST=Ontario/O=Seneca CDOT/OU=/CN=kojiweb/emailAddress="'''Location>
Using the [[Fedora_Arm_Secondary_Architecture/Koji_Certificates|Koji certificates]], we need to add the following lines to ‘/etc/httpd/conf.d/ssl.conf’, under the section
‘VirtualHost _default_:443′:
SSLCertificateFile /etc/pki/koji/certs/kojihub.crt
SSLCertificateKeyFile /etc/pki/koji/certs/kojihub.key
SSLCertificateChainFile /etc/pki/koji/koji_ca_cert.crt
SSLCACertificateFile /etc/pki/koji/koji_ca_cert.crt
SSLVerifyClient require
SSLVerifyDepth 10
And Even though SE Linux is not currently in use on Hong Kong, it may be in the ‘/etc/httpd/conffuture.d/kojihub.conf’ uncomment In order to allow Apache to connect to the Postgresql database run the following linescommand as root:
Location /kojihub> setsebool -P httpd_can_network_connect_db 1
SSLOptions +StdEnvVarsTo allow Koji to work, a skeleton filesystem needs to be created and the ownership changed so Apache can write to it as required. The following commands were executed:
mkdir -p /Location>'''mnt/koji/{packages,repos,work,scratch} chown -R apache.apache /mnt/koji
Using Then edited the certificates created by Sadiki, we need to add the following lines to ‘'/etc/httpd/koji.conf.d/ssl.conf’, under ' file and changed the section ‘VirtualHost _default_following lines:443′:SSLCertificateFile /etc/pki/koji/certs/kojihub.crtSSLCertificateKeyFile /etc/pki/koji/certs/kojihub.keySSLCertificateChainFile /etc/pki/koji/koji_ca_cert.crtSSLCACertificateFile /etc/pki/koji/koji_ca_cert.crtSSLVerifyClient requireSSLVerifyDepth 10
Even though SE Linux is not currently in use ;url of XMLRPC server server = http://hongkong.proximity.on Hong Kong, it may be in .ca/kojihub ;url of web interface weburl = http://hongkong.proximity.on.ca/koji ;url of package download site pkgurl = http://hongkong.proximity.on.ca/packages ;path to the koji top directory topdir = /mnt/koji ;configuration for SSL athentication ;client certificate cert = ~/.koji/client.crt ;certificate of the CA that issued the futureclient certificate ca = ~/.koji/clientca. In order to allow Apache to connect to crt ;certificate of the Postgresql database run CA that issued the following command as root:HTTP server certificate[root@hongkong serverca = ~]#setsebool -P httpd_can_network_connect_db 1/.koji/serverca.crt
To allow Koji to workAfter this is competed, a skeleton filesystem needs to the final step is the addition of the user and builder accounts. First add the kojira account and grant repo privileges with the following command( this should be created and done before running kojira for the ownership changed so Apache can write to it as required. The follwing commands were executedfirst time) :cd /mntmkdir kojicd kojimkdir {packages,repos,work,scratch}chown apache.apache *
Then edited the ‘/etc/koji.conf’ file and changed the following lines:;url of XMLRPC serverserver = http://hongkong.proximity.on.ca/kojihub;url of web interfaceweburl = http://hongkong.proximity.on.ca/koji;url of package download sitepkgurl = http://hongkong.proximity.on.ca/packages;path to the koji top directorytopdir = /mnt/koji;configuration for SSL athentication;client certificatecert = ~/.koji/client.crt;certificate of the CA that issued the client certificateca = ~/.koji/clientca.crt;certificate of the CA that issued the HTTP server certificateserverca = ~/.koji/serverca.crtAfter this is competed, the final step is the addition of the user and builder accounts. First add the kojira account and grant repo privileges with the following command( this should be done before running kojira for the first time) :[root@hongkong ~]# su - kojiadmin[kojiadmin@hongkong ~]$ koji add-user kojira[kojiadmin@hongkong ~]$ koji grant-permission repo kojira
Then add as many builders as required using the following commands editing where required (this should also be done prior to running kojid on each host):
[kojiadmin@hongkong ~]$ koji add-host arm-001-001 arm[kojiadmin@hongkong ~]$ koji add-host arm-001-002 arm[kojiadmin@hongkong ~]$ koji add-host arm-001-003 arm
Next… Koji Web.