/kp

Korora packaging tool

Primary LanguageShellGNU General Public License v3.0GPL-3.0

Korora Package (KP)

A Korora package can be considered a high level package that often (but not
always) manages all Korora specific modifications to upstream packages. Some
packages are entirely new projects which Korora has baked itself but they are
treated much the same.

The Korora packages are stored completely within git and are best managed with
the Korora packaging utility called “kp”. The kp utility allows you to reproduce
the entire Korora ecosystem, as well as contribute easier to the project through
submission of patches and pull requests.

In order to allow for the various use cases involved in the endeavour, the tool
uses a number of options and flags that are controlled via a global config file,
with the option to override these flags using local package options. This gives
us the freedom as well as flexibility to set up and use the kp tool, to build
korora from scratch.

To begin with, here's an annotated global config file (usually stored in the
same dir as the kp tool) to specify the options needed by git and kp.

##### BEGIN -----------8< ---- kp.conf --- >8----------   ##########
# A heavily annotated kp.conf file for illustration purposes Name as 'kp.conf'
# and store this file in the same dir as "kp" tool.  Who to build packages as
# (defaults to anonymous).  Substitute with username to use developer account

KP_DEV_ACCOUNT=""  # if using for first time, leave blank
KP_DEV_EMAIL=""    #   ======"======DITTO======"========

# Protocol for git (can be 'git' or 'https' or 'ssh')
GIT_PROTOCOL="http" # again, first timers, use this
# https or ssh can be used, if you aready have GH experience
# but first time user doing anonymous fetches is better off with http

# URLs for git
GIT_URL_GIT="git://github.com/kororaproject"
GIT_URL_HTTP="https://github.com/kororaproject"
GIT_URL_SSH="git@github.com:kororaproject"

# location of git repo holding packages
GIT_URL=git://github.com/kororaproject
GIT_URL_DEV=git@github.com:kororaproject

# Temporary location for building packages
TMP_DIR=/var/lib/kp

# Enable debug
#DEBUG=1

# N.B: Keep the dir containing the kp tool separate from the dir containing all
# the korora packages. See above. Both dirs are actually different locations
# within the "korora" dir tree.
#  /home/jackychan
#     |--- projects
#           |--- kpchan #<== here be all fedora/korora packages
#           |--- kp.git #<== and the "kp" tool, cloned from git
# keep reading below to get the idea behind the above dir structure

## working dirs
_CODE="/home/jackychan/projects/kpchan"
WORKING_DIR="${_CODE}/kp"
# ^^ these dirs contain all packages needed for building korora
#CONFIG_DIR="${_CODE}/kp/conf/"

# dir below refers to a dir containing kp tool checked out from repos
LIB_DIR="${_CODE}/kp.git/lib/"
LOG_DIR=/tmp

# Set the key to use for a release version, e.g. 18 and 19
KEY_ID[18]=30B55DCA
KEY_ID[19]=DCBE2AC3

### -----8<-------  EOF   kp.conf ------>8--------- EOF  ##########

As a first step, copy the contents above into the kp.conf file that is present
in the kp tool dir. Keep a copy of the original, if you wish. Initially get
comfortable with the tool by typing

    ./kp --help,   followed by
    ./kp [command] --help

respectively, where [command] is the list of available options that the tool can
handle for building korora packages.

The next step is to do some tool "housekeeping". This sets up the dir structure
and other config files needed for the tool to pull the upstream repos for the
korora build. To do this type

    ./kp  init  {or} ./kp --init

and you are ready to do business...


Now, get a feel for the various packages needed for kororification of your
system by typing

    ./kp  list  {or}  ./kp --list

lists all the packages/kickstarts that are relevant for the process.  Initially
the packages will come with a '-' next to them. This means, the package in
question is available, but not checked out.  As you start working with packages,
the '-' will be replaced by other symbols. The help command will provide you
with details on the various symbols and their meanings. (Hint: ./kp list --help)

Once you can see the list of korora packages, you can issue a bulk checkout
which will pull all the upstream repos to your local machine. For example, in
the above example (from kp. conf above), when you issue a checkout, the
individual packages checked out from the repositories will reside in the
following directory:
   "/home/jackychan/projects/kpchan/packages/"

To checkout all or a specific [package], issue

    ./kp checkout [package]   {or} ./kp --checkout [package]

Examples:
    ./kp checkout handbrake # pulls handbrake tool from repos
    ./kp checkout jockey # drivers support from ubuntu's stable
    ./kp checkout  # get the full kaboodle

Note that the build operation fetches information from online repositories and
therefore requires a working internet connection.  If all this went smoothly,
congratulations. The only thing left is to build korora on your machine.The next
few steps show you how.

The first thing you do is to turn off selinux to "permissive" mode,
from its default mode of "enforcing". A discussion on this is beyond
the scope of this document; however you are referred to many
excellent resources available on the internet. For example:
  http://wiki.centos.org/HowTos/SELinux
  http://en.wikipedia.org/wiki/Security-Enhanced_Linux

On the terminal, type
    getenforce        # You *should* get "Enforcing" as response
    sudo setenforce 0 #  set mode to permissive
    ./kp build [package]  {or}  ./kp --build [package]
    # like checkout, omitting a package builds everything, and
    # specifying a package name builds only that package
    sudo setenforce 1 #  set mode to enforcing again

Copy any errors that you may encounter, as it will assist in troubleshooting
issues.

If you are satisfied with all the actions so far, and wish to deploy a korora
ISO of your own, type this (as sudo) in your terminal.

    sudo ./kp release [gnome/kde] # self-explanatory

Now to briefly look at local(ised) configuration files that provide
package-level granularity in controlling the kp tool. As always, here's an
annotated file for the jockey proprietary driver support tool, shown below:


---8<--- jockey.conf --->8---

KP_NAME=jockey
KP_VERSION=0.9.1

# indicate what the upstream source is wrapped in, and where to get it
KP_UPSTREAM_SRC_TYPE=git,svn,rpm,tarball
KP_UPSTREAM_SRC_URL=

# GIT specific - what branch/commit should all package builds be built relative
# to
KP_UPSTREAM_SRC_GIT_COMMIT=
KP_UPSTREAM_SRC_GIT_BRANCH=

# SVN specific - what revision number should all package builds be built
# relative to
KP_UPSTREAM_SRC_SVN_REVISION


# RPM specific - what’s the reference upstream spec
KP_UPSTREAM_SPEC=%upstream%/spec


# if undefined uses upstream spec (if defined) otherwise errors if missing
KP_BUILD_SPEC=

# the build spec will be dynamically built via the build spec template. Patch,
# source and build numbers will be dynamically updated based on the template.
KP_BUILD_SPEC_TEMPLATE=
KP_BUILD_ARCH=i686,x86_64

# defines the commit of the latest stable release from the korora package tree
KP_RELEASE_GIT_COMMIT=


---8<--- end jockey.conf --->8---

File Tree

./upstream

Contains the primary source relating to the package, could be a GIT, SVN url or
the extracted source from an RPM (ie akin to extracted files from
rpmbuild/SOURCES)

./build

Contains the necessary files to build the release RPM. If the upstream is GIT it
will contain the necessary patches (based on appropriate git diff). SVN would be
similar. The package spec file would be dynamically updated based on the

./release

Contains built RPMs