Difference between revisions of "Create or Update a Debian package"

From Organic Design wiki
(Change source-code blocks to standard format)
 
(27 intermediate revisions by 2 users not shown)
Line 1: Line 1:
 
{{procedure
 
{{procedure
|description = This procedure defines the steps required to package up a collection of official packages and other installation script into a Debian package which can then be installed as part of the [[Debian Post Install]] using ''apt-get''
+
|description = This procedure defines the steps required to package up a collection of official packages and other installation scripts into a [[w:Debian package|Debian package]] which can then be installed as part of the [[Debian Post Install]] using ''apt-get''. See [[Packages]] for more information on our overall package repository plans.
|role = dev
+
|role = sysop
 +
|status = in use
 
}}__NOTOC__
 
}}__NOTOC__
  
== organicdesign-server ==
+
== General procedure ==
The ultimate purpose of the ''organicdesign-server'' package is to replace the [[Debian Post Install]] script.
+
=== Working directory structure ===
<pre>
+
Here's an example directory structure for a package which replaces the apache default config file and sets up default php and html files in ''/var/www''.
Package: organicdesign-server
+
{{code|{{#tree:root=example-package|
Version: 1.0
+
*DEBIAN
Section: admin
+
**control
Priority: optional
+
**postinst
Architecture: all
+
**postrm
Essential: no
+
**prerm
Depends: build-essential, p7zip-full, bzip2, rar, htmldoc, subversion, mysql-server-5.0, apache2, libapache2-svn,
+
*etc
        libapache2-mod-php5, php5-mysql, php5-gd, php5-xsl, php5-curl, php5-sqlite3, imagemagick, perlmagick,
+
**apache2
        librsvg2-bin, libwww-perl, libio-socket-ssl-perl, libtimedate-perl, libnet-scp-expect-perl
+
***sites-available
Maintainer: Aran Dunkley [aran@organicdesign.co.nz]
+
****default
Description: Installs everything required by an Organic Design server.
+
*var
</pre>
+
**www
 +
***index.php
 +
***index.html
 +
***index.php5
 +
}}}}
 +
The ''control'' file in the DEBIAN sub-directory is where all the main configuration is done. The other three files in that sub-directory are scripts which execute on installation and removal of the package.
  
Need to add this script
+
The rest of the directory structure outside the DEBIAN sub-directory define the directory structure which will be merged with the root of the filesystem when the package is installed.
ln -s /etc/apache2/mods-available/ssl.conf /etc/apache2/mods-enabled/ssl.conf
 
ln -s /etc/apache2/mods-available/ssl.load /etc/apache2/mods-enabled/ssl.load
 
ln -s /etc/apache2/mods-available/rewrite.load /etc/apache2/mods-enabled/rewrite.load
 
  
== organicdesign-mail ==
+
Our packages at Organic Design are in ''/var/www/domains/packages'' and the source directory structures for them are in the ''sources'' subdirectory.
This package will set up IMAP, POP3 and webmail
 
  
== organicdesign-workstation ==
+
=== Building or updating a package ===
This package will ultimately replace the [[Ubuntu Post Install]] so that a freshly installed Ubuntu workstation simply needs to ''apt-get organicdesign-workstation''.
+
Next the source needs to be built into a .deb file, if this is being done for an existing package which is being updated, then don't forget to ensure that the version number in the control file is larger.
<pre>
 
Package: organicdesign-workstation
 
Version: 1.0
 
Section: admin
 
Priority: optional
 
Architecture: all
 
Essential: no
 
Depends: build-essential, p7zip-full, bzip2, rar, thunderbird, geany, vlc, inkscape, samba, gparted, ntfsprogs, sysinfo
 
Maintainer: Aran Dunkley [aran@organicdesign.co.nz]
 
Description: Installs everything required by an Organic Design workstation.
 
</pre>
 
  
Still need to include
+
To turn the directory structure into a proper ''.deb'' package file, use:
*Skype
+
<source>
*Wine with IE 6 & 7
+
cd /var/www/domains/packages
*Advanced Desktop Effects Settings
+
dpkg -b source/<package-name> main/<package-name>.deb
 +
</source>
  
== organicdesign-toshiba-satellite-A210 ==
+
=== Adding to a package repository ===
Packages which are little more than collections of other packages are pretty easy to make, so once we have the procedure clearly documented, we may as well package up other specific things such as the installation of specific drivers and configuration for our laptops. Currently the details are in [[Toshiba Satellite A210 (701)]].
+
All the ''.deb'' package files must be added to the ''main'' repository on the server which is in ''/var/www/packages/main''. Ensure that this repository is included in your ''/etc/apt/sources.list'':
 +
