3 To avoid cluttering our main Git repository with Debian source and
4 binary packages, we have set an APT repository up.
11 We use one single APT repository hosting multiple *suites*:
13 * We have a (read-only) suite for every past release: `0.9`,
15 * We have a suite for each *main* branch: `stable`, `testing`, `devel`
16 * We have a suite for each *topic* branch: `bugfix/*`, `feature/*`.
17 **Important note**: the APT suite corresponding to a given Git topic
18 branch contains *only* the packages this branch adds to the tag or
19 *main* branch it diverged from.
20 * We also have a less formal `unstable` suite, that should not be used
21 by any Tails git branch; it can be used as hosting space for other
22 packaging work we might do, e.g. acting as upstream or
24 * We also have a `debomatic-squeeze-backports-mozilla` suite, used
25 (hopefully temporarily) import build-deps for our web browser, that
26 are not available elsewhere (anymore). This suite is used by the
27 `squeeze-backports-mozilla` chroot in our [[contribute/Debian
29 * We also have a `builder-wheezy` suite, used to provide additional
30 packages needed on a Wheezy system to build Tails.
32 The suite(s) to use as sources for APT, during the build and inside
33 the resulting system, are determined at Tails build time
34 (`auto/config`). See details in the *Build system* section bellow.
36 We manage our APT repository with
37 [reprepro](http://mirrorer.alioth.debian.org/).
39 The Puppet modules used to manage this part of our infrastructure are
40 listed on our [[contribute/Git]] page.
42 Basically, a cronjob fetches and scans the Tails Git repository every
43 few minutes, detects new branches, and accordingly:
45 - generates `conf/distributions`
46 - generates `conf/incoming`
47 - create new suites in the APT repository
52 The build system adds the relevant APT sources:
54 * if the version in `debian/changelog` was released already (i.e.
55 a matching tag exists), then add the suite corresponding to this
56 release (e.g. `0.10` or `0.10.1`);
57 * else, if building from the `testing` branch, add the `testing` suite
58 * else, if building from the `experimental` branch, add the `experimental` suite
59 * else, if building from the `devel` branch, add its own suite
61 Also, if we're building from a bugfix or feature branch, add its
67 One must configure their SSH client to connect to the APT server:
69 Host incoming.deb.tails.boum.org
75 This is the http:// public APT repository used at Tails
76 build time. The `tails::reprepro` Puppet class sets nginx up to
85 Push your branch to Git and wait a few minutes for the new APT suite
88 Importing a new package
89 -----------------------
91 ### Building a package
93 Make sure the `Distribution:` field in your `.changes` file matches
94 the suite you want the package to land in (e.g.
95 pass `--changes-option=-DDistribution=feature-torbrowser` to
96 pdebuild's `--debbuildopts`).
98 Make sure to have the `.changes` file include the original source
99 archive (`.orig.tar.{gz,bz2,xz}`) if it is not already in our APT
100 repository; this can be done by passing `-sa` to pdebuild's
103 ### Configuring an upload tool
105 #### Configuring dupload
107 Add this configuration snippet to your `dupload` configuration:
109 $config::cfg{'tails'} = {
110 fqdn => "incoming.deb.tails.boum.org",
113 incoming => "/srv/reprepro/incoming/",
117 #### Confuguring dput
119 Add this to `.dput.cf`:
122 fqdn = incoming.deb.tails.boum.org
125 incoming = /srv/reprepro/incoming/
129 ### Uploading and importing process
131 Carefully prepare and build your package. Usual precautions, (Lintian
134 Carefully check the `.changes` file (especially the `Distribution`
135 control field, and the included files list; the former can be fixed
136 with the `changestool(1)` command, from [[!debpkg reprepro]]).
138 Sign the `.changes` file with a key that is in the uploaders list:
140 $ debsign $CHANGES_FILE
142 Upload the files to the incoming queue:
144 $ dupload --to tails $CHANGES_FILE
146 reprepro will automatically notice the new files and import them into
147 the suite specified in your `.changes` file.
151 $ ssh reprepro@incoming.deb.tails.boum.org reprepro list $SUITE $PACKAGENAME
153 <a id="workflow-merge-topic-branch"></a>
155 Merging a topic branch
156 ----------------------
158 When a Git *topic* branch is merged into a *main* branch, the
159 corresponding operation must be done on the APT suites.
164 $ git merge feature/icedove
165 $ ssh reprepro@incoming.deb.tails.boum.org \
166 tails-merge-suite feature-icedove devel
169 (Note that unfortunately, contrary to what whoever with a Git
170 background would guess, the reprepro operation called *pull* is not
171 what we want: it pulls from *all* other suites into the ones specified
172 on the command-line.)
174 <a id="workflow-merge-main-branch"></a>
176 Merging a main branch
177 ----------------------
179 When a Git *main* branch (`devel`, `experimental`, `testing`,
180 `stable`) is merged into another *main* branch, the corresponding
181 operation must be done on the APT suites.
183 1. Save the list of packages currently present in the APT suite we
184 want to merge *into*, e.g. `reprepro list experimental`.
185 2. Make sure you are not going to overwrite newer packages with
187 3. Merge the APT suites [[the same way as when we merge a topic
188 branch|APT_repository#workflow-merge-topic-branch]].
189 4. Make sure not to re-add, into the branch we merge into, any package
190 that was removed from it, but still is in the branch we merge from:
191 e.g. when merging `devel` into `experimental`, it may be that
192 `experimental` had some packages removed (e.g. due to previously
193 merging a topic branch into it, whose purpose is to *remove* custom
194 packages). To this end, compare the resulting list of (package,
195 version) in the `experimental` APT suite with the one saved before
196 the merge (hint: use the `tails-diff-suites` script), check Git
197 merges history if needed, apply common sense, and remove from
198 `experimental` the packages that were removed from it a while ago,
199 and were just erroneously re-added by the merge operation.
201 <a id="workflow-reset"></a>
203 Resetting a suite to the state of another one
204 ---------------------------------------------
206 a. First, set some environment variables:
210 # the final state it should be in
213 b. Then, empty the `OLD` suite:
215 ssh reprepro@incoming.deb.tails.boum.org \
216 reprepro removematched $OLD '\*'
218 c. Finally, merge `NEW` into `OLD`
220 ssh reprepro@incoming.deb.tails.boum.org \
221 tails-merge-suite $NEW $OLD
223 <a id="workflow-freeze"></a>
225 Freezing devel into testing
226 ---------------------------
228 1. Merge `devel` branch into `testing` in Git
229 2. (Manually) [[hard reset|APT_repository#workflow-reset]] the
230 `testing` suite to the current state of the `devel` one.
232 <a id="workflow-post-tag"></a>
234 Tagging a new Tails release
235 ---------------------------
237 Once the new release's Git tag is pushed, a cronjob should create
238 a new APT suite on the APT repository's side within a few minutes.
239 This new APT suite is called the same as the new release version.
240 One may check it has appeared in `~reprepro/conf/distributions`.
242 Then, the APT suite corresponding to the branch that was used to
243 prepare the release must be copied to the new empty APT suite that
246 If this is a major release:
248 $ ssh reprepro@incoming.deb.tails.boum.org \
249 tails-merge-suite testing $TAG
251 Else, if this is a point-release:
253 $ ssh reprepro@incoming.deb.tails.boum.org \
254 tails-merge-suite stable $TAG
256 <a id="workflow-post-release"></a>
258 After a new Tails release is out
259 --------------------------------
261 If you just put out a final release:
263 * [[merge `stable` or `testing` into
264 `devel`|APT_repository#workflow-merge-main-branch]]
265 * increment the version number in devel's `debian/changelog` to match
266 the next major release, so that
267 next builds from the `devel` branch do not use the APT suite meant
269 * increment the version number in devel's `debian/changelog` to match
270 the next point release, so that
271 next builds from the `stable` branch do not use the APT suite meant
274 If you just released a RC:
276 * add a dummy changelog entry (for the upcoming, non-RC version) in
277 the branch used for the release (`stable` or `testing`), so that the
278 next builds from it do not use the APT suite meant for the RC
279 * add a dummy changelog entry (for the release *after* the one you
280 released a RC for) in the branch used for the release (`stable` or
281 `testing`), so that the next builds from it do not use the APT suite
284 If the release was a major one, then [[reset the stable APT suite to
285 the state of the testing one|APT_repository#workflow-reset]].
287 Giving access to a core developer
288 ---------------------------------
290 1. Give SSH access to the `reprepro` user on the system that hosts
291 reprepro (using the `ssh_authorized_key` Puppet resource).
292 2. Import the developer's public GnuPG key into the `reprepro` user's
293 GnuPG keyring -- should be doable using Puppet, some day
294 3. Add the developer's OpenPGP key ID to `$reprepro_uploaders` in our
295 `tails::reprepro` Puppet module. Deploy.
297 Contributing without privileged access
298 --------------------------------------
300 Non-core developers without access to the "private" APT infrastructure
301 would add the .deb they want to their Git branch as we have been
302 doing until now, push the result on repo.or.cz or whatever... and at
303 merge time, we would rewrite their history to remove the .deb, and
304 import it into our APT repo.