<source>
 +
echo "deb http://packages.organicdesign.co.nz main/" >> /etc/apt/sources.list
 +
</source>
 +
 
 +
 
 +
Whenever any of the packages in the repository change, the ''Packages.gz'' index file must be updated which can be done as follows.
 +
<source>
 +
cd /var/www/domains/packages
 +
dpkg-scanpackages main /dev/null | gzip > main/Packages.gz
 +
</source>
 +
 
 +
== Creating a GPG Key ==
 +
<source>
 +
gpg --gen-key
 +
</source>
 +
*Don't choose a password for signing, or automated package processing will not work.
 +
 
 +
Export the public key for import into apt:
 +
<source>
 +
gpg --list-public-keys
 +
</source>
 +
 
 +
 
 +
Using the line that states "pub" look for the hex numbers after the / (eg. pub 1024D/5F6DEDCD 2008-07-10)
 +
 
 +
We'll use my temporary key hex for this example, be sure to change it.
 +
<source>
 +
gpg --export 0x5F6DEDCD >repo.key
 +
</source>
 +
 
 +
 
 +
Whenever you connect a new system to this apt repository you will need to place a copy of the key into your working directory and issue the following command:
 +
<source>
 +
apt-key add repo.key
 +
</source>
 +
 
 +
== Modifying dependencies in a .deb file ==
 +
# dpkg-deb -x foo.deb tmpdir
 +
# dpkg-deb --control foo.deb tmpdir/DEBIAN
 +
# nano tmpdir/DEBIAN/control
 +
# dpkg -b tmpdir hacked.deb
  
 
== See also ==
 
== See also ==
 +
*[[Packages]] ''- we plan to manage our IT infrastructure using APT''
 +
*[[organicdesign-server]]
 +
*[[organicdesign-workstation]]
 
*[http://www.linuxdevices.com/articles/AT8047723203.html LinuxDevices instructions]
 
*[http://www.linuxdevices.com/articles/AT8047723203.html LinuxDevices instructions]
 
*[http://tldp.org/HOWTO/html_single/Debian-Binary-Package-Building-HOWTO TLDP HOWTO]
 
*[http://tldp.org/HOWTO/html_single/Debian-Binary-Package-Building-HOWTO TLDP HOWTO]
 
*[[Google:creating Debian packages]]
 
*[[Google:creating Debian packages]]
 +
*[http://mirror.atrpms.net/ccrma/man/man5/sources.list.5.html Format of sources.list file]

Latest revision as of 18:11, 22 May 2015

Procedure.svg Create or Update a Debian package
Organic Design procedure

General procedure

Working directory structure

Here's an example directory structure for a package which replaces the apache default config file and sets up default php and html files in /var/www.

The control file in the DEBIAN sub-directory is where all the main configuration is done. The other three files in that sub-directory are scripts which execute on installation and removal of the package.

The rest of the directory structure outside the DEBIAN sub-directory define the directory structure which will be merged with the root of the filesystem when the package is installed.

Our packages at Organic Design are in /var/www/domains/packages and the source directory structures for them are in the sources subdirectory.

Building or updating a package

Next the source needs to be built into a .deb file, if this is being done for an existing package which is being updated, then don't forget to ensure that the version number in the control file is larger.

To turn the directory structure into a proper .deb package file, use:

cd /var/www/domains/packages
dpkg -b source/<package-name> main/<package-name>.deb

Adding to a package repository

All the .deb package files must be added to the main repository on the server which is in /var/www/packages/main. Ensure that this repository is included in your /etc/apt/sources.list:

echo "deb http://packages.organicdesign.co.nz main/" >> /etc/apt/sources.list


Whenever any of the packages in the repository change, the Packages.gz index file must be updated which can be done as follows.

cd /var/www/domains/packages
dpkg-scanpackages main /dev/null | gzip > main/Packages.gz

Creating a GPG Key

gpg --gen-key
  • Don't choose a password for signing, or automated package processing will not work.

Export the public key for import into apt:

gpg --list-public-keys


Using the line that states "pub" look for the hex numbers after the / (eg. pub 1024D/5F6DEDCD 2008-07-10)

We'll use my temporary key hex for this example, be sure to change it.

gpg --export 0x5F6DEDCD >repo.key


Whenever you connect a new system to this apt repository you will need to place a copy of the key into your working directory and issue the following command:

apt-key add repo.key

Modifying dependencies in a .deb file

  1. dpkg-deb -x foo.deb tmpdir
  2. dpkg-deb --control foo.deb tmpdir/DEBIAN
  3. nano tmpdir/DEBIAN/control
  4. dpkg -b tmpdir hacked.deb

See also